summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-28 08:35:52 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-28 08:35:52 +0000
commit48af602e38293f53e7c9afa7b41ba778714220f4 (patch)
tree41616dbb2f84a964c02563f1909c2ce368abb77e
parent727d85c0e359657ea0538c9d81de2f870d007120 (diff)
* time.c (make_time_t): verify mktime and timegm result.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14765 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--time.c29
2 files changed, 17 insertions, 16 deletions
diff --git a/ChangeLog b/ChangeLog
index e7f633043c..564a489c62 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Fri Dec 28 17:33:44 2007 Tanaka Akira <akr@fsij.org>
+
+ * time.c (make_time_t): verify mktime and timegm result.
+
Fri Dec 28 16:36:33 2007 NARUSE, Yui <naruse@airemix.com>
* lib/resolv.rb (Resolv::DNS#each_address): now returns IPv6 address.
diff --git a/time.c b/time.c
index 36df242ee5..f9ebc6900f 100644
--- a/time.c
+++ b/time.c
@@ -826,40 +826,37 @@ make_time_t(struct tm *tptr, int utc_p)
buf = *tptr;
if (utc_p) {
#if defined(HAVE_TIMEGM)
- if ((t = timegm(&buf)) != -1)
- return t;
-#ifdef NEGATIVE_TIME_T
+ t = timegm(&buf);
+ if (t == (time_t)-1)
+#endif
+ t = search_time_t(&buf, utc_p);
if ((tmp = gmtime(&t)) &&
tptr->tm_year == tmp->tm_year &&
tptr->tm_mon == tmp->tm_mon &&
tptr->tm_mday == tmp->tm_mday &&
tptr->tm_hour == tmp->tm_hour &&
tptr->tm_min == tmp->tm_min &&
- tptr->tm_sec == tmp->tm_sec
- )
+ tptr->tm_sec == tmp->tm_sec) {
return t;
-#endif
-#endif
- return search_time_t(&buf, utc_p);
+ }
}
else {
#if defined(HAVE_MKTIME)
- if ((t = mktime(&buf)) != -1)
- return t;
-#ifdef NEGATIVE_TIME_T
+ t = mktime(&buf);
+ if (t == (time_t)-1)
+#endif
+ t = search_time_t(&buf, utc_p);
if ((tmp = localtime(&t)) &&
tptr->tm_year == tmp->tm_year &&
tptr->tm_mon == tmp->tm_mon &&
tptr->tm_mday == tmp->tm_mday &&
tptr->tm_hour == tmp->tm_hour &&
tptr->tm_min == tmp->tm_min &&
- tptr->tm_sec == tmp->tm_sec
- )
+ tptr->tm_sec == tmp->tm_sec) {
return t;
-#endif
-#endif
- return search_time_t(&buf, utc_p);
+ }
}
+ rb_raise(rb_eArgError, "couldn't generate a time");
}
static VALUE