48 lines
1.3 KiB
PHP
48 lines
1.3 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Zend Framework (http://framework.zend.com/)
|
||
|
*
|
||
|
* @link http://github.com/zendframework/zf2 for the canonical source repository
|
||
|
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
|
||
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
||
|
*/
|
||
|
|
||
|
namespace Zend\Stdlib;
|
||
|
|
||
|
use DateTimeZone;
|
||
|
|
||
|
trigger_error('DateTime extension deprecated as of ZF 2.1.4; use the \DateTime constructor to parse extended ISO8601 dates instead', E_USER_DEPRECATED);
|
||
|
|
||
|
/**
|
||
|
* DateTime
|
||
|
*
|
||
|
* An extension of the \DateTime object.
|
||
|
*
|
||
|
* @deprecated
|
||
|
*/
|
||
|
class DateTime extends \DateTime
|
||
|
{
|
||
|
/**
|
||
|
* The DateTime::ISO8601 constant used by php's native DateTime object does
|
||
|
* not allow for fractions of a second. This function better handles ISO8601
|
||
|
* formatted date strings.
|
||
|
*
|
||
|
* @param string $time
|
||
|
* @param DateTimeZone $timezone
|
||
|
* @return mixed
|
||
|
*/
|
||
|
public static function createFromISO8601($time, DateTimeZone $timezone = null)
|
||
|
{
|
||
|
$format = self::ISO8601;
|
||
|
if (isset($time[19]) && $time[19] === '.') {
|
||
|
$format = 'Y-m-d\TH:i:s.uO';
|
||
|
}
|
||
|
|
||
|
if ($timezone !== null) {
|
||
|
return self::createFromFormat($format, $time, $timezone);
|
||
|
}
|
||
|
|
||
|
return self::createFromFormat($format, $time);
|
||
|
}
|
||
|
}
|