From: Dale Weiler Date: Wed, 2 Jan 2013 21:53:46 +0000 (+0000) Subject: Implemented __TIME__ for ftepp X-Git-Tag: before-library~384 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=a2f63aae33190a6764cbb82b4c8a447a1bcc410e;p=xonotic%2Fgmqcc.git Implemented __TIME__ for ftepp --- diff --git a/ftepp.c b/ftepp.c index a5c50ee..436b05b 100644 --- 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)