mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
19991129
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:
parent
a9412adde8
commit
7b319538c2
8 changed files with 87 additions and 26 deletions
28
ChangeLog
28
ChangeLog
|
|
@ -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
1
enum.c
|
|
@ -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
48
eval.c
|
|
@ -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
17
gc.c
|
|
@ -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);
|
||||||
|
|
|
||||||
1
intern.h
1
intern.h
|
|
@ -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));
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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)
|
||||||
|
|
|
||||||
12
variable.c
12
variable.c
|
|
@ -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
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue