2014-01-21 22:41:50 +01:00
|
|
|
###
|
|
|
|
# Copyright (c) 2014, Valentin Lorentz
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions are met:
|
|
|
|
#
|
|
|
|
# * Redistributions of source code must retain the above copyright notice,
|
|
|
|
# this list of conditions, and the following disclaimer.
|
|
|
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
# this list of conditions, and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
# * Neither the name of the author of this software nor the name of
|
|
|
|
# contributors to this software may be used to endorse or promote products
|
|
|
|
# derived from this software without specific prior written consent.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
###
|
|
|
|
|
|
|
|
"""Restricted equivalent to six."""
|
|
|
|
|
2015-08-26 17:59:50 +02:00
|
|
|
from __future__ import division
|
|
|
|
|
2014-01-21 22:41:50 +01:00
|
|
|
import sys
|
2015-08-30 17:33:39 +02:00
|
|
|
import warnings
|
2014-01-21 22:41:50 +01:00
|
|
|
|
|
|
|
if sys.version_info[0] >= 3:
|
2015-08-08 23:01:02 +02:00
|
|
|
PY2 = False
|
|
|
|
PY3 = True
|
2014-01-21 22:41:50 +01:00
|
|
|
intern = sys.intern
|
2015-08-08 23:01:02 +02:00
|
|
|
integer_types = (int,)
|
2015-08-10 20:24:11 +02:00
|
|
|
string_types = (str,)
|
2015-08-08 23:01:02 +02:00
|
|
|
long = int
|
2015-08-10 17:55:25 +02:00
|
|
|
|
|
|
|
import io
|
|
|
|
import pickle
|
|
|
|
import queue
|
2015-08-10 18:52:51 +02:00
|
|
|
|
|
|
|
u = lambda x:x
|
2015-08-11 16:50:23 +02:00
|
|
|
L = lambda x:x
|
2015-08-26 17:42:42 +02:00
|
|
|
|
|
|
|
def make_datetime_utc(dt):
|
|
|
|
import datetime
|
|
|
|
return dt.replace(tzinfo=datetime.timezone.utc)
|
2015-08-26 17:59:50 +02:00
|
|
|
def timedelta__totalseconds(td):
|
|
|
|
return td.total_seconds()
|
2015-08-26 17:42:42 +02:00
|
|
|
if sys.version_info >= (3, 3):
|
|
|
|
def datetime__timestamp(dt):
|
|
|
|
return dt.timestamp()
|
|
|
|
else:
|
|
|
|
def datetime__timestamp(dt):
|
|
|
|
import datetime
|
2015-08-26 17:59:50 +02:00
|
|
|
td = dt - datetime.datetime(1970, 1, 1, tzinfo=datetime.timezone.utc)
|
|
|
|
return timedelta__totalseconds(td)
|
2014-01-21 22:41:50 +01:00
|
|
|
else:
|
2015-08-08 23:01:02 +02:00
|
|
|
PY2 = True
|
|
|
|
PY3 = False
|
2014-01-21 22:41:50 +01:00
|
|
|
if isinstance(__builtins__, dict):
|
|
|
|
intern = __builtins__['intern']
|
|
|
|
else:
|
|
|
|
intern = __builtins__.intern
|
2015-08-08 23:01:02 +02:00
|
|
|
integer_types = (int, long)
|
2015-08-10 20:24:11 +02:00
|
|
|
string_types = (basestring,)
|
2015-08-08 23:01:02 +02:00
|
|
|
long = long
|
2015-08-10 17:55:25 +02:00
|
|
|
|
|
|
|
class io:
|
|
|
|
# cStringIO is buggy with Python 2.6 (
|
|
|
|
# see http://paste.progval.net/show/227/ )
|
|
|
|
# and it does not handle unicode objects in Python 2.x
|
|
|
|
from StringIO import StringIO
|
|
|
|
from cStringIO import StringIO as BytesIO
|
|
|
|
import cPickle as pickle
|
|
|
|
import Queue as queue
|
2015-08-10 18:52:51 +02:00
|
|
|
|
|
|
|
u = lambda x:x.decode('utf8')
|
2015-08-11 16:50:23 +02:00
|
|
|
L = lambda x:long(x)
|
2015-08-26 17:42:42 +02:00
|
|
|
|
|
|
|
def make_datetime_utc(dt):
|
2015-08-30 17:33:39 +02:00
|
|
|
warnings.warn('Timezones are not available on this version of '
|
|
|
|
'Python and may lead to incorrect results. You should '
|
|
|
|
'consider upgrading to Python 3.')
|
2015-08-26 17:42:42 +02:00
|
|
|
return dt.replace(tzinfo=None)
|
2015-08-26 17:59:50 +02:00
|
|
|
if sys.version_info >= (2, 7):
|
|
|
|
def timedelta__totalseconds(td):
|
|
|
|
return td.total_seconds()
|
|
|
|
else:
|
|
|
|
def timedelta__totalseconds(td):
|
|
|
|
return (td.microseconds + (td.seconds + td.days * 24 * 3600) * 10**6) / 10**6
|
|
|
|
|
2015-08-26 17:42:42 +02:00
|
|
|
def datetime__timestamp(dt):
|
|
|
|
import datetime
|
2015-08-30 17:33:39 +02:00
|
|
|
warnings.warn('Timezones are not available on this version of '
|
|
|
|
'Python and may lead to incorrect results. You should '
|
|
|
|
'consider upgrading to Python 3.')
|
2015-08-26 17:59:50 +02:00
|
|
|
return timedelta__totalseconds(dt - datetime.datetime(1970, 1, 1))
|