2016-11-20 21:49:06 -05:00
|
|
|
<?php
|
|
|
|
namespace Psalm\Checker;
|
|
|
|
|
2017-07-25 16:11:02 -04:00
|
|
|
use Psalm\Aliases;
|
2016-11-20 21:49:06 -05:00
|
|
|
use Psalm\StatementsSource;
|
|
|
|
|
|
|
|
abstract class SourceChecker implements StatementsSource
|
|
|
|
{
|
2017-01-02 15:31:18 -05:00
|
|
|
/**
|
|
|
|
* @var StatementsSource|null
|
|
|
|
*/
|
|
|
|
protected $source = null;
|
|
|
|
|
2016-11-20 23:45:10 -05:00
|
|
|
/**
|
2017-07-25 16:11:02 -04:00
|
|
|
* @return Aliases
|
2016-11-20 23:45:10 -05:00
|
|
|
*/
|
2017-07-25 16:11:02 -04:00
|
|
|
public function getAliases()
|
2016-11-20 21:49:06 -05:00
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
2016-11-20 22:40:19 -05:00
|
|
|
}
|
|
|
|
|
2017-07-25 16:11:02 -04:00
|
|
|
return $this->source->getAliases();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-12-24 18:23:22 +00:00
|
|
|
* @return array<string, string>
|
2016-11-20 21:49:06 -05:00
|
|
|
*/
|
|
|
|
public function getAliasedClassesFlipped()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getAliasedClassesFlipped();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-01-07 14:35:07 -05:00
|
|
|
* @return string|null
|
2016-11-20 21:49:06 -05:00
|
|
|
*/
|
|
|
|
public function getFQCLN()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getFQCLN();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-01-07 14:35:07 -05:00
|
|
|
* @return string|null
|
2016-11-20 21:49:06 -05:00
|
|
|
*/
|
|
|
|
public function getClassName()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
2016-11-20 21:49:06 -05:00
|
|
|
|
2017-01-07 14:35:07 -05:00
|
|
|
return $this->source->getClassName();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
2017-01-02 15:31:18 -05:00
|
|
|
/**
|
|
|
|
* @return FileChecker
|
|
|
|
*/
|
2017-07-29 15:05:06 -04:00
|
|
|
abstract public function getFileChecker();
|
2017-01-02 15:31:18 -05:00
|
|
|
|
2016-11-20 21:49:06 -05:00
|
|
|
/**
|
|
|
|
* @return string|null
|
|
|
|
*/
|
2017-01-07 14:35:07 -05:00
|
|
|
public function getParentFQCLN()
|
2016-11-20 21:49:06 -05:00
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getParentFQCLN();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getFileName()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getFileName();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
2016-12-03 19:11:30 -05:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getFilePath()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getFilePath();
|
2016-12-03 19:11:30 -05:00
|
|
|
}
|
|
|
|
|
2016-11-20 21:49:06 -05:00
|
|
|
/**
|
|
|
|
* @param string|null $file_name
|
2016-12-03 19:11:30 -05:00
|
|
|
* @param string|null $file_path
|
2017-05-26 20:16:18 -04:00
|
|
|
*
|
2016-11-20 21:49:06 -05:00
|
|
|
* @return void
|
|
|
|
*/
|
2017-01-07 19:33:33 -05:00
|
|
|
public function setFileName($file_name, $file_path)
|
2016-11-20 21:49:06 -05:00
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
2017-01-07 19:33:33 -05:00
|
|
|
$this->source->setFileName($file_name, $file_path);
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getCheckedFileName()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getCheckedFileName();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
2016-12-03 19:11:30 -05:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getCheckedFilePath()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
2016-12-03 19:11:30 -05:00
|
|
|
|
2017-01-07 14:35:07 -05:00
|
|
|
return $this->source->getCheckedFilePath();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2017-01-02 15:31:18 -05:00
|
|
|
* @return StatementsSource
|
2016-11-20 21:49:06 -05:00
|
|
|
*/
|
|
|
|
public function getSource()
|
|
|
|
{
|
2017-01-02 15:31:18 -05:00
|
|
|
return $this->source ?: $this;
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a list of suppressed issues
|
|
|
|
*
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public function getSuppressedIssues()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getSuppressedIssues();
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|
2016-12-17 00:48:31 -05:00
|
|
|
|
2017-10-26 18:19:19 -04:00
|
|
|
/**
|
|
|
|
* @param array<int, string> $new_issues
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function addSuppressedIssues(array $new_issues)
|
|
|
|
{
|
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->addSuppressedIssues($new_issues);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array<int, string> $new_issues
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function removeSuppressedIssues(array $new_issues)
|
|
|
|
{
|
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->removeSuppressedIssues($new_issues);
|
|
|
|
}
|
|
|
|
|
2017-01-06 01:07:11 -05:00
|
|
|
/**
|
2017-11-26 16:03:17 -05:00
|
|
|
* @return ?string
|
2017-01-06 01:07:11 -05:00
|
|
|
*/
|
2016-12-17 00:48:31 -05:00
|
|
|
public function getNamespace()
|
|
|
|
{
|
2017-01-07 14:35:07 -05:00
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->getNamespace();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isStatic()
|
|
|
|
{
|
|
|
|
if ($this->source === null) {
|
|
|
|
throw new \UnexpectedValueException('$source cannot be null');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->source->isStatic();
|
2016-12-17 00:48:31 -05:00
|
|
|
}
|
2016-11-20 21:49:06 -05:00
|
|
|
}
|