Fix commit gone wild.

git-svn-id: http://svn.automattic.com/wordpress/trunk@3026 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2005-11-09 21:30:40 +00:00
parent dace166de0
commit d2fec03493
1 changed files with 97 additions and 101 deletions

View File

@ -260,38 +260,32 @@ function url_to_postid($url) {
/* Options functions */ /* Options functions */
function get_settings($setting) { function get_settings($setting) {
global $wpdb, $cache_settings, $cache_nonexistantoptions; global $wpdb;
if ( strstr($_SERVER['REQUEST_URI'], 'wp-admin/install.php') || defined('WP_INSTALLING') ) if ( strstr($_SERVER['REQUEST_URI'], 'wp-admin/install.php') || defined('WP_INSTALLING') )
return false; return false;
if ( empty($cache_settings) ) $value = wp_cache_get($setting, 'options');
$cache_settings = get_alloptions();
if ( empty($cache_nonexistantoptions) ) if ( false === $value ) {
$cache_nonexistantoptions = array(); $value = $wpdb->get_row("SELECT option_value FROM $wpdb->options WHERE option_name = '$setting'");
if( is_object( $value ) ) {
$value = $value->option_value;
wp_cache_set($setting, $value, 'options');
}
}
if ( 'home' == $setting && '' == $cache_settings->home ) // If home is not set use siteurl.
return apply_filters('option_' . $setting, $cache_settings->siteurl); if ( 'home' == $setting && '' == $value )
return get_settings('siteurl');
if ( isset($cache_settings->$setting) ) : if ( 'siteurl' == $setting || 'home' == $setting || 'category_base' == $setting )
return apply_filters('option_' . $setting, $cache_settings->$setting); $value = preg_replace('|/+$|', '', $value);
else :
// for these cases when we're asking for an unknown option
if ( isset($cache_nonexistantoptions[$setting]) )
return false;
$option = $wpdb->get_var("SELECT option_value FROM $wpdb->options WHERE option_name = '$setting'"); @ $kellogs = unserialize($value);
if ( $kellogs !== FALSE )
if (!$option) : return apply_filters('option_' . $setting, $kellogs);
$cache_nonexistantoptions[$setting] = true; else
return false; return apply_filters('option_' . $setting, $value);
endif;
@ $kellogs = unserialize($option);
if ( $kellogs !== FALSE )
return apply_filters('option_' . $setting, $kellogs);
else return apply_filters('option_' . $setting, $option);
endif;
} }
function get_option($option) { function get_option($option) {
@ -338,7 +332,7 @@ function get_alloptions() {
} }
function update_option($option_name, $newvalue) { function update_option($option_name, $newvalue) {
global $wpdb, $cache_settings; global $wpdb;
if ( is_string($newvalue) ) if ( is_string($newvalue) )
$newvalue = trim($newvalue); $newvalue = trim($newvalue);
@ -352,12 +346,13 @@ function update_option($option_name, $newvalue) {
// If it's not there add it // If it's not there add it
if ( !$wpdb->get_var("SELECT option_name FROM $wpdb->options WHERE option_name = '$option_name'") ) if ( !$wpdb->get_var("SELECT option_name FROM $wpdb->options WHERE option_name = '$option_name'") )
add_option($option_name); add_option($option_name, $newvalue);
wp_cache_set($option_name, $newvalue, 'options');
$newvalue = $wpdb->escape($newvalue); $newvalue = $wpdb->escape($newvalue);
$option_name = $wpdb->escape( $option_name ); $option_name = $wpdb->escape($option_name);
$wpdb->query("UPDATE $wpdb->options SET option_value = '$newvalue' WHERE option_name = '$option_name'"); $wpdb->query("UPDATE $wpdb->options SET option_value = '$newvalue' WHERE option_name = '$option_name'");
$cache_settings = get_alloptions(); // Re cache settings
return true; return true;
} }
@ -370,27 +365,23 @@ function update_user_option( $user_id, $option_name, $newvalue, $global = false
// thx Alex Stapleton, http://alex.vort-x.net/blog/ // thx Alex Stapleton, http://alex.vort-x.net/blog/
function add_option($name, $value = '', $description = '', $autoload = 'yes') { function add_option($name, $value = '', $description = '', $autoload = 'yes') {
global $wpdb, $cache_settings; global $wpdb;
// Make sure the option doesn't already exist // Make sure the option doesn't already exist
if ( isset($cache_settings->$name) ) if ( false !== get_option($name) )
return; return;
$original = $value; $original = $value;
if ( is_array($value) || is_object($value) ) if ( is_array($value) || is_object($value) )
$value = serialize($value); $value = serialize($value);
if ( !$wpdb->get_var("SELECT option_name FROM $wpdb->options WHERE option_name = '$name'") ) { wp_cache_set($name, $value, 'options');
$name = $wpdb->escape($name);
$value = $wpdb->escape($value); $name = $wpdb->escape($name);
$description = $wpdb->escape($description); $value = $wpdb->escape($value);
$wpdb->query("INSERT INTO $wpdb->options (option_name, option_value, option_description, autoload) VALUES ('$name', '$value', '$description', '$autoload')"); $description = $wpdb->escape($description);
$wpdb->query("INSERT INTO $wpdb->options (option_name, option_value, option_description, autoload) VALUES ('$name', '$value', '$description', '$autoload')");
if ( $wpdb->insert_id ) {
global $cache_settings;
$cache_settings->{$name} = $original;
}
}
return; return;
} }
@ -400,6 +391,7 @@ function delete_option($name) {
$option_id = $wpdb->get_var("SELECT option_id FROM $wpdb->options WHERE option_name = '$name'"); $option_id = $wpdb->get_var("SELECT option_id FROM $wpdb->options WHERE option_name = '$name'");
if ( !$option_id ) return false; if ( !$option_id ) return false;
$wpdb->query("DELETE FROM $wpdb->options WHERE option_name = '$name'"); $wpdb->query("DELETE FROM $wpdb->options WHERE option_name = '$name'");
wp_cache_delete($name, 'options');
return true; return true;
} }
@ -568,7 +560,7 @@ function &get_post(&$post, $output = OBJECT) {
if ( isset($post_cache[$post]) ) if ( isset($post_cache[$post]) )
$_post = & $post_cache[$post]; $_post = & $post_cache[$post];
else { else {
$query = "SELECT * FROM $wpdb->posts WHERE ID = '$post'"; $query = "SELECT * FROM $wpdb->posts WHERE ID = '$post' LIMIT 1";
$post_cache[$post] = & $wpdb->get_row($query); $post_cache[$post] = & $wpdb->get_row($query);
$_post = & $post_cache[$post]; $_post = & $post_cache[$post];
} }
@ -588,26 +580,28 @@ function &get_post(&$post, $output = OBJECT) {
// Retrieves page data given a page ID or page object. // Retrieves page data given a page ID or page object.
// Handles page caching. // Handles page caching.
function &get_page(&$page, $output = OBJECT) { function &get_page(&$page, $output = OBJECT) {
global $page_cache, $wpdb; global $wpdb;
if ( empty($page) ) { if ( empty($page) ) {
if ( isset($GLOBALS['page']) ) if ( isset($GLOBALS['page']) ) {
$_page = & $GLOBALS['page']; $_page = & $GLOBALS['page'];
else wp_cache_add($_page->ID, $_page, 'pages');
} else {
$_page = null; $_page = null;
}
} elseif ( is_object($page) ) { } elseif ( is_object($page) ) {
if ( !isset($page_cache[$page->ID]) ) wp_cache_add($page->ID, $page, 'pages');
$page_cache[$page->ID] = &$page; $_page = $page;
$_page = & $page_cache[$page->ID];
} else { } else {
if ( isset($GLOBALS['page']) && ($page == $GLOBALS['page']->ID) ) if ( isset($GLOBALS['page']) && ($page == $GLOBALS['page']->ID) ) {
$_page = & $GLOBALS['page']; $_page = & $GLOBALS['page'];
elseif ( isset($page_cache[$page]) ) wp_cache_add($_page->ID, $_page, 'pages');
$_page = & $page_cache[$page]; } elseif ( $_page = wp_cache_get($page, 'pages') ) {
else { // Got it.
$query = "SELECT * FROM $wpdb->posts WHERE ID= '$page'"; } else {
$page_cache[$page] = & $wpdb->get_row($query); $query = "SELECT * FROM $wpdb->posts WHERE ID= '$page' LIMIT 1";
$_page = & $page_cache[$page]; $_page = & $wpdb->get_row($query);
wp_cache_add($_page->ID, $_page, 'pages');
} }
} }
@ -622,30 +616,43 @@ function &get_page(&$page, $output = OBJECT) {
} }
} }
function set_category_path($cat) {
$cat->fullpath = '/' . $cat->category_nicename;
$path = $cat->fullpath;
$curcat = $cat;
while ($curcat->category_parent != 0) {
$curcat = get_category($curcat->category_parent);
$path = '/' . $curcat->category_nicename . $path;
}
$cat->fullpath = $path;
return $cat;
}
// Retrieves category data given a category ID or category object. // Retrieves category data given a category ID or category object.
// Handles category caching. // Handles category caching.
function &get_category(&$category, $output = OBJECT) { function &get_category(&$category, $output = OBJECT) {
global $cache_categories, $wpdb; global $wpdb;
if ( empty($category) ) if ( empty($category) )
return null; return null;
if ( !isset($cache_categories) )
update_category_cache();
if ( is_object($category) ) { if ( is_object($category) ) {
if ( !isset($cache_categories[$category->cat_ID]) ) wp_cache_add($category->cat_ID, $category, 'category');
$cache_categories[$category->cat_ID] = &$category; $_category = $category;
$_category = & $cache_categories[$category->cat_ID];
} else { } else {
if ( !isset($cache_categories[$category]) ) { if ( ! $_category = wp_cache_get($category, 'category') ) {
$_category = $wpdb->get_row("SELECT * FROM $wpdb->categories WHERE cat_ID = '$category'"); $_category = $wpdb->get_row("SELECT * FROM $wpdb->categories WHERE cat_ID = '$category' LIMIT 1");
$cache_categories[$category->cat_ID] = & $_category; wp_cache_add($category, $_category, 'category');
} else {
$_category = & $cache_categories[$category];
} }
} }
if ( !isset($_category->fullpath) ) {
$_category = set_category_path($_category);
wp_cache_replace($_category->cat_ID, $_category, 'category');
}
if ( $output == OBJECT ) { if ( $output == OBJECT ) {
return $_category; return $_category;
} elseif ( $output == ARRAY_A ) { } elseif ( $output == ARRAY_A ) {
@ -671,7 +678,7 @@ function &get_comment(&$comment, $output = OBJECT) {
$_comment = & $comment_cache[$comment->comment_ID]; $_comment = & $comment_cache[$comment->comment_ID];
} else { } else {
if ( !isset($comment_cache[$comment]) ) { if ( !isset($comment_cache[$comment]) ) {
$_comment = $wpdb->get_row("SELECT * FROM $wpdb->comments WHERE comment_ID = '$comment'"); $_comment = $wpdb->get_row("SELECT * FROM $wpdb->comments WHERE comment_ID = '$comment' LIMIT 1");
$comment_cache[$comment->comment_ID] = & $_comment; $comment_cache[$comment->comment_ID] = & $_comment;
} else { } else {
$_comment = & $comment_cache[$comment]; $_comment = & $comment_cache[$comment];
@ -694,6 +701,17 @@ function get_catname($cat_ID) {
return $category->cat_name; return $category->cat_name;
} }
function get_all_category_ids() {
global $wpdb;
if ( ! $cat_ids = wp_cache_get('all_category_ids', 'category') ) {
$cat_ids = $wpdb->get_col("SELECT cat_ID FROM $wpdb->categories");
wp_cache_add('all_category_ids', $cat_ids, 'category');
}
return $cat_ids;
}
function gzip_compression() { function gzip_compression() {
if ( strstr($_SERVER['PHP_SELF'], 'wp-admin') ) return false; if ( strstr($_SERVER['PHP_SELF'], 'wp-admin') ) return false;
if ( !get_settings('gzipcompression') ) return false; if ( !get_settings('gzipcompression') ) return false;
@ -1231,6 +1249,7 @@ function update_page_cache(&$pages) {
for ($i = 0; $i < count($pages); $i++) { for ($i = 0; $i < count($pages); $i++) {
$page_cache[$pages[$i]->ID] = &$pages[$i]; $page_cache[$pages[$i]->ID] = &$pages[$i];
wp_cache_add($pages[$i]->ID, $pages[$i], 'pages');
} }
} }
@ -1243,7 +1262,7 @@ function clean_page_cache($id) {
} }
function update_post_category_cache($post_ids) { function update_post_category_cache($post_ids) {
global $wpdb, $category_cache, $cache_categories; global $wpdb, $category_cache;
if ( empty($post_ids) ) if ( empty($post_ids) )
return; return;
@ -1255,14 +1274,11 @@ function update_post_category_cache($post_ids) {
post_id, cat_ID FROM $wpdb->categories, $wpdb->post2cat post_id, cat_ID FROM $wpdb->categories, $wpdb->post2cat
WHERE category_id = cat_ID AND post_id IN ($post_ids)"); WHERE category_id = cat_ID AND post_id IN ($post_ids)");
if ( !isset($cache_categories) ) if ( empty($dogs) )
update_category_cache(); return;
if ( !empty($dogs) ) { foreach ($dogs as $catt)
foreach ($dogs as $catt) { $category_cache[$catt->post_id][$catt->cat_ID] = &get_category($catt->cat_ID);
$category_cache[$catt->post_id][$catt->cat_ID] = &$cache_categories[$catt->cat_ID];
}
}
} }
function update_post_caches(&$posts) { function update_post_caches(&$posts) {
@ -1322,30 +1338,7 @@ function update_post_caches(&$posts) {
} }
function update_category_cache() { function update_category_cache() {
global $cache_categories, $wpdb; return true;
if ( $dogs = $wpdb->get_results("SELECT * FROM $wpdb->categories") ):
foreach ($dogs as $catt)
$cache_categories[$catt->cat_ID] = $catt;
foreach ($cache_categories as $catt) {
$curcat = $catt->cat_ID;
$cache_categories[$catt->cat_ID]->fullpath = '/' . $cache_categories[$catt->cat_ID]->category_nicename;
while ($cache_categories[$curcat]->category_parent != 0) {
$curcat = $cache_categories[$curcat]->category_parent;
$cache_categories[$catt->cat_ID]->fullpath = '/' . $cache_categories[$curcat]->category_nicename . $cache_categories[$catt->cat_ID]->fullpath;
}
}
return true;
else :
return false;
endif;
}
function clean_user_cache($id) {
global $cache_userdata;
if ( isset( $cache_userdata[$id] ) )
unset( $cache_userdata[$id] );
} }
function wp_head() { function wp_head() {
@ -2123,6 +2116,9 @@ function update_usermeta( $user_id, $meta_key, $meta_value ) {
} }
if ( $cur->meta_value != $meta_value ) if ( $cur->meta_value != $meta_value )
$wpdb->query("UPDATE $wpdb->usermeta SET meta_value = '$meta_value' WHERE user_id = '$user_id' AND meta_key = '$meta_key'"); $wpdb->query("UPDATE $wpdb->usermeta SET meta_value = '$meta_value' WHERE user_id = '$user_id' AND meta_key = '$meta_key'");
wp_cache_delete($user_id, 'users');
// FIXME: Need to delete username keyed cache object.
} }
function register_activation_hook($file, $function) { function register_activation_hook($file, $function) {