Author: marius
Date: Thu Sep  7 23:28:35 2017
New Revision: 323291
URL: https://svnweb.freebsd.org/changeset/base/323291

Log:
  MFC: r321293
  
  date: avoid crash on invalid time
  
  PR:           220828
  Approved by:  re (kib)

Modified:
  stable/10/bin/date/date.c
Directory Properties:
  stable/10/   (props changed)

Modified: stable/10/bin/date/date.c
==============================================================================
--- stable/10/bin/date/date.c   Thu Sep  7 21:43:39 2017        (r323290)
+++ stable/10/bin/date/date.c   Thu Sep  7 23:28:35 2017        (r323291)
@@ -85,7 +85,7 @@ main(int argc, char *argv[])
        int set_timezone;
        struct vary *v;
        const struct vary *badv;
-       struct tm lt;
+       struct tm *lt;
        struct stat sb;
 
        v = NULL;
@@ -174,8 +174,10 @@ main(int argc, char *argv[])
        if (*argv && **argv == '+')
                format = *argv + 1;
 
-       lt = *localtime(&tval);
-       badv = vary_apply(v, &lt);
+       lt = localtime(&tval);
+       if (lt == NULL)
+               errx(1, "invalid time");
+       badv = vary_apply(v, lt);
        if (badv) {
                fprintf(stderr, "%s: Cannot apply date adjustment\n",
                        badv->arg);
@@ -191,7 +193,7 @@ main(int argc, char *argv[])
                 */
                setlocale(LC_TIME, "C");
 
-       (void)strftime(buf, sizeof(buf), format, &lt);
+       (void)strftime(buf, sizeof(buf), format, lt);
        (void)printf("%s\n", buf);
        if (fflush(stdout))
                err(1, "stdout");
@@ -210,6 +212,8 @@ setthetime(const char *fmt, const char *p, int jflag, 
        int century;
 
        lt = localtime(&tval);
+       if (lt == NULL)
+               errx(1, "invalid time");
        lt->tm_isdst = -1;              /* divine correct DST */
 
        if (fmt != NULL) {
_______________________________________________
[email protected] mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "[email protected]"

Reply via email to