From 91d1db8456410623ee8f3ae6a08e2e3751c6618a Mon Sep 17 00:00:00 2001 From: Tilghman Lesher Date: Mon, 7 Apr 2008 19:06:46 +0000 Subject: [PATCH] Merged revisions 113117 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r113117 | tilghman | 2008-04-07 12:51:49 -0500 (Mon, 07 Apr 2008) | 3 lines Force ast_mktime() to check for DST, since strptime(3) does not. (Closes issue #12374) ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@113172 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- funcs/func_strings.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/funcs/func_strings.c b/funcs/func_strings.c index 45d476ef21..f50ea245dc 100644 --- a/funcs/func_strings.c +++ b/funcs/func_strings.c @@ -704,7 +704,10 @@ static int acf_strptime(struct ast_channel *chan, const char *cmd, char *data, if (!strptime(args.timestring, args.format, &t.time)) { ast_log(LOG_WARNING, "C function strptime() output nothing?!!\n"); } else { - struct timeval tv = ast_mktime(&t.atm, args.timezone); + struct timeval tv; + /* Since strptime(3) does not check DST, force ast_mktime() to calculate it. */ + t.atm.tm_isdst = -1; + tv = ast_mktime(&t.atm, args.timezone); snprintf(buf, len, "%d", (int) tv.tv_sec); }