1
0
mirror of https://github.com/danog/psalm.git synced 2024-12-15 19:07:00 +01:00
psalm/src/Psalm/Checker/SourceChecker.php

227 lines
4.9 KiB
PHP
Raw Normal View History

2016-11-21 03:49:06 +01:00
<?php
namespace Psalm\Checker;
use PhpParser\Node\Stmt\Namespace_;
use PhpParser;
use Psalm\Context;
use Psalm\StatementsSource;
use Psalm\Type;
abstract class SourceChecker implements StatementsSource
{
/**
* @var StatementsSource|null
*/
protected $source = null;
/**
* @var FileChecker|null
*/
protected $file_checker;
2016-11-21 05:45:10 +01:00
/**
2017-01-07 20:35:07 +01:00
* @return array<string, string>
2016-11-21 05:45:10 +01:00
*/
2017-01-07 20:35:07 +01:00
public function getAliasedClasses()
2016-11-21 03:49:06 +01:00
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
2016-11-21 04:40:19 +01:00
}
2017-01-07 20:35:07 +01:00
return $this->source->getAliasedClasses();
2016-11-21 03:49:06 +01:00
}
/**
* @return array<string, string>
2016-11-21 03:49:06 +01:00
*/
public function getAliasedClassesFlipped()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getAliasedClassesFlipped();
2016-11-21 03:49:06 +01:00
}
/**
* Gets a list of all aliased constants
*
2017-01-07 20:35:07 +01:00
* @return array<string, string>
2016-11-21 03:49:06 +01:00
*/
public function getAliasedConstants()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getAliasedConstants();
2016-11-21 03:49:06 +01:00
}
/**
* Gets a list of all aliased functions
*
2017-01-07 20:35:07 +01:00
* @return array<string, string>
2016-11-21 03:49:06 +01:00
*/
public function getAliasedFunctions()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getAliasedFunctions();
2016-11-21 03:49:06 +01:00
}
/**
2017-01-07 20:35:07 +01:00
* @return string|null
2016-11-21 03:49:06 +01:00
*/
public function getFQCLN()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getFQCLN();
2016-11-21 03:49:06 +01:00
}
/**
2017-01-07 20:35:07 +01:00
* @return string|null
2016-11-21 03:49:06 +01:00
*/
public function getClassName()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
2016-11-21 03:49:06 +01:00
2017-01-07 20:35:07 +01:00
return $this->source->getClassName();
2016-11-21 03:49:06 +01:00
}
/**
* @return FileChecker
* @psalm-suppress InvalidReturnType because it basically always returns a file checker
*/
public function getFileChecker()
{
return $this->file_checker;
}
2016-11-21 03:49:06 +01:00
/**
* @return string|null
*/
2017-01-07 20:35:07 +01:00
public function getParentFQCLN()
2016-11-21 03:49:06 +01:00
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getParentFQCLN();
2016-11-21 03:49:06 +01:00
}
/**
* @return string
*/
public function getFileName()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getFileName();
2016-11-21 03:49:06 +01:00
}
/**
* @return string
*/
public function getFilePath()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getFilePath();
}
2016-11-21 03:49:06 +01:00
/**
* @param string|null $file_name
* @param string|null $file_path
2016-11-21 03:49:06 +01:00
* @return void
*/
2017-01-08 01:33:33 +01:00
public function setFileName($file_name, $file_path)
2016-11-21 03:49:06 +01:00
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
2017-01-08 01:33:33 +01:00
$this->source->setFileName($file_name, $file_path);
2016-11-21 03:49:06 +01:00
}
/**
* @return string
*/
public function getCheckedFileName()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getCheckedFileName();
2016-11-21 03:49:06 +01:00
}
/**
* @return string
*/
public function getCheckedFilePath()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
2017-01-07 20:35:07 +01:00
return $this->source->getCheckedFilePath();
2016-11-21 03:49:06 +01:00
}
/**
* @return StatementsSource
2016-11-21 03:49:06 +01:00
*/
public function getSource()
{
return $this->source ?: $this;
2016-11-21 03:49:06 +01:00
}
/**
* Get a list of suppressed issues
*
* @return array<string>
*/
public function getSuppressedIssues()
{
2017-01-07 20:35:07 +01:00
if ($this->source === null) {
throw new \UnexpectedValueException('$source cannot be null');
}
return $this->source->getSuppressedIssues();
2016-11-21 03:49:06 +01:00
}
2016-12-17 06:48:31 +01:00
/**
* @return string
*/
2016-12-17 06:48:31 +01:00
public function getNamespace()
{
2017-01-07 20:35:07 +01: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 06:48:31 +01:00
}
2016-11-21 03:49:06 +01:00
}