summaryrefslogtreecommitdiff
path: root/modules/gallery/libraries/Theme_View.php
diff options
context:
space:
mode:
Diffstat (limited to 'modules/gallery/libraries/Theme_View.php')
-rw-r--r--modules/gallery/libraries/Theme_View.php29
1 files changed, 26 insertions, 3 deletions
diff --git a/modules/gallery/libraries/Theme_View.php b/modules/gallery/libraries/Theme_View.php
index 7696f3b0..1746f1d2 100644
--- a/modules/gallery/libraries/Theme_View.php
+++ b/modules/gallery/libraries/Theme_View.php
@@ -170,11 +170,34 @@ class Theme_View_Core extends View {
private function _combine_script() {
$links = array();
- Kohana::log("error", Kohana::debug($this->scripts));
+ $key = "";
foreach (array_keys($this->scripts) as $file) {
- $links[] = html::script($file);
+ $path = DOCROOT . $file;
+ if (file_exists($path)) {
+ $stats = stat($path);
+ $links[] = $path;
+ // 7 == size, 9 == mtime, see http://php.net/stat
+ $key = "{$key}$file $stats[7] $stats[9],";
+ } else {
+ Kohana::log("warn", "Javascript file missing: " . $file);
+ }
+ }
+
+ $key = md5($key);
+ $file = "tmp/CombinedJavascript_$key";
+ if (!file_exists(VARPATH . $file)) {
+ $contents = '';
+ foreach ($links as $link) {
+ $contents .= file_get_contents($link);
+ }
+ file_put_contents(VARPATH . $file, $contents);
+ if (function_exists("gzencode")) {
+ file_put_contents(VARPATH . "{$file}_gzip", gzencode($contents, 9, FORCE_GZIP));
+ }
}
- return empty($links) ? "" : implode("\n", $links);
+
+ return "<script type=\"text/javascript\" src=\"" . url::site("javascript/combined/$key") .
+ "\"></script>";
}
/**