]> git.rm.cloudns.org Git - xonotic/gmqcc.git/commitdiff
Implemented __TIME__ for ftepp
authorDale Weiler <killfieldengine@gmail.com>
Wed, 2 Jan 2013 21:53:46 +0000 (21:53 +0000)
committerDale Weiler <killfieldengine@gmail.com>
Wed, 2 Jan 2013 21:53:46 +0000 (21:53 +0000)
ftepp.c

diff --git a/ftepp.c b/ftepp.c
index a5c50ee85544ad98dc808d44f130eb6f3fe98953..436b05beab8ff4c351565881e441b6a1990a9e31 100644 (file)
--- a/ftepp.c
+++ b/ftepp.c
@@ -100,6 +100,24 @@ char *ftepp_predef_date(lex_file *context) {
     return value;
 }
 
+/* __TIME__ */
+char *ftepp_predef_time(lex_file *context) {
+    struct tm *itime;
+    time_t     rtime;
+    char      *value = mem_a(82);
+    /* 82 is enough for strftime but we also have " " in our string */
+
+    (void)context;
+
+    /* get time */
+    time (&rtime);
+    itime = localtime(&rtime);
+
+    strftime(value, 82, "\"%X\"", itime);
+
+    return value;
+}
+
 /* __LINE__ */
 char *ftepp_predef_line(lex_file *context) {
     char   *value;
@@ -157,7 +175,8 @@ static const predef_t ftepp_predefs[] = {
     { "__COUNTER_LAST__", &ftepp_predef_counterlast },
     { "__RANDOM__",       &ftepp_predef_random      },
     { "__RANDOM_LAST__",  &ftepp_predef_randomlast  },
-    { "__DATE__",         &ftepp_predef_date        }
+    { "__DATE__",         &ftepp_predef_date        },
+    { "__TIME__",         &ftepp_predef_time        }
 };
 
 #define ftepp_tokval(f) ((f)->lex->tok.value)