summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorctrlaltca <>2013-01-06 19:12:45 +0000
committerctrlaltca <>2013-01-06 19:12:45 +0000
commit11d9e3f39458c4870ca722ba1d3db0d5bba754dc (patch)
treefeaa32bfba9a6480c3b7d5b66b520ec27be9b2cc
parent0335d5868ca022a455a36fef89bff4952db67c17 (diff)
fix #44
-rw-r--r--HISTORY1
-rw-r--r--framework/Util/TDateTimeStamp.php26
-rw-r--r--framework/Util/TSimpleDateFormatter.php11
3 files changed, 28 insertions, 10 deletions
diff --git a/HISTORY b/HISTORY
index 93ef280f..e8542456 100644
--- a/HISTORY
+++ b/HISTORY
@@ -1,5 +1,6 @@
Version 3.2.1 to be released
+BUG: Issue #44 - [895] SDateFormatter cannot parse date earlier than 1970 (ctrlaltca)
BUG: Issue #412 - open_basedir restriction (ctrlaltca)
BUG: Issue #413 - TActiveDatePicker does not fire TCallbackClientSide's events (ctrlaltca)
BUG: Issue #414 - ActiveDatagrid's pager does not fire TCallbackClientSide's events (ctrlaltca)
diff --git a/framework/Util/TDateTimeStamp.php b/framework/Util/TDateTimeStamp.php
index a7a43b3c..f5f76004 100644
--- a/framework/Util/TDateTimeStamp.php
+++ b/framework/Util/TDateTimeStamp.php
@@ -105,6 +105,30 @@ class TDateTimeStamp
/**
* @return array an array with date info.
*/
+ function parseDate($txt=false)
+ {
+ if ($txt === false) return getdate();
+
+ $dt = new DateTime($txt);
+
+ return array(
+ 'seconds' => (int) $dt->format('s'),
+ 'minutes' => (int) $dt->format('i'),
+ 'hours' => (int) $dt->format('G'),
+ 'mday' => (int) $dt->format('j'),
+ 'wday' => (int) $dt->format('w'),
+ 'mon' => (int) $dt->format('n'),
+ 'year' => (int) $dt->format('Y'),
+ 'yday' => (int) $dt->format('z'),
+ 'weekday' => $dt->format('l'),
+ 'month' => $dt->format('F'),
+ 0 => (int) $dt->format('U'),
+ );
+ }
+
+ /**
+ * @return array an array with date info.
+ */
function getDate($d=false,$fast=false)
{
if ($d === false) return getdate();
@@ -123,7 +147,7 @@ class TDateTimeStamp
'yday' => (int) $dt->format('z'),
'weekday' => $dt->format('l'),
'month' => $dt->format('F'),
- 0 => (int) $d
+ 0 => (int) $dt->format('U'),
);
}
diff --git a/framework/Util/TSimpleDateFormatter.php b/framework/Util/TSimpleDateFormatter.php
index 8b17048a..a1a1842a 100644
--- a/framework/Util/TSimpleDateFormatter.php
+++ b/framework/Util/TSimpleDateFormatter.php
@@ -173,15 +173,8 @@ class TSimpleDateFormatter
*/
private function getDate($value)
{
- if(!is_string($value))
- {
- $s = Prado::createComponent('System.Util.TDateTimeStamp');
- return $s->getDate($value);
- }
- $date = @strtotime($value);
- if($date < 0)
- throw new TInvalidDataValueException('invalid_date', $value);
- return @getdate($date);
+ $s = Prado::createComponent('System.Util.TDateTimeStamp');
+ return $s->parseDate($value);
}
/**