summaryrefslogtreecommitdiff
path: root/db-prefs.php
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2005-12-29 15:10:03 +0100
committerAndrew Dolgov <[email protected]>2005-12-29 15:10:03 +0100
commit11de82c37d385a85033d21f239a8865171405403 (patch)
treed5e417f190155e56831619443f95e4a8b85adb1f /db-prefs.php
parent798f722b017aea45da7ecf14b266884ad838840e (diff)
cache db-prefs (reset on preferences -> save), misc query optimizations
Diffstat (limited to 'db-prefs.php')
-rw-r--r--db-prefs.php23
1 files changed, 18 insertions, 5 deletions
diff --git a/db-prefs.php b/db-prefs.php
index c81149e6f..5f61f15ae 100644
--- a/db-prefs.php
+++ b/db-prefs.php
@@ -1,9 +1,12 @@
<?
- // TODO cache last query results
-
require_once "config.php";
require_once "db.php";
+ session_start();
+
+ if (!$_SESSION["prefs_cache"])
+ $_SESSION["prefs_cache"] = array();
+
function get_pref($link, $pref_name, $user_id = false) {
$pref_name = db_escape_string($pref_name);
@@ -12,6 +15,11 @@
$user_id = $_SESSION["uid"];
} else {
$user_id = sprintf("%d", $user_id);
+ $prefs_cache = false;
+ }
+
+ if ($_SESSION["prefs_cache"] && $_SESSION["prefs_cache"][$pref_name]) {
+ return $_SESSION["prefs_cache"][$pref_name];
}
$result = db_query($link, "SELECT
@@ -29,12 +37,17 @@
$type_name = db_fetch_result($result, 0, "type_name");
if ($type_name == "bool") {
- return $value == "true";
+ $retv = $value == "true";
} else if ($type_name == "integer") {
- return sprintf("%d", $value);
+ $retv = sprintf("%d", $value);
} else {
- return $value;
+ $retv = $value;
+ }
+
+ if ($user_id = $_SESSION["uid"]) {
+ $_SESSION["prefs_cache"][$pref_name] = $value;
}
+ return $value;
} else {
die("Fatal error, unknown preferences key: $pref_name");