Fix commit gone wild.
git-svn-id: http://svn.automattic.com/wordpress/trunk@3026 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
dace166de0
commit
d2fec03493
|
@ -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) {
|
||||||
|
|
Loading…
Reference in New Issue