1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_4@572 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
matz 1999-11-29 06:33:02 +00:00
parent a9412adde8
commit 7b319538c2
8 changed files with 87 additions and 26 deletions

View file

@ -1,3 +1,31 @@
Mon Nov 29 15:28:52 1999 Yukihiro Matsumoto <matz@netlab.co.jp>
* variable.c (rb_path2class): evaluated value from path should be
module or class.
Fri Nov 26 18:12:49 1999 Yukihiro Matsumoto <matz@netlab.co.jp>
* eval.c (rb_exec_end_proc): should remove only end_procs defined
within load wrapper.
* eval.c (rb_load): save and restore ruby_wrapper around loading.
* eval.c (rb_mark_end_proc): mark end procs registered by END{} or
at_exit{}.
* eval.c (rb_set_end_proc): should not call rb_global_variable()
on heap address; it crashed mod_ruby.
Fri Nov 26 18:12:49 1999 Yukihiro Matsumoto <matz@netlab.co.jp>
* enum.c (enum_grep): does not return nil.
* eval.c (rb_mark_end_proc): mark end procs registered by END{} or
at_exit{}.
* eval.c (rb_set_end_proc): should not call rb_global_variable()
on heap address; it crashed mod_ruby.
Thu Nov 18 16:18:27 1999 Yukihiro Matsumoto <matz@netlab.co.jp> Thu Nov 18 16:18:27 1999 Yukihiro Matsumoto <matz@netlab.co.jp>
* lib/pstore.rb: mutual lock by flock(2). * lib/pstore.rb: mutual lock by flock(2).

1
enum.c
View file

@ -54,7 +54,6 @@ enum_grep(obj, pat)
} }
else { else {
rb_iterate(rb_each, obj, grep_i, (VALUE)arg); rb_iterate(rb_each, obj, grep_i, (VALUE)arg);
if (RARRAY(tmp)->len == 0) return Qnil;
} }
return tmp; return tmp;
} }

48
eval.c
View file

@ -4655,6 +4655,7 @@ rb_load(fname, wrap)
int state; int state;
char *file; char *file;
volatile ID last_func; volatile ID last_func;
volatile VALUE wrapper = 0;
VALUE self = ruby_top_self; VALUE self = ruby_top_self;
TMP_PROTECT; TMP_PROTECT;
@ -4671,9 +4672,11 @@ rb_load(fname, wrap)
PUSH_VARS(); PUSH_VARS();
PUSH_CLASS(); PUSH_CLASS();
wrapper = ruby_wrapper;
if (!wrap) { if (!wrap) {
rb_secure(4); /* should alter global state */ rb_secure(4); /* should alter global state */
ruby_class = rb_cObject; ruby_class = rb_cObject;
ruby_wrapper = 0;
} }
else { else {
/* load in anonymous module as toplevel */ /* load in anonymous module as toplevel */
@ -4720,7 +4723,7 @@ rb_load(fname, wrap)
POP_FRAME(); POP_FRAME();
POP_CLASS(); POP_CLASS();
POP_VARS(); POP_VARS();
ruby_wrapper = 0; ruby_wrapper = wrapper;
if (ruby_nerrs > 0) { if (ruby_nerrs > 0) {
ruby_nerrs = 0; ruby_nerrs = 0;
rb_exc_raise(ruby_errinfo); rb_exc_raise(ruby_errinfo);
@ -5193,7 +5196,8 @@ struct end_proc_data {
VALUE data; VALUE data;
struct end_proc_data *next; struct end_proc_data *next;
}; };
static struct end_proc_data *end_proc_data;
static struct end_proc_data *end_procs, *ephemeral_end_procs;
void void
rb_set_end_proc(func, data) rb_set_end_proc(func, data)
@ -5201,12 +5205,31 @@ rb_set_end_proc(func, data)
VALUE data; VALUE data;
{ {
struct end_proc_data *link = ALLOC(struct end_proc_data); struct end_proc_data *link = ALLOC(struct end_proc_data);
struct end_proc_data **list;
link->next = end_proc_data; if (ruby_wrapper) list = &ephemeral_end_procs;
else list = &end_procs;
link->next = *list;
link->func = func; link->func = func;
link->data = data; link->data = data;
rb_global_variable(&link->data); *list = link;
end_proc_data = link; }
void
rb_mark_end_proc()
{
struct end_proc_data *link;
link = end_procs;
while (link) {
rb_gc_mark(link->data);
link = link->next;
}
link = ephemeral_end_procs;
while (link) {
rb_gc_mark(link->data);
link = link->next;
}
} }
static void static void
@ -5239,17 +5262,20 @@ rb_f_at_exit()
void void
rb_exec_end_proc() rb_exec_end_proc()
{ {
struct end_proc_data *link = end_proc_data; struct end_proc_data *link;
struct end_proc_data *tmp;
int status; int status;
link = end_procs;
while (link) { while (link) {
rb_protect((VALUE(*)())link->func, link->data, &status); rb_protect((VALUE(*)())link->func, link->data, &status);
tmp = link->next; link = link->next;
free(link); }
link = tmp; while (ephemeral_end_procs) {
link = ephemeral_end_procs;
ephemeral_end_procs = link->next;
rb_protect((VALUE(*)())link->func, link->data, &status);
free(link);
} }
end_proc_data = 0;
} }
void void

17
gc.c
View file

@ -893,6 +893,10 @@ rb_gc()
jmp_buf save_regs_gc_mark; jmp_buf save_regs_gc_mark;
#ifdef C_ALLOCA #ifdef C_ALLOCA
VALUE stack_end; VALUE stack_end;
alloca(0);
# define STACK_END (&stack_end)
#else
# define STACK_END alloca(1)
#endif #endif
alloc_objects = 0; alloc_objects = 0;
@ -901,10 +905,6 @@ rb_gc()
if (during_gc) return; if (during_gc) return;
during_gc++; during_gc++;
#ifdef C_ALLOCA
alloca(0);
#endif
/* mark frame stack */ /* mark frame stack */
for (frame = ruby_frame; frame; frame = frame->prev) { for (frame = ruby_frame; frame; frame = frame->prev) {
rb_gc_mark_frame(frame); rb_gc_mark_frame(frame);
@ -924,18 +924,14 @@ rb_gc()
/* This assumes that all registers are saved into the jmp_buf */ /* This assumes that all registers are saved into the jmp_buf */
setjmp(save_regs_gc_mark); setjmp(save_regs_gc_mark);
mark_locations_array((VALUE*)save_regs_gc_mark, sizeof(save_regs_gc_mark) / sizeof(VALUE *)); mark_locations_array((VALUE*)save_regs_gc_mark, sizeof(save_regs_gc_mark) / sizeof(VALUE *));
#ifdef C_ALLOCA rb_gc_mark_locations(rb_gc_stack_start, (VALUE*)STACK_END);
rb_gc_mark_locations(rb_gc_stack_start, (VALUE*)&stack_end);
#else
rb_gc_mark_locations(rb_gc_stack_start, (VALUE*)alloca(1));
#endif
#if defined(THINK_C) || defined(__human68k__) #if defined(THINK_C) || defined(__human68k__)
#ifndef __human68k__ #ifndef __human68k__
mark_locations_array((VALUE*)((char*)save_regs_gc_mark+2), mark_locations_array((VALUE*)((char*)save_regs_gc_mark+2),
sizeof(save_regs_gc_mark) / sizeof(VALUE *)); sizeof(save_regs_gc_mark) / sizeof(VALUE *));
#endif #endif
rb_gc_mark_locations((VALUE*)((char*)rb_gc_stack_start + 2), rb_gc_mark_locations((VALUE*)((char*)rb_gc_stack_start + 2),
(VALUE*)((char*)&stack_end + 2)); (VALUE*)((char*)STACK_END + 2));
#endif #endif
rb_gc_mark_threads(); rb_gc_mark_threads();
@ -943,6 +939,7 @@ rb_gc()
for (list = Global_List; list; list = list->next) { for (list = Global_List; list; list = list->next) {
rb_gc_mark(*list->varptr); rb_gc_mark(*list->varptr);
} }
rb_mark_end_proc();
rb_gc_mark_global_tbl(); rb_gc_mark_global_tbl();
rb_mark_tbl(rb_class_tbl); rb_mark_tbl(rb_class_tbl);

View file

@ -121,6 +121,7 @@ VALUE rb_f_lambda _((void));
VALUE rb_protect _((VALUE (*)(), VALUE, int*)); VALUE rb_protect _((VALUE (*)(), VALUE, int*));
void rb_set_end_proc _((void (*)(), VALUE)); void rb_set_end_proc _((void (*)(), VALUE));
void rb_exec_end_proc _((void)); void rb_exec_end_proc _((void));
void rb_mark_end_proc _((void));
void rb_gc_mark_threads _((void)); void rb_gc_mark_threads _((void));
void rb_thread_start_timer _((void)); void rb_thread_start_timer _((void));
void rb_thread_stop_timer _((void)); void rb_thread_stop_timer _((void));

View file

@ -107,6 +107,7 @@ class PStore
Marshal::dump(@table, file) Marshal::dump(@table, file)
rescue rescue
File::rename backup, @filename if File::exist?(backup) File::rename backup, @filename if File::exist?(backup)
raise
end end
end end
@abort = false @abort = false

View file

@ -664,7 +664,6 @@ An end of a defun is found by moving forward from the beginning of one."
"return" "return"
"then" "then"
"throw" "throw"
"self"
"super" "super"
"unless" "unless"
"undef" "undef"
@ -676,8 +675,8 @@ An end of a defun is found by moving forward from the beginning of one."
"\\)\\>[^_]") "\\)\\>[^_]")
2) 2)
;; variables ;; variables
'("\\b\\(nil\\|self\\|true\\|false\\)\\b" '("\\(^\\|[^_:.@$]\\|\\.\\.\\)\\b\\(nil\\|self\\|true\\|false\\)\\b[^_]"
1 font-lock-variable-name-face) 2 font-lock-variable-name-face)
;; variables ;; variables
'("[$@].\\(\\w\\|_\\)*" '("[$@].\\(\\w\\|_\\)*"
0 font-lock-variable-name-face) 0 font-lock-variable-name-face)

View file

@ -195,10 +195,20 @@ VALUE
rb_path2class(path) rb_path2class(path)
const char *path; const char *path;
{ {
VALUE c;
if (path[0] == '#') { if (path[0] == '#') {
rb_raise(rb_eArgError, "can't retrieve anonymous class %s", path); rb_raise(rb_eArgError, "can't retrieve anonymous class %s", path);
} }
return rb_eval_string(path); c = rb_eval_string(path);
switch (TYPE(c)) {
case T_MODULE:
case T_CLASS:
break;
default:
rb_raise(rb_eTypeError, "class path %s does not point class", path);
}
return c;
} }
void void