blob: e750e3768602c8790d1b1c864b3019eac5d11e07 [file] [log] [blame]
MG Mud User88f12472016-06-24 23:31:02 +02001SYNOPSIS
Zesstrad59c3892019-11-28 20:53:39 +01002 #include <time.h>
MG Mud User88f12472016-06-24 23:31:02 +02003
Zesstrad59c3892019-11-28 20:53:39 +01004 int mktime(int *ts)
MG Mud User88f12472016-06-24 23:31:02 +02005
6BESCHREIBUNG
Zesstrad59c3892019-11-28 20:53:39 +01007 Ist das Argument <ts> ein Array mit 9 Elementen (int) entsprechend
8 des Rueckgabewertes von local_time()/gm_time(), so liefert die Funktion
MG Mud User88f12472016-06-24 23:31:02 +02009 die Anzahl Sekunden seit dem 01. Januar 1970, 00:00:00 zurueck.
10 Dies ist von Nutzen, wenn man ein Datum/Uhrzeit hat, diese aber als
11 Ganzzahl-Wert speichern will oder eine Zeitdifferenz zwischen zwei
12 Daten ausrechnen will.
13
14 Das Array muss dabei so aufgebaut sein:
15 int TM_SEC (0): Sekunde in der Minute (0..59)
16 int TM_MIN (1): Minute in der Stunde (0..59)
17 int TM_HOUR (2): Stunde des Tages (0..23)
18 int TM_MDAY (3): Tag im Monat (1..31)
19 int TM_MON (4): Monat des Jahres (0..11)
20 int TM_YEAR (5): Jahr (z.B. 2001)
21 int TM_WDAY (6): Wochentag (0..6, Sonntag = 0)
22 int TM_YDAY (7): Tag im Jahr (0..365)
23 inz TM_ISDST (8): TRUE: Daylight Saving Time
24
Zesstrad59c3892019-11-28 20:53:39 +010025 TM_YDAY und TM_WDAY werden ignoriert und koennen beliebige Zahlen
26 enthalten.
MG Mud User88f12472016-06-24 23:31:02 +020027
Zesstrad59c3892019-11-28 20:53:39 +010028BEISPIELE
29 Man hat ein Datum/Uhrzeit (z.B. Benutzereingabe), welches als
30 Unix-Zeitstempel gespeichert werden soll:
31 // "Mit, 24. Okt 2007, 10:48:00" entspricht folgendem Zeitstempel:
32 int unixzeit = mktime(({0, 48, 09, 24, 09, 2007, 0, 01, 0}));
MG Mud User88f12472016-06-24 23:31:02 +020033
Zesstrad59c3892019-11-28 20:53:39 +010034GESCHICHTE
35 Eingefuehrt in LDMud 3.3.718.
MG Mud User88f12472016-06-24 23:31:02 +020036
37SIEHE AUCH
Zesstrad59c3892019-11-28 20:53:39 +010038 ctime(E), gmtime(E), local_time(E), time(E), utime(E)