diff --git a/ChangeLog b/ChangeLog index 19ca56bf17..e7a6778567 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +Tue Feb 14 11:42:38 2006 NAKAMURA Usaku + + * time.c (search_time_t): support non 32bit time_t environments. + + * win32/Makefile.sub (config.h): VC++8 have ``long long'' type. + + * win32/Makefile.sub (config.h): VC++8's time_t is 64bit value. + Mon Feb 13 18:01:52 2006 Yukihiro Matsumoto * eval.c (copy_node_scope): remove duplicated semicolons at end. diff --git a/time.c b/time.c index 3252b8b55b..666199dd0a 100644 --- a/time.c +++ b/time.c @@ -459,6 +459,16 @@ tmcmp(struct tm *a, struct tm *b) return 0; } +#if SIZEOF_TIME_T == SIZEOF_LONG +typedef unsigned long unsigned_time_t; +#elif SIZEOF_TIME_T == SIZEOF_INT +typedef unsigned int unsigned_time_t; +#elif SIZEOF_TIME_T == SIZEOF_LONG_LONG +typedef unsigned LONG_LONG unsigned_time_t; +#else +# error cannot find integer type which size is same as time_t. +#endif + static time_t search_time_t(struct tm *tptr, int utc_p) { @@ -470,12 +480,12 @@ search_time_t(struct tm *tptr, int utc_p) find_dst = 0 < tptr->tm_isdst; #ifdef NEGATIVE_TIME_T - guess_lo = 1L << (8 * sizeof(time_t) - 1); + guess_lo = (time_t)~((unsigned_time_t)~(time_t)0 >> 1); #else guess_lo = 0; #endif guess_hi = ((time_t)-1) < ((time_t)0) ? - (1UL << (8 * sizeof(time_t) - 1)) - 1 : + (time_t)((unsigned_time_t)~(time_t)0 >> 1) : ~(time_t)0; guess = timegm_noleapsecond(tptr); @@ -1201,16 +1211,6 @@ time_to_s(VALUE time) return rb_str_new(buf, len); } -#if SIZEOF_TIME_T == SIZEOF_LONG -typedef unsigned long unsigned_time_t; -#elif SIZEOF_TIME_T == SIZEOF_INT -typedef unsigned int unsigned_time_t; -#elif SIZEOF_TIME_T == SIZEOF_LONG_LONG -typedef unsigned LONG_LONG unsigned_time_t; -#else -# error cannot find integer type which size is same as time_t. -#endif - static VALUE time_add(struct time_object *tobj, VALUE offset, int sign) { diff --git a/win32/Makefile.sub b/win32/Makefile.sub index 0c48ba8bbe..d6e4780709 100644 --- a/win32/Makefile.sub +++ b/win32/Makefile.sub @@ -225,13 +225,21 @@ $(CONFIG_H): $(MKFILES) $(srcdir)/win32/Makefile.sub #define SIZEOF_INT 4 #define SIZEOF_SHORT 2 #define SIZEOF_LONG 4 +!if $(MSC_VER) >= 1400 +#define SIZEOF_LONG_LONG 8 +!else #define SIZEOF_LONG_LONG 0 +!endif #define SIZEOF___INT64 8 #define SIZEOF_OFF_T 4 #define SIZEOF_VOIDP 4 #define SIZEOF_FLOAT 4 #define SIZEOF_DOUBLE 8 +!if $(MSC_VER) >= 1400 +#define SIZEOF_TIME_T 8 +!else #define SIZEOF_TIME_T 4 +!endif #define HAVE_PROTOTYPES 1 #define TOKEN_PASTE(x,y) x##y #define HAVE_STDARG_PROTOTYPES 1