diff options
author | thomascube <thomas@roundcube.net> | 2009-06-09 08:08:00 +0000 |
---|---|---|
committer | thomascube <thomas@roundcube.net> | 2009-06-09 08:08:00 +0000 |
commit | 533e8602c0be3aed7becc74002c58a7d1cf400c3 (patch) | |
tree | dd1ee6db894960ecb8b8a215b8d29e36bfa4a7a6 /program/include | |
parent | 384d83adb9641cfcb5365b25706c89cee8e688de (diff) |
Add cache-buster to scripts and linked files in skin templates
Diffstat (limited to 'program/include')
-rw-r--r-- | program/include/main.inc | 11 | ||||
-rw-r--r-- | program/include/rcube_html_page.php | 13 | ||||
-rwxr-xr-x | program/include/rcube_template.php | 1 |
3 files changed, 17 insertions, 8 deletions
diff --git a/program/include/main.inc b/program/include/main.inc index f9783ba3f..dbed2ba09 100644 --- a/program/include/main.inc +++ b/program/include/main.inc @@ -1023,17 +1023,16 @@ function write_log($name, $line) * @access private */ function rcube_timer() - { - list($usec, $sec) = explode(" ", microtime()); - return ((float)$usec + (float)$sec); - } +{ + return microtime(true); +} /** * @access private */ function rcube_print_time($timer, $label='Timer') - { +{ static $print_count = 0; $print_count++; @@ -1044,7 +1043,7 @@ function rcube_print_time($timer, $label='Timer') $label = 'Timer '.$print_count; console(sprintf("%s: %0.4f sec", $label, $diff)); - } +} /** diff --git a/program/include/rcube_html_page.php b/program/include/rcube_html_page.php index b8db7b37a..d56b5ce3f 100644 --- a/program/include/rcube_html_page.php +++ b/program/include/rcube_html_page.php @@ -55,7 +55,7 @@ class rcube_html_page static $sa_files = array(); if (!preg_match('|^https?://|i', $file) && $file[0] != '/') - $file = $this->scripts_path . $file; + $file = $this->scripts_path . $file . (($fs = @filesize($this->scripts_path . $file)) ? '?s='.$fs : ''); if (in_array($file, $sa_files)) { return; @@ -249,10 +249,19 @@ class rcube_html_page $__page_header = $__page_footer = ''; // correct absolute paths in images and other tags - $output = preg_replace('/(src|href|background)=(["\']?)(\/[a-z0-9_\-]+)/Ui', "\\1=\\2$base_path\\3", $output); + $output = preg_replace('!(src|href|background)=(["\']?)(/[a-z0-9_-]+)!i', "\\1=\\2$base_path\\3", $output); + $output = preg_replace_callback('!(src|href)=(["\']?)([a-z0-9/_.-]+.(css|js))(["\'\s>])!i', array($this, 'add_filesize'), $output); $output = str_replace('$__skin_path', $base_path, $output); echo rcube_charset_convert($output, 'UTF-8', $this->charset); } + + /** + * Callback function for preg_replace_callback in write() + */ + public function add_filesize($matches) + { + return sprintf("%s=%s%s?s=%d%s", $matches[1], $matches[2], $matches[3], @filesize($matches[3]), $matches[5]); + } } diff --git a/program/include/rcube_template.php b/program/include/rcube_template.php index c6d75dd19..3d0e7390a 100755 --- a/program/include/rcube_template.php +++ b/program/include/rcube_template.php @@ -435,6 +435,7 @@ class rcube_template extends rcube_html_page */ private function parse_with_globals($input) { + $GLOBALS['__version'] = Q(RCMAIL_VERSION); $GLOBALS['__comm_path'] = Q($this->app->comm_path); return preg_replace('/\$(__[a-z0-9_\-]+)/e', '$GLOBALS["\\1"]', $input); } |