[FrameworkBundle] fixed cache:clear command when the kernel class is not AppKernel

This commit is contained in:
Fabien Potencier 2011-06-26 18:34:40 +02:00
parent a19c336c18
commit 9cd15908f3

View File

@ -79,7 +79,15 @@ EOF
{
$this->getContainer()->get('filesystem')->remove($warmupDir);
$kernel = $this->getTempKernel($this->getContainer()->get('kernel'), $warmupDir);
$parent = $this->getContainer()->get('kernel');
$class = get_class($parent);
$namespace = '';
if (false !== $pos = strrpos($class, '\\')) {
$namespace = substr($class, 0, $pos);
$class = substr($class, $pos + 1);
}
$kernel = $this->getTempKernel($parent, $namespace, $class, $warmupDir);
$kernel->boot();
$warmer = $kernel->getContainer()->get('cache_warmer');
@ -99,8 +107,8 @@ EOF
// fix meta references to the Kernel
foreach ($finder->files()->name('*.meta')->in($warmupDir) as $file) {
$content = preg_replace(
'/C\:\d+\:"AppKernel'.preg_quote($this->getTempKernelSuffix(), '"/').'"/',
'C:9:"AppKernel"',
'/C\:\d+\:"'.preg_quote($class.$this->getTempKernelSuffix(), '"/').'"/',
sprintf('C:%s:"%s"', strlen($class), $class),
file_get_contents($file)
);
file_put_contents($file, $content);
@ -116,25 +124,16 @@ EOF
return $this->name;
}
protected function getTempKernel(KernelInterface $parent, $warmupDir)
protected function getTempKernel(KernelInterface $parent, $namespace, $class, $warmupDir)
{
$parentClass = get_class($parent);
$namespace = '';
if (false !== $pos = strrpos($parentClass, '\\')) {
$namespace = substr($parentClass, 0, $pos);
$parentClass = substr($parentClass, $pos + 1);
}
$suffix = $this->getTempKernelSuffix();
$class = $parentClass.$suffix;
$rootDir = $parent->getRootDir();
$code = <<<EOF
<?php
namespace $namespace
{
class $class extends $parentClass
class $class$suffix extends $class
{
public function getCacheDir()
{
@ -148,7 +147,7 @@ namespace $namespace
protected function getContainerClass()
{
return parent::getContainerClass().'{$suffix}';
return parent::getContainerClass().'$suffix';
}
}
}
@ -157,8 +156,7 @@ EOF;
file_put_contents($file = $warmupDir.'/kernel.tmp', $code);
require_once $file;
@unlink($file);
$class = "$namespace\\$class";
$class = "$namespace\\$class$suffix";
return new $class($parent->getEnvironment(), $parent->isDebug());
}