diff options
author | Arnold D. Robbins <arnold@skeeve.com> | 2015-04-26 22:41:07 +0300 |
---|---|---|
committer | Arnold D. Robbins <arnold@skeeve.com> | 2015-04-26 22:41:07 +0300 |
commit | 20834c2a3086611f15814f24abfbb4b16d20275c (patch) | |
tree | afb3fd232f7dfa0e70ccfe94f011a59d531f8a84 /builtin.c | |
parent | 559a3395fcb32cdee8a6cdf482656c0b78628f8a (diff) | |
parent | 1770ada8bd6e72dfd3138d72cd6049edca79a4f5 (diff) | |
download | egawk-20834c2a3086611f15814f24abfbb4b16d20275c.tar.gz egawk-20834c2a3086611f15814f24abfbb4b16d20275c.tar.bz2 egawk-20834c2a3086611f15814f24abfbb4b16d20275c.zip |
Merge branch 'master' into feature/wasted-byte
Diffstat (limited to 'builtin.c')
-rw-r--r-- | builtin.c | 16 |
1 files changed, 11 insertions, 5 deletions
@@ -1925,15 +1925,21 @@ do_strftime(int nargs) clock_val = get_number_d(t2); fclock = (time_t) clock_val; /* - * 4/2015: Protect against negative value being assigned + * Protect against negative value being assigned * to unsigned time_t. */ - if (clock_val < 0 && fclock > 0) - fatal(_("strftime: second argument less than 0 or too big for time_t")); + if (clock_val < 0 && fclock > 0) { + if (do_lint) + lintwarn(_("strftime: second argument less than 0 or too big for time_t")); + return make_string("", 0); + } /* And check that the value is in range */ - if (clock_val < time_t_min || clock_val > time_t_max) - fatal(_("strftime: second argument out of range for time_t")); + if (clock_val < time_t_min || clock_val > time_t_max) { + if (do_lint) + lintwarn(_("strftime: second argument out of range for time_t")); + return make_string("", 0); + } DEREF(t2); } |