1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-22 13:51:54 +01:00
psalm/tests/Internal/Provider/FakeFileReferenceCacheProvider.php

298 lines
6.6 KiB
PHP
Raw Normal View History

2018-09-29 23:51:06 -04:00
<?php
namespace Psalm\Tests\Internal\Provider;
2018-09-29 23:51:06 -04:00
/**
* Used to determine which files reference other files, necessary for using the --diff
* option from the command line.
*/
2018-11-05 21:57:36 -05:00
class FakeFileReferenceCacheProvider extends \Psalm\Internal\Provider\FileReferenceCacheProvider
2018-09-29 23:51:06 -04:00
{
/** @var ?array */
private $cached_file_references;
/** @var ?array */
private $cached_classlike_files;
/** @var ?array */
private $cached_method_class_references;
/** @var ?array */
private $cached_nonmethod_class_references;
2018-09-29 23:51:06 -04:00
/** @var ?array */
private $cached_method_member_references;
/** @var ?array */
private $cached_file_member_references;
/** @var ?array */
private $cached_method_missing_member_references;
/** @var ?array */
private $cached_file_missing_member_references;
2018-09-29 23:51:06 -04:00
2019-04-27 17:38:24 -04:00
/** @var ?array */
private $cached_unknown_member_references;
/** @var ?array */
private $cached_method_param_uses;
2018-09-29 23:51:06 -04:00
/** @var ?array */
private $cached_issues;
/** @var array<string, array<string, int>> */
2018-09-29 23:51:06 -04:00
private $cached_correct_methods = [];
/**
* @var array<
* string,
* array{
2020-05-15 10:18:05 -04:00
* 0: array<int, array{0: int, 1: non-empty-string}>,
* 1: array<int, array{0: int, 1: non-empty-string}>,
* 2: array<int, array{0: int, 1: non-empty-string, 2: int}>
* }
* >
*/
2018-10-17 15:52:58 -04:00
private $cached_file_maps = [];
2020-06-06 16:57:25 -04:00
public function __construct()
{
2020-06-06 12:06:31 -04:00
$this->config = \Psalm\Config::getInstance();
}
2018-09-29 23:51:06 -04:00
/**
* @return ?array
*/
public function getCachedFileReferences()
{
return $this->cached_file_references;
}
/**
* @return ?array
*/
public function getCachedClassLikeFiles()
{
return $this->cached_classlike_files;
}
/**
* @return ?array
*/
public function getCachedMethodClassReferences()
{
return $this->cached_method_class_references;
}
/**
* @return ?array
*/
public function getCachedNonMethodClassReferences()
{
return $this->cached_method_class_references;
}
2018-09-29 23:51:06 -04:00
/**
* @return ?array
*/
public function getCachedFileMemberReferences()
{
return $this->cached_file_member_references;
}
/**
* @return ?array
*/
public function getCachedMethodMemberReferences()
2018-09-29 23:51:06 -04:00
{
return $this->cached_method_member_references;
}
/**
* @return ?array
*/
public function getCachedFileMissingMemberReferences()
{
return $this->cached_file_missing_member_references;
}
2019-04-27 17:38:24 -04:00
/**
* @return ?array
*/
public function getCachedMixedMemberNameReferences()
{
return $this->cached_unknown_member_references;
}
/**
* @return ?array
*/
public function getCachedMethodMissingMemberReferences()
{
return $this->cached_method_missing_member_references;
2018-09-29 23:51:06 -04:00
}
/**
* @return ?array
*/
public function getCachedMethodParamUses()
{
return $this->cached_method_missing_member_references;
}
2018-09-29 23:51:06 -04:00
/**
* @return ?array
*/
public function getCachedIssues()
{
return $this->cached_issues;
}
/**
* @return void
*/
public function setCachedFileReferences(array $file_references)
{
$this->cached_file_references = $file_references;
}
/**
* @return void
*/
public function setCachedClassLikeFiles(array $file_references)
{
$this->cached_classlike_files = $file_references;
}
/**
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setCachedMethodClassReferences(array $method_class_references)
{
2020-08-09 23:19:59 -04:00
$this->cached_method_class_references = $method_class_references;
}
/**
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setCachedNonMethodClassReferences(array $file_class_references)
{
2020-08-09 23:19:59 -04:00
$this->cached_nonmethod_class_references = $file_class_references;
}
2018-09-29 23:51:06 -04:00
/**
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setCachedMethodMemberReferences(array $member_references)
{
2020-08-09 23:19:59 -04:00
$this->cached_method_member_references = $member_references;
}
/**
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setCachedMethodMissingMemberReferences(array $member_references)
{
2020-08-09 23:19:59 -04:00
$this->cached_method_missing_member_references = $member_references;
}
/**
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setCachedFileMemberReferences(array $member_references)
{
2020-08-09 23:19:59 -04:00
$this->cached_file_member_references = $member_references;
}
/**
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setCachedFileMissingMemberReferences(array $member_references)
2018-09-29 23:51:06 -04:00
{
2020-08-09 23:19:59 -04:00
$this->cached_file_missing_member_references = $member_references;
2018-09-29 23:51:06 -04:00
}
2019-04-27 17:38:24 -04:00
/**
* @return void
*/
public function setCachedMixedMemberNameReferences(array $references)
{
$this->cached_unknown_member_references = $references;
}
/**
* @return void
*/
public function setCachedMethodParamUses(array $uses)
{
$this->cached_method_param_uses = $uses;
}
2018-09-29 23:51:06 -04:00
/**
* @return void
*/
public function setCachedIssues(array $issues)
{
$this->cached_issues = $issues;
}
/**
* @return array<string, array<string, int>>
2018-09-29 23:51:06 -04:00
*/
2018-11-01 21:52:39 -04:00
public function getAnalyzedMethodCache()
2018-09-29 23:51:06 -04:00
{
return $this->cached_correct_methods;
}
/**
2020-08-09 23:19:59 -04:00
* @param array<string, array<string, int>> $analyzed_methods
2019-03-23 14:27:54 -04:00
*
2018-09-29 23:51:06 -04:00
* @return void
*/
2020-08-09 23:19:59 -04:00
public function setAnalyzedMethodCache(array $analyzed_methods)
2018-09-29 23:51:06 -04:00
{
2020-08-09 23:19:59 -04:00
$this->cached_correct_methods = $analyzed_methods;
2018-09-29 23:51:06 -04:00
}
2018-10-17 15:52:58 -04:00
/**
* @return array<
* string,
* array{
2020-05-15 10:18:05 -04:00
* 0: array<int, array{0: int, 1: non-empty-string}>,
* 1: array<int, array{0: int, 1: non-empty-string}>,
* 2: array<int, array{0: int, 1: non-empty-string, 2: int}>
* }
* >
2018-10-17 15:52:58 -04:00
*/
public function getFileMapCache()
{
return $this->cached_file_maps;
}
/**
* @param array<
* string,
* array{
2020-05-15 10:18:05 -04:00
* 0: array<int, array{0: int, 1: non-empty-string}>,
* 1: array<int, array{0: int, 1: non-empty-string}>,
* 2: array<int, array{0: int, 1: non-empty-string, 2: int}>
* }
* > $file_maps
2019-03-23 14:27:54 -04:00
*
2018-10-17 15:52:58 -04:00
* @return void
*/
public function setFileMapCache(array $file_maps)
{
$this->cached_file_maps = $file_maps;
}
2020-06-06 16:57:25 -04:00
/**
* @param array<string, array{int, int}> $mixed_counts
*
* @return void
*/
public function setTypeCoverage(array $mixed_counts)
{
}
2018-09-29 23:51:06 -04:00
}