1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-07 05:28:37 +01:00
psalm/src/Psalm/Internal/Provider/FileStorageProvider.php

158 lines
3.2 KiB
PHP
Raw Normal View History

<?php
2018-11-06 03:57:36 +01:00
namespace Psalm\Internal\Provider;
2019-07-05 22:24:00 +02:00
use function array_merge;
use Psalm\Storage\FileStorage;
use function strtolower;
/**
* @internal
*/
class FileStorageProvider
{
/**
* A list of data useful to analyse files
* Storing this statically is much faster (at least in PHP 7.2.1)
*
* @var array<string, FileStorage>
*/
private static $storage = [];
/**
* A list of data useful to analyse new files
* Storing this statically is much faster (at least in PHP 7.2.1)
*
* @var array<string, FileStorage>
*/
private static $new_storage = [];
2018-02-19 06:27:39 +01:00
/**
* @var ?FileStorageCacheProvider
2018-02-19 06:27:39 +01:00
*/
public $cache;
public function __construct(FileStorageCacheProvider $cache = null)
2018-02-19 06:27:39 +01:00
{
$this->cache = $cache;
}
/**
* @param string $file_path
*
* @return FileStorage
*/
public function get($file_path)
{
$file_path = strtolower($file_path);
if (!isset(self::$storage[$file_path])) {
throw new \InvalidArgumentException('Could not get file storage for ' . $file_path);
}
return self::$storage[$file_path];
}
/**
* @param string $file_path
*
* @return void
*/
public function remove($file_path)
{
unset(self::$storage[strtolower($file_path)]);
}
2018-02-19 06:27:39 +01:00
/**
* @param string $file_path
* @param string $file_contents
*
* @return bool
*/
public function has($file_path, string $file_contents = null)
2018-02-19 06:27:39 +01:00
{
$file_path = strtolower($file_path);
if (isset(self::$storage[$file_path])) {
return true;
}
if ($file_contents === null) {
return false;
}
if (!$this->cache) {
return false;
}
2018-02-19 06:27:39 +01:00
$cached_value = $this->cache->getLatestFromCache($file_path, $file_contents);
2018-02-19 06:27:39 +01:00
if (!$cached_value) {
return false;
}
2018-02-19 06:27:39 +01:00
self::$storage[$file_path] = $cached_value;
self::$new_storage[$file_path] = $cached_value;
2018-02-19 06:27:39 +01:00
return true;
}
/**
* @return array<string, FileStorage>
*/
public function getAll()
{
return self::$storage;
}
/**
* @return array<string, FileStorage>
*/
public function getNew()
{
return self::$new_storage;
}
/**
* @param array<string, FileStorage> $more
2019-07-05 22:24:00 +02:00
*
* @return void
*/
public function addMore(array $more)
{
self::$new_storage = array_merge(self::$new_storage, $more);
self::$storage = array_merge(self::$storage, $more);
}
/**
* @param string $file_path
*
* @return FileStorage
*/
public function create($file_path)
{
$file_path_lc = strtolower($file_path);
$storage = new FileStorage($file_path);
self::$storage[$file_path_lc] = $storage;
self::$new_storage[$file_path_lc] = $storage;
return $storage;
}
/**
* @return void
*/
2018-01-21 18:44:46 +01:00
public static function deleteAll()
{
self::$storage = [];
}
/**
* @return void
*/
public static function populated()
{
self::$new_storage = [];
}
}