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

Bust cache when config changes, don’t rely on > modified time

This commit is contained in:
Brown 2018-11-01 17:42:48 -04:00
parent f017599b3f
commit df8b0a1fc5
4 changed files with 52 additions and 7 deletions

View File

@ -297,9 +297,9 @@ class Config
public $exit_functions = [];
/**
* @var int
* @var string
*/
public $modified_time = 0;
public $hash = '';
/** @var string|null */
public $error_baseline = null;
@ -388,7 +388,7 @@ class Config
try {
$config = self::loadFromXML($base_dir, $file_contents);
$config->modified_time = filemtime($file_path);
$config->hash = sha1($file_contents);
} catch (ConfigException $e) {
throw new ConfigException(
'Problem parsing ' . $file_path . ":\n" . ' ' . $e->getMessage()

View File

@ -43,7 +43,7 @@ class ClassLikeStorageCacheProvider
$this->modified_timestamps .= ' ' . filemtime($dependent_file_path);
}
$this->modified_timestamps .= PSALM_VERSION . $this->config->modified_time;
$this->modified_timestamps .= PSALM_VERSION . $this->config->hash;
}
/**

View File

@ -34,15 +34,23 @@ class FileReferenceCacheProvider
const CLASS_METHOD_CACHE_NAME = 'class_method_references';
const ISSUES_CACHE_NAME = 'issues';
const FILE_MAPS_CACHE_NAME = 'file_maps';
const CONFIG_HASH_CACHE_NAME = 'config';
/**
* @var Config
*/
private $config;
/**
* @var bool
*/
public $config_changed;
public function __construct(Config $config)
{
$this->config = $config;
$this->config_changed = $config->hash !== $this->getConfigHashCache();
$this->setConfigHashCache($config->hash);
}
/**
@ -191,7 +199,7 @@ class FileReferenceCacheProvider
if ($cache_directory
&& file_exists($correct_methods_cache_location)
&& filemtime($correct_methods_cache_location) > $this->config->modified_time
&& !$this->config_changed
) {
/** @var array<string, array<string, int>> */
return unserialize(file_get_contents($correct_methods_cache_location));
@ -229,7 +237,7 @@ class FileReferenceCacheProvider
if ($cache_directory
&& file_exists($file_maps_cache_location)
&& filemtime($file_maps_cache_location) > $this->config->modified_time
&& !$this->config_changed
) {
/** @var array<string, array{0: TaggedCodeType, 1: TaggedCodeType}> */
$file_maps_cache = unserialize(file_get_contents($file_maps_cache_location));
@ -256,4 +264,41 @@ class FileReferenceCacheProvider
);
}
}
/**
* @return string|false
*/
public function getConfigHashCache()
{
$cache_directory = $this->config->getCacheDirectory();
$config_hash_cache_location = $cache_directory . DIRECTORY_SEPARATOR . self::CONFIG_HASH_CACHE_NAME;
if ($cache_directory
&& file_exists($config_hash_cache_location)
) {
/** @var string */
$file_maps_cache = unserialize(file_get_contents($config_hash_cache_location));
return $file_maps_cache;
}
return false;
}
/**
* @return void
*/
public function setConfigHashCache(string $hash)
{
$cache_directory = Config::getInstance()->getCacheDirectory();
if ($cache_directory) {
$config_hash_cache_location = $cache_directory . DIRECTORY_SEPARATOR . self::CONFIG_HASH_CACHE_NAME;
file_put_contents(
$config_hash_cache_location,
serialize($hash)
);
}
}
}

View File

@ -44,7 +44,7 @@ class FileStorageCacheProvider
$this->modified_timestamps .= ' ' . filemtime($dependent_file_path);
}
$this->modified_timestamps .= PSALM_VERSION . $this->config->modified_time;
$this->modified_timestamps .= PSALM_VERSION . $this->config->hash;
}
/**