1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-21 21:31:13 +01:00

Preserve self refs where possible

This commit is contained in:
Matthew Brown 2019-11-16 19:59:08 -05:00
parent 7d7d4dd926
commit 2369bac943
8 changed files with 47 additions and 27 deletions

View File

@ -1149,7 +1149,9 @@ abstract class FunctionLikeAnalyzer extends SourceAnalyzer implements Statements
$this,
$param_name_node,
$resolved_name,
$context->calling_method_id
$context->calling_method_id,
false,
true
);
}
}
@ -1181,7 +1183,9 @@ abstract class FunctionLikeAnalyzer extends SourceAnalyzer implements Statements
$this,
$return_name_node,
$resolved_name,
$context->calling_method_id
$context->calling_method_id,
false,
true
);
}
}

View File

@ -974,7 +974,8 @@ class StaticCallAnalyzer extends \Psalm\Internal\Analyzer\Statements\Expression\
$stmt->class,
$new_fq_class_name,
$context->calling_method_id,
strtolower($old_declaring_fq_class_name) !== strtolower($new_fq_class_name)
strtolower($old_declaring_fq_class_name) !== strtolower($new_fq_class_name),
$stmt->class->parts[0] === 'self'
)) {
$moved_call = true;
}
@ -1087,7 +1088,9 @@ class StaticCallAnalyzer extends \Psalm\Internal\Analyzer\Statements\Expression\
$statements_analyzer,
$stmt->class,
$fq_class_name,
$context->calling_method_id
$context->calling_method_id,
false,
$stmt->class->parts[0] === 'self'
);
}

View File

@ -97,7 +97,9 @@ class ClassConstFetchAnalyzer
$statements_analyzer,
$stmt->class,
$fq_class_name,
$context->calling_method_id
$context->calling_method_id,
false,
$stmt->class->parts[0] === 'self'
);
}

View File

@ -1027,7 +1027,8 @@ class ClassLikes
PhpParser\Node $class_name_node,
string $fq_class_name,
?string $calling_method_id,
bool $force_change = false
bool $force_change = false,
bool $was_self = false
) : bool {
$calling_fq_class_name = $source->getFQCLN();
@ -1050,7 +1051,8 @@ class ClassLikes
$source->getFilePath(),
(int) $class_name_node->getAttribute('startFilePos'),
(int) $class_name_node->getAttribute('endFilePos') + 1,
$class_name_node instanceof PhpParser\Node\Scalar\MagicConst\Class_
$class_name_node instanceof PhpParser\Node\Scalar\MagicConst\Class_,
$was_self
);
return true;
@ -1120,7 +1122,8 @@ class ClassLikes
$new_fq_class_name,
$source_namespace,
$uses_flipped,
$migrated_source_fqcln
$migrated_source_fqcln,
$was_self
)
. ($class_name_node instanceof PhpParser\Node\Scalar\MagicConst\Class_ ? '::class' : '')
);
@ -1330,7 +1333,8 @@ class ClassLikes
string $source_file_path,
int $source_start,
int $source_end,
bool $add_class_constant = false
bool $add_class_constant = false,
bool $allow_self = false
) : void {
$project_analyzer = \Psalm\Internal\Analyzer\ProjectAnalyzer::getInstance();
$codebase = $project_analyzer->getCodebase();
@ -1350,7 +1354,8 @@ class ClassLikes
$fq_class_name,
$destination_class_storage->aliases->namespace,
$destination_class_storage->aliases->uses_flipped,
$destination_class_storage->name
$destination_class_storage->name,
$allow_self
) . ($add_class_constant ? '::class' : '')
);

View File

@ -1100,9 +1100,10 @@ abstract class Type
string $value,
?string $namespace,
array $aliased_classes,
?string $this_class
?string $this_class,
bool $allow_self = false
) : string {
if ($value === $this_class) {
if ($allow_self && $value === $this_class) {
return 'self';
}

View File

@ -77,7 +77,8 @@ class TNamedObject extends Atomic
$use_phpdoc_format
);
return Type::getStringFromFQCLN($this->value, $namespace, $aliased_classes, $this_class) . $intersection_types;
return Type::getStringFromFQCLN($this->value, $namespace, $aliased_classes, $this_class, true)
. $intersection_types;
}
/**

View File

@ -219,6 +219,7 @@ class ClassMoveTest extends \Psalm\Tests\TestCase
*/
public static function foo(self $one, A $two) : void {
A::foo($one, $two);
self::foo($one, $two);
parent::foo($one, $two);
static::foo($one, $two);
return new static();
@ -248,6 +249,7 @@ class ClassMoveTest extends \Psalm\Tests\TestCase
* @return static
*/
public static function foo(self $one, self $two) : void {
B::foo($one, $two);
self::foo($one, $two);
parent::foo($one, $two);
static::foo($one, $two);
@ -367,6 +369,7 @@ class ClassMoveTest extends \Psalm\Tests\TestCase
echo \A::class;
echo __CLASS__;
echo self::class;
ArrayObject::foo();
@ -399,7 +402,8 @@ class ClassMoveTest extends \Psalm\Tests\TestCase
}
echo self::class;
echo B::class;
echo B::class;
echo self::class;
\ArrayObject::foo();

View File

@ -116,8 +116,8 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
class B {
public static function bar() : void {
self::Fe();
foreach (self::Fe() as $f) {}
B::Fe();
foreach (B::Fe() as $f) {}
}
/**
@ -356,11 +356,11 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
echo A::C;
A::Bar();
A::Bar();
echo self::D;
echo B::D;
new A();
/** @var A */
$a = new A();
new self();
new B();
return $a;
}
@ -433,12 +433,12 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
echo A::C;
echo A::C;
self::Blacksheep();
self::Blacksheep();
echo self::D;
B::Blacksheep();
echo B::D;
new A();
/** @var A */
$a = new A();
new self();
new B();
return $a;
}
@ -515,11 +515,11 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
echo A::C;
$this->Bar();
A::Bar();
echo self::D;
echo AChild::D;
new A();
/** @var A */
$a = new A();
new self();
new AChild();
return $a;
}
@ -559,7 +559,7 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
class B {
public static function bar() : void {
self::Fe();
B::Fe();
}
/**
@ -598,7 +598,7 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
class B {
public static function bar() : void {
self::Fe();
B::Fe();
}
/**
@ -652,7 +652,7 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
namespace Ns2\Ns3 {
class B {
public static function bar() : void {
self::Fe();
B::Fe();
}
/**
@ -705,7 +705,7 @@ class MethodMoveTest extends \Psalm\Tests\TestCase
class B {
public static function bar() : void {
self::Fedcba();
B::Fedcba();
}
/**