Fix datetime comparison in relative datetime functions.

Closes #2987,#3514
This commit is contained in:
ADmad 2013-04-20 13:10:06 +05:30
parent 842b1802d9
commit ae8386c48a

View file

@ -468,7 +468,8 @@ class CakeTime {
*/ */
public static function isToday($dateString, $timezone = null) { public static function isToday($dateString, $timezone = null) {
$timestamp = self::fromString($dateString, $timezone); $timestamp = self::fromString($dateString, $timezone);
return date('Y-m-d', $timestamp) == date('Y-m-d', time()); $now = self::fromString('now', $timezone);
return date('Y-m-d', $timestamp) == date('Y-m-d', $now);
} }
/** /**
@ -481,7 +482,8 @@ class CakeTime {
*/ */
public static function isThisWeek($dateString, $timezone = null) { public static function isThisWeek($dateString, $timezone = null) {
$timestamp = self::fromString($dateString, $timezone); $timestamp = self::fromString($dateString, $timezone);
return date('W o', $timestamp) == date('W o', time()); $now = self::fromString('now', $timezone);
return date('W o', $timestamp) == date('W o', $now);
} }
/** /**
@ -494,7 +496,8 @@ class CakeTime {
*/ */
public static function isThisMonth($dateString, $timezone = null) { public static function isThisMonth($dateString, $timezone = null) {
$timestamp = self::fromString($dateString, $timezone); $timestamp = self::fromString($dateString, $timezone);
return date('m Y', $timestamp) == date('m Y', time()); $now = self::fromString('now', $timezone);
return date('m Y', $timestamp) == date('m Y', $now);
} }
/** /**
@ -507,7 +510,8 @@ class CakeTime {
*/ */
public static function isThisYear($dateString, $timezone = null) { public static function isThisYear($dateString, $timezone = null) {
$timestamp = self::fromString($dateString, $timezone); $timestamp = self::fromString($dateString, $timezone);
return date('Y', $timestamp) == date('Y', time()); $now = self::fromString('now', $timezone);
return date('Y', $timestamp) == date('Y', $now);
} }
/** /**
@ -521,7 +525,8 @@ class CakeTime {
*/ */
public static function wasYesterday($dateString, $timezone = null) { public static function wasYesterday($dateString, $timezone = null) {
$timestamp = self::fromString($dateString, $timezone); $timestamp = self::fromString($dateString, $timezone);
return date('Y-m-d', $timestamp) == date('Y-m-d', strtotime('yesterday')); $yesterday = self::fromString('yesterday', $timezone);
return date('Y-m-d', $timestamp) == date('Y-m-d', $yesterday);
} }
/** /**
@ -534,7 +539,8 @@ class CakeTime {
*/ */
public static function isTomorrow($dateString, $timezone = null) { public static function isTomorrow($dateString, $timezone = null) {
$timestamp = self::fromString($dateString, $timezone); $timestamp = self::fromString($dateString, $timezone);
return date('Y-m-d', $timestamp) == date('Y-m-d', strtotime('tomorrow')); $tomorrow = self::fromString('tomorrow', $timezone);
return date('Y-m-d', $timestamp) == date('Y-m-d', $tomorrow);
} }
/** /**
@ -880,8 +886,9 @@ class CakeTime {
$date = self::fromString($dateString, $timezone); $date = self::fromString($dateString, $timezone);
$interval = self::fromString('-' . $timeInterval); $interval = self::fromString('-' . $timeInterval);
$now = self::fromString('now', $timezone);
return $date >= $interval && $date <= time(); return $date >= $interval && $date <= $now;
} }
/** /**
@ -902,8 +909,9 @@ class CakeTime {
$date = self::fromString($dateString, $timezone); $date = self::fromString($dateString, $timezone);
$interval = self::fromString('+' . $timeInterval); $interval = self::fromString('+' . $timeInterval);
$now = self::fromString('now', $timezone);
return $date <= $interval && $date >= time(); return $date <= $interval && $date >= $now;
} }
/** /**