about summary refs log tree commit diff
path: root/.venv/lib/python3.12/site-packages/isodate/isotzinfo.py
diff options
context:
space:
mode:
authorS. Solomon Darnell2025-03-28 21:52:21 -0500
committerS. Solomon Darnell2025-03-28 21:52:21 -0500
commit4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch)
treeee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/isodate/isotzinfo.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-master.tar.gz
two version of R2R are here HEAD master
Diffstat (limited to '.venv/lib/python3.12/site-packages/isodate/isotzinfo.py')
-rw-r--r--.venv/lib/python3.12/site-packages/isodate/isotzinfo.py91
1 files changed, 91 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/isodate/isotzinfo.py b/.venv/lib/python3.12/site-packages/isodate/isotzinfo.py
new file mode 100644
index 00000000..54f36de0
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/isodate/isotzinfo.py
@@ -0,0 +1,91 @@
+"""
+This module provides an ISO 8601:2004 time zone info parser.
+
+It offers a function to parse the time zone offset as specified by ISO 8601.
+"""
+
+import re
+
+from isodate.isoerror import ISO8601Error
+from isodate.tzinfo import UTC, ZERO, FixedOffset
+
+TZ_REGEX = (
+    r"(?P<tzname>(Z|(?P<tzsign>[+-])" r"(?P<tzhour>[0-9]{2})(:?(?P<tzmin>[0-9]{2}))?)?)"
+)
+
+TZ_RE = re.compile(TZ_REGEX)
+
+
+def build_tzinfo(tzname, tzsign="+", tzhour=0, tzmin=0):
+    """
+    create a tzinfo instance according to given parameters.
+
+    tzname:
+      'Z'       ... return UTC
+      '' | None ... return None
+      other     ... return FixedOffset
+    """
+    if tzname is None or tzname == "":
+        return None
+    if tzname == "Z":
+        return UTC
+    tzsign = ((tzsign == "-") and -1) or 1
+    return FixedOffset(tzsign * tzhour, tzsign * tzmin, tzname)
+
+
+def parse_tzinfo(tzstring):
+    """
+    Parses ISO 8601 time zone designators to tzinfo objects.
+
+    A time zone designator can be in the following format:
+              no designator indicates local time zone
+      Z       UTC
+      +-hhmm  basic hours and minutes
+      +-hh:mm extended hours and minutes
+      +-hh    hours
+    """
+    match = TZ_RE.match(tzstring)
+    if match:
+        groups = match.groupdict()
+        return build_tzinfo(
+            groups["tzname"],
+            groups["tzsign"],
+            int(groups["tzhour"] or 0),
+            int(groups["tzmin"] or 0),
+        )
+    raise ISO8601Error("%s not a valid time zone info" % tzstring)
+
+
+def tz_isoformat(dt, format="%Z"):
+    """
+    return time zone offset ISO 8601 formatted.
+    The various ISO formats can be chosen with the format parameter.
+
+    if tzinfo is None returns ''
+    if tzinfo is UTC returns 'Z'
+    else the offset is rendered to the given format.
+    format:
+        %h ... +-HH
+        %z ... +-HHMM
+        %Z ... +-HH:MM
+    """
+    tzinfo = dt.tzinfo
+    if (tzinfo is None) or (tzinfo.utcoffset(dt) is None):
+        return ""
+    if tzinfo.utcoffset(dt) == ZERO and tzinfo.dst(dt) == ZERO:
+        return "Z"
+    tdelta = tzinfo.utcoffset(dt)
+    seconds = tdelta.days * 24 * 60 * 60 + tdelta.seconds
+    sign = ((seconds < 0) and "-") or "+"
+    seconds = abs(seconds)
+    minutes, seconds = divmod(seconds, 60)
+    hours, minutes = divmod(minutes, 60)
+    if hours > 99:
+        raise OverflowError("can not handle differences > 99 hours")
+    if format == "%Z":
+        return "%s%02d:%02d" % (sign, hours, minutes)
+    elif format == "%z":
+        return "%s%02d%02d" % (sign, hours, minutes)
+    elif format == "%h":
+        return "%s%02d" % (sign, hours)
+    raise ValueError('unknown format string "%s"' % format)