From 1947f04aac662d340e69aa07ddae8bcf64b794da Mon Sep 17 00:00:00 2001 From: michelvaldrighi Date: Sat, 28 Feb 2004 17:51:41 +0000 Subject: [PATCH] =?UTF-8?q?added=20a=20timezone=20argument=20to=20get?= =?UTF-8?q?=EF=BF=BD=5Flastpost*()?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit git-svn-id: http://svn.automattic.com/wordpress/trunk@952 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/functions.php | 52 ++++++++++++++++++++++++++++++--------- 1 file changed, 40 insertions(+), 12 deletions(-) diff --git a/wp-includes/functions.php b/wp-includes/functions.php index 27a7ac96de..ffc83a7aca 100644 --- a/wp-includes/functions.php +++ b/wp-includes/functions.php @@ -95,26 +95,54 @@ function get_weekstartend($mysqlstring, $start_of_week) { return $week; } -function get_lastpostdate() { +function get_lastpostdate($timezone = 'server') { global $tableposts, $cache_lastpostdate, $use_cache, $pagenow, $wpdb; - if ((!isset($cache_lastpostdate)) OR (!$use_cache)) { - $now = gmdate('Y-m-d H:i:s'); - $lastpostdate = $wpdb->get_var("SELECT post_date FROM $tableposts WHERE post_date <= '$now' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1"); - $cache_lastpostdate = $lastpostdate; + $add_seconds_blog = get_settings('gmt_offset') * 3600; + $add_seconds_server = date('Z'); + $now = gmdate('Y-m-d H:i:s'); + if ((!isset($cache_lastpostdate[$timezone])) OR (!$use_cache)) { + switch(strtolower($timezone)) { + case 'gmt': + $lastpostdate = $wpdb->get_var("SELECT post_date FROM $tableposts WHERE post_date <= '$now' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1"); + break; + case 'blog': + $lastpostdate = $wpdb->get_var("SELECT DATE_ADD(post_date, INTERVAL '$add_seconds_blog' SECOND) FROM $tableposts WHERE post_date <= '$now' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1"); + break; + case 'server': + $lastpostdate = $wpdb->get_var("SELECT DATE_ADD(post_date, INTERVAL '$add_seconds_server' SECOND) FROM $tableposts WHERE post_date <= '$now' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1"); + break; + } + $cache_lastpostdate[$timezone] = $lastpostdate; } else { - $lastpostdate = $cache_lastpostdate; + $lastpostdate = $cache_lastpostdate[$timezone]; } return $lastpostdate; } -function get_lastpostmodified() { +function get_lastpostmodified($timezone = 'server') { global $tableposts, $cache_lastpostmodified, $use_cache, $pagenow, $wpdb; - if ((!isset($cache_lastpostmodified)) OR (!$use_cache)) { - $now = gmdate('Y-m-d H:i:s'); - $lastpostmodified = $wpdb->get_var("SELECT post_modified FROM $tableposts WHERE post_modified <= '$now' AND post_status = 'publish' ORDER BY post_modified DESC LIMIT 1"); - $cache_lastpostmodified = $lastpostmodified; + $add_seconds_blog = get_settings('gmt_offset') * 3600; + $add_seconds_server = date('Z'); + $now = gmdate('Y-m-d H:i:s'); + if ((!isset($cache_lastpostmodified[$timezone])) OR (!$use_cache)) { + switch($timezone) { + case 'gmt': + $lastpostmodified = $wpdb->get_var("SELECT post_modified FROM $tableposts WHERE post_modified <= '$now' AND post_status = 'publish' ORDER BY post_modified DESC LIMIT 1"); + break; + case 'blog': + $lastpostmodified = $wpdb->get_var("SELECT DATE_ADD(post_modified, INTERVAL '$add_seconds_blog' SECOND) FROM $tableposts WHERE post_modified <= '$now' AND post_status = 'publish' ORDER BY post_modified DESC LIMIT 1"); + break; + case 'server': + $lastpostmodified = $wpdb->get_var("SELECT DATE_ADD(post_modified, INTERVAL '$add_seconds_server' SECOND) FROM $tableposts WHERE post_modified <= '$now' AND post_status = 'publish' ORDER BY post_modified DESC LIMIT 1"); + break; + } + $lastpostdate = get_lastpostdate($timezone); + if ($lastpostdate > $lastpostmodified) { + $lastpostmodified = $lastpostdate; + } + $cache_lastpostmodified[$timezone] = $lastpostmodified; } else { - $lastpostmodified = $cache_lastpostmodified; + $lastpostmodified = $cache_lastpostmodified[$timezone]; } return $lastpostmodified; }