diff --git a/ChangeLog b/ChangeLog index 57f3832e45..5749b70a32 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +Tue Mar 8 10:05:40 2005 Yukihiro Matsumoto + + * error.c (errno_missing): Errno.const_missing to allow references + to SyscallError exceptions not defined on the platform. + [ruby-core:04522] + + * error.c (Init_syserr): Errno::NOERROR(0) for fallback exception. + Sat Mar 8 01:19:00 2005 NARUSE, Yui * ext/nkf/nkf-utf8/nkf.c: follow nkf 1.66 @@ -22,6 +30,11 @@ Mon Mar 7 16:46:02 2005 NAKAMURA Usaku * ext/openssl/ossl_ssl.c (ossl_start_ssl, ossl_ssl_read, ossl_ssl_write): need to set errno on Win32 platform. +Mon Mar 7 14:55:43 2005 Yukihiro Matsumoto + + * eval.c (block_pass): should not push unique number if a block is + not an orphan. [ruby-dev:25808] + Mon Mar 7 14:13:23 2005 GOTOU Yuuzou * ext/openssl/lib/openssl/buffering.rb (Buffering#initialize): diff --git a/error.c b/error.c index f8414060f5..91bc993542 100644 --- a/error.c +++ b/error.c @@ -312,6 +312,7 @@ VALUE rb_eLoadError; VALUE rb_eSystemCallError; VALUE rb_mErrno; +static VALUE eNOERROR; VALUE rb_exc_new(etype, ptr, len) @@ -1016,6 +1017,13 @@ syserr_eqq(self, exc) return Qfalse; } +static VALUE +errno_missing(self, id) + VALUE self, id; +{ + return eNOERROR; +} + /* * Descendents of class Exception are used to communicate * between raise methods and rescue @@ -1085,6 +1093,7 @@ Init_Exception() rb_define_singleton_method(rb_eSystemCallError, "===", syserr_eqq, 1); rb_mErrno = rb_define_module("Errno"); + rb_define_singleton_method(rb_mErrno, "const_missing", errno_missing, 1); rb_define_global_function("warn", rb_warn_m, 1); } @@ -1587,6 +1596,7 @@ Init_syserr() #ifdef EDQUOT set_syserr(EDQUOT, "EDQUOT"); #endif + eNOERROR = set_syserr(0, "NOERROR"); } static void diff --git a/eval.c b/eval.c index 276989aa45..59e115408a 100644 --- a/eval.c +++ b/eval.c @@ -8598,7 +8598,7 @@ rb_block_pass(func, arg, proc) /* PUSH BLOCK from data */ _block = *data; _block.outer = ruby_block; - _block.uniq = block_unique++; + if (orphan) _block.uniq = block_unique++; ruby_block = &_block; PUSH_ITER(ITER_PRE); if (ruby_frame->iter == ITER_NOT) diff --git a/lib/parsedate.rb b/lib/parsedate.rb index 2c24ec1636..39b5e7fa1e 100644 --- a/lib/parsedate.rb +++ b/lib/parsedate.rb @@ -12,8 +12,9 @@ module ParseDate def strptime(str, format) - Date._strptime(str, format). - values_at(:year, :mon, :mday, :hour, :min, :sec, :zone, :wday) + d = Date._strptime(str, format) + raise ArgumentError, "invalid strptime format - `#{format}'" unless d + d.values_at(:year, :mon, :mday, :hour, :min, :sec, :zone, :wday) end module_function :parsedate, :strptime