Initial code commit for Toolkit 1.1.
[silc.git] / lib / silcutil / silctime.h
diff --git a/lib/silcutil/silctime.h b/lib/silcutil/silctime.h
new file mode 100644 (file)
index 0000000..c72f0a9
--- /dev/null
@@ -0,0 +1,196 @@
+/*
+
+  silctime.h
+
+  Author: Pekka Riikonen <priikone@silcnet.org>
+
+  Copyright (C) 2003 - 2005 Pekka Riikonen
+
+  This program is free software; you can redistribute it and/or modify
+  it under the terms of the GNU General Public License as published by
+  the Free Software Foundation; version 2 of the License.
+
+  This program is distributed in the hope that it will be useful,
+  but WITHOUT ANY WARRANTY; without even the implied warranty of
+  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+  GNU General Public License for more details.
+
+*/
+
+/****h* silcutil/SILC Time Interface
+ *
+ * DESCRIPTION
+ *
+ * This interface provides various utility functions for getting current
+ * time and converting different time representations into the SilcTime
+ * representation.
+ *
+ ***/
+
+#ifndef SILCTIME_H
+#define SILCTIME_H
+
+/****s* silcutil/SilcTimeAPI/SilcTime
+ *
+ * NAME
+ *
+ *    typedef struct { ... } *SilcTime, SilcTimeStruct;
+ *
+ * DESCRIPTION
+ *
+ *    This context represents time value.  It includes date and time
+ *    down to millisecond precision.
+ *
+ * SOURCE
+ *
+ ***/
+typedef struct {
+  unsigned int year       : 13;           /* Year,     0 - 8191 */
+  unsigned int month      : 4;    /* Month,    1 - 12 */
+  unsigned int day        : 5;    /* Day,      1 - 31 */
+  unsigned int hour       : 5;    /* Hour,     0 - 23 */
+  unsigned int minute     : 6;    /* Minute,   0 - 59 */
+  unsigned int second     : 6;    /* Second,   0 - 61 */
+  unsigned int msecond    : 10;           /* Millisec, 0 - 1000 */
+  unsigned int utc_hour   : 5;    /* Offset to Zulu (UTC) hours */
+  unsigned int utc_minute : 6;    /* Offset to Zulu (UTC) minutes */
+  unsigned int utc_east   : 1;    /* Offset, 1 east (+), 0 west (-) */
+  unsigned int dst        : 1;    /* Set if daylight saving time */
+  /* 2 bits to spare */
+} *SilcTime, SilcTimeStruct;
+/***/
+
+/****f* silcutil/SilcTimeAPI/silc_time
+ *
+ * SYNOPSIS
+ *
+ *    SilcInt64 silc_time(void);
+ *
+ * DESCRIPTION
+ *
+ *    Returns the current time of the system since Epoch.  The returned
+ *    value is seconds since Epoch (1.1.1970).  Returns -1 on error.
+ *
+ ***/
+SilcInt64 silc_time(void);
+
+/****f* silcutil/SilcTimeAPI/silc_time_string
+ *
+ * SYNOPSIS
+ *
+ *    const char *silc_time_string(SilcInt64 timeval);
+ *
+ * DESCRIPTION
+ *
+ *    Returns time and date as string.  The caller must not free the string
+ *    and next call to this function will delete the old string.  If the
+ *    `timeval' is zero (0) returns current time as string, otherwise the
+ *    `timeval' as string.  Returns NULL on error.
+ *
+ ***/
+const char *silc_time_string(SilcInt64 timeval);
+
+/****f* silcutil/SilcTimeAPI/silc_time_value
+ *
+ * SYNOPSIS
+ *
+ *   bool silc_time_value(SilcInt64 timeval, SilcTime ret_time);
+ *
+ * DESCRIPTION
+ *
+ *    Returns time and date as SilcTime.  If the `timeval' is zero (0)
+ *    returns current time as SilcTime, otherwise the `timeval' as SilcTime.
+ *    Returns FALSE on error, TRUE otherwise.
+ *
+ ***/
+bool silc_time_value(SilcInt64 timeval, SilcTime ret_time);
+
+/****f* silcutil/SilcTimeAPI/silc_time_universal
+ *
+ * SYNOPSIS
+ *
+ *    bool silc_time_universal(const char *universal_time,
+ *                             SilcTime ret_time);
+ *
+ * DESCRIPTION
+ *
+ *    Returns time and date as SilcTime from `universal_time' string which
+ *    format is "YYMMDDhhmmssZ", where YY is year, MM is month, DD is day,
+ *    hh is hour, mm is minutes, ss is seconds and Z is timezone, which
+ *    by default is Zulu (UTC).  Universal time is defined in ISO/EIC 8824-1.
+ *
+ *    Returns FALSE on error, TRUE otherwise.
+ *
+ * EXAMPLE
+ *
+ *    SilcTimeStruct ret_time;
+ *
+ *    time is 03/02/19 19:04:03 Zulu (UTC)
+ *    silc_time_universal("030219190403Z", &ret_time);
+ *
+ ***/
+bool silc_time_universal(const char *universal_time, SilcTime ret_time);
+
+/****f* silcutil/SilcTimeAPI/silc_time_universal_string
+ *
+ * SYNOPSIS
+ *
+ *    bool silc_time_universal_string(SilcTime timeval, char *ret_string,
+ *                                    SilcUInt32 ret_string_size);
+ *
+ * DESCRIPTION
+ *
+ *    Encodes the SilcTime `time' into the universal time format into the
+ *    `ret_string' buffer.  Returns FALSE if the buffer is too small.
+ *
+ ***/
+bool silc_time_universal_string(SilcTime timeval, char *ret_string,
+                               SilcUInt32 ret_string_size);
+
+/****f* silcutil/SilcTimeAPI/silc_time_generalized
+ *
+ * SYNOPSIS
+ *
+ *    bool silc_time_generalized(const char *generalized_time,
+ *                               SilcTime ret_time);
+ *
+ * DESCRIPTION
+ *
+ *    Returns time and date as SilcTime from `generalized_time' string which
+ *    format is "YYYYMMDDhhmmss.ppZ", where YYYY is year, MM is month, DD
+ *    is day, hh is hour, mm is minutes, ss is seconds which may have optional
+ *    precision pp, and Z is timezone, which by default is Zulu (UTC).
+ *    Generalized time is defined in ISO/EIC 8824-1.
+ *
+ *    Returns FALSE on error, TRUE otherwise.
+ *
+ * EXAMPLE
+ *
+ *    SilcTimeStruct ret_time;
+ *
+ *    time is 2003/02/19 19:04:03 Zulu (UTC)
+ *    silc_time_generalized("20030219190403Z", &ret_time);
+ *
+ *    time is 2003/02/19 19:05:10.212 Zulu (UTC)
+ *    silc_time_generalized("20030219190510.212Z", &ret_time);
+ *
+ ***/
+bool silc_time_generalized(const char *generalized_time, SilcTime ret_time);
+
+/****f* silcutil/SilcTimeAPI/silc_time_generalized_string
+ *
+ * SYNOPSIS
+ *
+ *    bool silc_time_generalized_string(SilcTime timeval, char *ret_string,
+ *                                      SilcUInt32 ret_string_size);
+ *
+ * DESCRIPTION
+ *
+ *    Encodes the SilcTime `time' into the generalized time format into the
+ *    `ret_string' buffer.  Returns FALSE if the buffer is too small.
+ *
+ ***/
+bool silc_time_generalized_string(SilcTime timeval, char *ret_string,
+                                 SilcUInt32 ret_string_size);
+
+#endif /* SILCTIME_H */