cache_dir = $phpbb_root_path . 'cache/'; } function load() { global $phpEx; @include($this->cache_dir . 'data_global.' . $phpEx); } function unload() { $this->save(); unset($this->vars); unset($this->vars_ts); unset($this->sql_rowset); } function save() { if (!$this->is_modified) { return; } global $phpEx; $file = 'vars=' . $this->format_array($this->vars) . ";\n\$this->vars_ts=" . $this->format_array($this->vars_ts) . ' ?>'; if ($fp = @fopen($this->cache_dir . 'data_global.' . $phpEx, 'wb')) { @flock($fp, LOCK_EX); fwrite($fp, $file); @flock($fp, LOCK_UN); fclose($fp); } $this->is_modified = FALSE; } function tidy($max_age = 0) { global $phpEx; $dir = opendir($this->cache_dir); while ($entry = readdir($dir)) { if (substr($entry, 0, 4) != 'sql_') { continue; } if (time() > filemtime($this->cache_dir . $entry) + $max_age) { unlink($this->cache_dir . $entry); } } @closedir($dir); if (file_exists($this->cache_dir . 'data_global.' . $phpEx)) { foreach ($this->vars_ts as $var_name => $timestamp) { if (time() > $timestamp + $max_age) { $this->destroy($var_name); } } } else { $this->vars = $this->vars_ts = array(); $this->is_modified = TRUE; } } function get($var_name, $max_age = 0) { return ($this->exists($var_name, $max_age)) ? $this->vars[$var_name] : NULL; } function put($var_name, $var) { $this->vars[$var_name] = $var; $this->vars_ts[$var_name] = time(); $this->is_modified = TRUE; } function destroy($var_name, $table = '') { if ($var_name == 'sql' && !empty($table)) { $regex = '(' . ((is_array($table)) ? implode('|', $table) : $table) . ')'; $dir = opendir($this->cache_dir); while ($entry = readdir($dir)) { if (substr($entry, 0, 4) != 'sql_') { continue; } $fp = fopen($this->cache_dir . $entry, 'rb'); $file = fread($fp, filesize($this->cache_dir . $entry)); @fclose($fp); if (preg_match('#/\*.*?\W' . $regex . '\W.*?\*/#s', $file, $m)) { unlink($this->cache_dir . $entry); } } @closedir($dir); } elseif (isset($this->vars[$var_name])) { $this->is_modified = TRUE; unset($this->vars[$var_name]); unset($this->vars_ts[$var_name]); } } function exists($var_name, $max_age = 0) { if (!is_array($this->vars)) { $this->load(); } if ($max_age > 0 && isset($this->vars_ts[$var_name])) { if (time() > $this->vars_ts[$var_name] + $max_age) { $this->destroy($var_name); return FALSE; } } return isset($this->vars[$var_name]); } function format_array($array) { $lines = array(); foreach ($array as $k => $v) { if (is_array($v)) { $lines[] = "'$k'=>" . $this->format_array($v); } elseif (is_int($v)) { $lines[] = "'$k'=>$v"; } elseif (is_bool($v)) { $lines[] = "'$k'=>" . (($v) ? 'TRUE' : 'FALSE'); } else { $lines[] = "'$k'=>'" . str_replace("'", "\'", str_replace('\\', '\\\\', $v)) . "'"; } } return 'array(' . implode(',', $lines) . ')'; } function sql_load($query, $max_age) { global $phpEx; // Remove extra spaces and tabs $query = preg_replace('/[\n\r\s\t]+/', ' ', $query); $filemtime = intval(@filemtime($this->cache_dir . 'sql_' . md5($query) . '.' . $phpEx)); if (time() > $filemtime + $max_age) { return FALSE; } $query_id = 'Cache id #' . count($this->sql_rowset); include($this->cache_dir . 'sql_' . md5($query) . '.' . $phpEx); // $this->sql_rowset[$query_id] =& $rowset; return $query_id; } function sql_save($query, &$query_result) { global $db, $phpEx; // Remove extra spaces and tabs $query = preg_replace('/[\n\r\s\t]+/', ' ', $query); if ($fp = @fopen($this->cache_dir . 'sql_' . md5($query) . '.' . $phpEx, 'wb')) { @flock($fp, LOCK_EX); $lines = array(); $query_id = 'Cache id #' . count($this->sql_rowset); $this->sql_rowset[$query_id] = array(); while ($row = $db->sql_fetchrow($query_result)) { $this->sql_rowset[$query_id][] = $row; $line = 'array('; foreach ($row as $key => $val) { $line .= "'$key'=>'" . str_replace("'", "\'", str_replace('\\', '\\\\', $val)) . "',"; } $lines[] = substr($line, 0, -1) . ')'; } fwrite($fp, "sql_rowset[\$query_id] = array(" . implode(',', $lines) . ') ?>'); @flock($fp, LOCK_UN); fclose($fp); $query_result = $query_id; } } function sql_exists($query_id) { return isset($this->sql_rowset[$query_id]); } function sql_fetchrow($query_id) { return array_shift($this->sql_rowset[$query_id]); } } ?>