diff options
author | Roeland Jago Douma <roeland@famdouma.nl> | 2017-03-21 21:53:20 +0100 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2017-03-22 20:14:08 +0100 |
commit | e3925ba2a1de18692f2687569c1f490a24ec11d3 (patch) | |
tree | 80652f6927a23ac680921ecbdc36d7ea5a9a3185 /lib/private | |
parent | 8b75e9b8a01f4dcd8404d1231f96461a4f405c67 (diff) | |
download | nextcloud-server-e3925ba2a1de18692f2687569c1f490a24ec11d3.tar.gz nextcloud-server-e3925ba2a1de18692f2687569c1f490a24ec11d3.zip |
Cache SCSS dependency file in memcache
Since reading a file from disks can be costly. Lets store the dependency
json also in memcache.
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/Template/SCSSCacher.php | 28 | ||||
-rw-r--r-- | lib/private/TemplateLayout.php | 5 |
2 files changed, 24 insertions, 9 deletions
diff --git a/lib/private/Template/SCSSCacher.php b/lib/private/Template/SCSSCacher.php index 4f5c66f2409..c12d8771513 100644 --- a/lib/private/Template/SCSSCacher.php +++ b/lib/private/Template/SCSSCacher.php @@ -30,6 +30,7 @@ use OCP\Files\IAppData; use OCP\Files\NotFoundException; use OCP\Files\NotPermittedException; use OCP\Files\SimpleFS\ISimpleFolder; +use OCP\ICache; use OCP\IConfig; use OCP\ILogger; use OCP\IURLGenerator; @@ -51,23 +52,29 @@ class SCSSCacher { /** @var string */ protected $serverRoot; + /** @var ICache */ + protected $depsCache; + /** * @param ILogger $logger * @param IAppData $appData * @param IURLGenerator $urlGenerator - * @param SystemConfig $systemConfig + * @param IConfig $config * @param string $serverRoot + * @param ICache $depsCache */ public function __construct(ILogger $logger, IAppData $appData, IURLGenerator $urlGenerator, IConfig $config, - $serverRoot) { + $serverRoot, + ICache $depsCache) { $this->logger = $logger; $this->appData = $appData; $this->urlGenerator = $urlGenerator; $this->config = $config; $this->serverRoot = $serverRoot; + $this->depsCache = $depsCache; } /** @@ -94,7 +101,7 @@ class SCSSCacher { $folder = $this->appData->newFolder($app); } - if($this->isCached($fileNameCSS, $fileNameSCSS, $folder, $path)) { + if($this->isCached($fileNameCSS, $folder)) { return true; } return $this->cache($path, $fileNameCSS, $fileNameSCSS, $folder, $webDir); @@ -103,17 +110,22 @@ class SCSSCacher { /** * Check if the file is cached or not * @param string $fileNameCSS - * @param string $fileNameSCSS * @param ISimpleFolder $folder - * @param string $path * @return boolean */ - private function isCached($fileNameCSS, $fileNameSCSS, ISimpleFolder $folder, $path) { + private function isCached($fileNameCSS, ISimpleFolder $folder) { try { $cachedFile = $folder->getFile($fileNameCSS); if ($cachedFile->getSize() > 0) { - $depFile = $folder->getFile($fileNameCSS . '.deps'); - $deps = json_decode($depFile->getContent(), true); + $depFileName = $fileNameCSS . '.deps'; + $deps = $this->depsCache->get($folder->getName() . '-' . $depFileName); + if ($deps === null) { + $depFile = $folder->getFile($depFileName); + $deps = $depFile->getContent(); + //Set to memcache for next run + $this->depsCache->set($folder->getName() . '-' . $depFileName, $deps); + } + $deps = json_decode($deps, true); foreach ($deps as $file=>$mtime) { if (!file_exists($file) || filemtime($file) > $mtime) { diff --git a/lib/private/TemplateLayout.php b/lib/private/TemplateLayout.php index 33f61e3c3ac..3206a1d3ba8 100644 --- a/lib/private/TemplateLayout.php +++ b/lib/private/TemplateLayout.php @@ -213,12 +213,15 @@ class TemplateLayout extends \OC_Template { $theme = \OC_Util::getTheme(); if($compileScss) { + /** @var \OC\Memcache\Factory $cache */ + $cache = \OC::$server->query('MemCacheFactory'); $SCSSCacher = new SCSSCacher( \OC::$server->getLogger(), \OC::$server->getAppDataDir('css'), \OC::$server->getURLGenerator(), \OC::$server->getConfig(), - \OC::$SERVERROOT + \OC::$SERVERROOT, + $cache->createLocal('SCSS') ); } else { $SCSSCacher = null; |