[#21482] begin/rescue/else syntax is broken — akira yamada <akira@...>
[#21498] test/ChangeLog ? lib/ChangeLog — "NAKAMURA, Hiroshi" <nakahiro@...>
なひです。
[#21499] File#path on closed file. — Tanaka Akira <akr@...17n.org>
ふと、
そういえば、
まつもと ゆきひろです
[#21508] eval BEGIN/END at runtime — "NAKAMURA, Hiroshi" <nakahiro@...>
なひです。
なひです。
新井です。
[#21511] return value of freeze — Tanaka Akira <akr@...17n.org>
ふと、freeze を使って思ったのですが、これの返値は何なんでしょうか?
[#21531] O_ACCMODE — Tanaka Akira <akr@...17n.org>
POSIX において fcntl.h に定義されている、O_ACCMODE が欲しくなったので
西山和広です。
In article <20031007220838.CC51.ZN@mbf.nifty.com>,
[#21543] Enumerator — "Akinori MUSHA" <knu@...>
1.8.0 のtきは標準ライブラリ入りについて異論はなかったものの
新井です。
[#21556] rewinding for Thread — nobu.nakada@...
なかだです。
まつもと ゆきひろです
なかだです。
まつもと ゆきひろです
[#21557] at_exist and safe level — Tanaka Akira <akr@...17n.org>
% ruby -ve '$SAFE = x = 1; at_exit { p $SAFE; p x }'
[#21572] core dump in rb_thread_schedule — Tanaka Akira <akr@...17n.org>
今日、cvs update したら、rb_thread_schedule で core を吐くようになったのですが、
まつもと ゆきひろです
なかだです。
In article <200310090901.h9991gfA004660@sharui.nakada.kanuma.tochigi.jp>,
In article <87ekxmojwc.fsf@serein.a02.aist.go.jp>,
[#21590] extend with marshal_dump/marshal_load — "NAKAMURA, Hiroshi" <nakahiro@...>
なひです。
[#21607] autoload の patch は取り込まれないんでしょうか? — Hidetoshi NAGAI <nagai@...>
永井@知能.九工大です.
[#21616] access ENV on $SAFE==4 — Hidetoshi NAGAI <nagai@...>
永井@知能.九工大です.
まつもと ゆきひろです
ただただしです。
永井@知能.九工大です.
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
まつもと ゆきひろです
永井@知能.九工大です.
まつもと ゆきひろです
永井@知能.九工大です.
永井@知能.九工大です.
まつもと ゆきひろです
永井@知能.九工大です.
永井@知能.九工大です.
まつもと ゆきひろです
ただただしです。
まつもと ゆきひろです
[#21632] SEGV (test_drb.rb) — Masatoshi Seki <m_seki@...>
咳といいます。
[#21639] load() blocks thread scheduling — Tietew <tietew-ml-ruby-dev@...>
Tietew です。
まつもと ゆきひろです
[#21641] SOAP::StreamError: Illegal media type. — matz@... (Yukihiro Matsumoto)
まつもと ゆきひろです。
[#21679] Proposal: string literal concatenation — mput <root@...>
mput です。
[#21682] ruby-tk hangs when exception is raised — akira yamada <akira@...>
なかだです。
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
なかだです。
永井@知能.九工大です.
まつもと ゆきひろです
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
永井@知能.九工大です.
[#21707] drb Hash#each — matz@... (Yukihiro Matsumoto)
まつもと ゆきひろです
まつもと ゆきひろです
まつもと ゆきひろです
まつもと ゆきひろです
咳といいます。
まつもと ゆきひろです
まつもと ゆきひろです
まつもと ゆきひろです
[#21730] exit in $SAFE = 4 with -d — Tanaka Akira <akr@...17n.org>
% ruby -de 'lambda { $SAFE = 4; exit }.call; p 1'
[#21747] ruby 1.8.1 preview1 schedule — matz@... (Yukihiro Matsumoto)
関係者各位、
Siena. です。
なかだです。
Siena. です。
なかだです。
[#21778] IOError while building on Solaris with Sun cc — 桑村慎哉 <kuwa@...>
桑村です。
まつもと ゆきひろです
[#21790] ruby 1.8.1 preview1 — matz@... (Yukihiro Matsumoto)
It's out.
取り敢えず、NetBSD currentでの状況です。pkgsrc的なことは特にせず、ある
[#21794] ruby-1.8.1-preview2 での rb_iter_break — Kenta MURATA <muraken2@...>
むらけんです.
[ruby-dev:21552] Thread.value from break
なかだです。
Threadの中でbreakしたとき、常にvalueがfalseになります。
$ ruby -v -e 'p Thread.start{break 10}.value'
ruby 1.8.0 (2003-10-06) [i686-linux]
false
# ついでにvolatile減らし。
* eval.c (rb_thread_start_0): set the value from break.
* eval.c (rb_thread_start_0, rb_thread_raise, rb_callcc): save
variables across THREAD_SAVE_CONTEXT.
Index: eval.c
===================================================================
RCS file: /cvs/ruby/src/ruby/eval.c,v
retrieving revision 1.551
diff -u -2 -p -r1.551 eval.c
--- eval.c 6 Oct 2003 17:59:52 -0000 1.551
+++ eval.c 8 Oct 2003 13:36:10 -0000
@@ -8200,5 +8200,5 @@ rb_thread_check(data)
}
-static VALUE rb_thread_raise _((int, VALUE*, volatile rb_thread_t));
+static VALUE rb_thread_raise _((int, VALUE*, rb_thread_t));
static int th_raise_argc;
@@ -9402,12 +9402,11 @@ rb_thread_stop_timer()
static VALUE
-rb_thread_start_0(fn, arg, th_arg)
+rb_thread_start_0(fn, arg, th)
VALUE (*fn)();
void *arg;
- rb_thread_t th_arg;
+ rb_thread_t th;
{
- volatile rb_thread_t th = th_arg;
- volatile VALUE thread = th->thread;
- volatile struct BLOCK* saved_block = 0;
+ volatile rb_thread_t th_save = th;
+ struct BLOCK *volatile saved_block = 0, *block;
enum thread_status status;
int state;
@@ -9432,5 +9431,5 @@ rb_thread_start_0(fn, arg, th_arg)
if (THREAD_SAVE_CONTEXT(curr_thread)) {
- return thread;
+ return th_save->thread;
}
@@ -9461,4 +9460,8 @@ rb_thread_start_0(fn, arg, th_arg)
}
}
+ else if (TAG_DST()) {
+ th->result = prot_tag->retval;
+ }
+ th = th_save;
POP_TAG();
status = th->status;
@@ -9467,10 +9470,10 @@ rb_thread_start_0(fn, arg, th_arg)
rb_thread_remove(th);
- while (saved_block) {
- volatile struct BLOCK *tmp = saved_block;
+ for (block = saved_block; block;) {
+ struct BLOCK *tmp = block;
if (tmp->frame.argc > 0)
free(tmp->frame.argv);
- saved_block = tmp->prev;
+ block = tmp->prev;
free((void*)tmp);
}
@@ -9765,6 +9768,8 @@ rb_thread_raise(argc, argv, th)
int argc;
VALUE *argv;
- volatile rb_thread_t th;
+ rb_thread_t th;
{
+ volatile rb_thread_t th_save = th;
+
if (rb_thread_dead(th)) return Qnil;
if (curr_thread == th) {
@@ -9774,5 +9779,5 @@ rb_thread_raise(argc, argv, th)
if (!rb_thread_dead(curr_thread)) {
if (THREAD_SAVE_CONTEXT(curr_thread)) {
- return th->thread;
+ return th_save->thread;
}
}
@@ -9937,5 +9942,6 @@ rb_callcc(self)
{
volatile VALUE cont;
- volatile rb_thread_t th;
+ rb_thread_t th;
+ volatile rb_thread_t th_save;
struct tag *tag;
struct RVarmap *vars;
@@ -9955,6 +9961,7 @@ rb_callcc(self)
}
+ th_save = th;
if (THREAD_SAVE_CONTEXT(th)) {
- return th->result;
+ return th_save->result;
}
else {