mirror of
https://github.com/ruby/ruby.git
synced 2025-08-23 21:14:23 +02:00
Merge from ruby_1_8.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_7@16539 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
ab3d450a54
commit
280f8df370
8 changed files with 73 additions and 45 deletions
26
ChangeLog
26
ChangeLog
|
@ -1,3 +1,29 @@
|
||||||
|
Fri May 23 01:03:23 2008 Akinori MUSHA <knu@iDaemons.org>
|
||||||
|
|
||||||
|
* class.c (rb_singleton_class_clone): Pass Qnil, not 0.
|
||||||
|
|
||||||
|
Fri May 23 00:51:48 2008 Akinori MUSHA <knu@iDaemons.org>
|
||||||
|
|
||||||
|
* class.c (clone_method): Totally revamp the previous fix which
|
||||||
|
was incorrect.
|
||||||
|
(rb_mod_init_copy): Ditto.
|
||||||
|
(singleton_class_clone_int): Ditto.
|
||||||
|
|
||||||
|
Fri May 23 00:48:10 2008 Akinori MUSHA <knu@iDaemons.org>
|
||||||
|
|
||||||
|
* eval.c (rb_copy_node_scope), node.h: Rename from copy_node_scope
|
||||||
|
and export.
|
||||||
|
|
||||||
|
Thu May 22 21:24:15 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
|
* parse.y (top_local_setup): fixed memory leak bug based on a
|
||||||
|
patch from Roger Pack <rogerpack2005 at gmail.com> in
|
||||||
|
[ruby-core:16610].
|
||||||
|
|
||||||
|
Thu May 22 14:20:54 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* array.c (flatten): check if reentered. [ruby-dev:34798]
|
||||||
|
|
||||||
Thu May 22 08:28:49 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Thu May 22 08:28:49 2008 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
* array.c (flatten): free memo hash table before raising exception.
|
* array.c (flatten): free memo hash table before raising exception.
|
||||||
|
|
8
array.c
8
array.c
|
@ -3107,8 +3107,8 @@ flatten(ary, level, modified)
|
||||||
st_table *memo;
|
st_table *memo;
|
||||||
st_data_t id;
|
st_data_t id;
|
||||||
|
|
||||||
stack = rb_ary_new();
|
stack = ary_new(0, ARY_DEFAULT_SIZE);
|
||||||
result = ary_new(rb_class_of(ary), RARRAY_LEN(ary));
|
result = ary_new(0, RARRAY_LEN(ary));
|
||||||
memo = st_init_numtable();
|
memo = st_init_numtable();
|
||||||
st_insert(memo, (st_data_t)ary, (st_data_t)Qtrue);
|
st_insert(memo, (st_data_t)ary, (st_data_t)Qtrue);
|
||||||
*modified = 0;
|
*modified = 0;
|
||||||
|
@ -3117,6 +3117,9 @@ flatten(ary, level, modified)
|
||||||
while (i < RARRAY(ary)->len) {
|
while (i < RARRAY(ary)->len) {
|
||||||
elt = RARRAY(ary)->ptr[i++];
|
elt = RARRAY(ary)->ptr[i++];
|
||||||
tmp = rb_check_array_type(elt);
|
tmp = rb_check_array_type(elt);
|
||||||
|
if (RBASIC(result)->klass) {
|
||||||
|
rb_raise(rb_eRuntimeError, "flatten reentered");
|
||||||
|
}
|
||||||
if (NIL_P(tmp) || (level >= 0 && RARRAY(stack)->len / 2 >= level)) {
|
if (NIL_P(tmp) || (level >= 0 && RARRAY(stack)->len / 2 >= level)) {
|
||||||
rb_ary_push(result, elt);
|
rb_ary_push(result, elt);
|
||||||
}
|
}
|
||||||
|
@ -3146,6 +3149,7 @@ flatten(ary, level, modified)
|
||||||
|
|
||||||
st_free_table(memo);
|
st_free_table(memo);
|
||||||
|
|
||||||
|
RBASIC(result)->klass = rb_class_of(ary);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
52
class.c
52
class.c
|
@ -48,42 +48,33 @@ rb_class_new(super)
|
||||||
return rb_class_boot(super);
|
return rb_class_boot(super);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct clone_method_data {
|
|
||||||
st_table *tbl;
|
|
||||||
VALUE klass;
|
|
||||||
VALUE cref;
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
clone_method(mid, body, data)
|
clone_method(mid, body, nklass)
|
||||||
ID mid;
|
ID mid;
|
||||||
NODE *body;
|
NODE *body;
|
||||||
struct clone_method_data *data;
|
VALUE nklass;
|
||||||
{
|
{
|
||||||
NODE *fbody = body->nd_body;
|
NODE *fbody = body->nd_body;
|
||||||
|
|
||||||
if (fbody && data->cref) {
|
if (fbody) {
|
||||||
VALUE body;
|
NODE *cref = NEW_NODE(NODE_CREF, nklass, 0, 0);
|
||||||
|
VALUE nbody;
|
||||||
|
|
||||||
switch (nd_type(fbody)) {
|
switch (nd_type(fbody)) {
|
||||||
case NODE_SCOPE:
|
case NODE_SCOPE:
|
||||||
if (fbody->nd_rval) {
|
fbody = rb_copy_node_scope(fbody, cref);
|
||||||
NODE *tmp = NEW_NODE(nd_type(fbody->u2.node), data->cref,
|
break;
|
||||||
fbody->u2.node->u2.node, fbody->u2.node->u3.node);
|
|
||||||
fbody = NEW_NODE(nd_type(fbody), fbody->u1.node, tmp, fbody->u3.node);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case NODE_BMETHOD:
|
case NODE_BMETHOD:
|
||||||
body = rb_block_dup(fbody->nd_cval, data->klass, data->cref);
|
nbody = rb_block_dup(fbody->nd_cval, nklass, (VALUE)cref);
|
||||||
fbody = NEW_BMETHOD(body);
|
fbody = NEW_BMETHOD(nbody);
|
||||||
break;
|
break;
|
||||||
case NODE_DMETHOD:
|
case NODE_DMETHOD:
|
||||||
body = rb_method_dup(fbody->nd_cval, data->klass, data->cref);
|
nbody = rb_method_dup(fbody->nd_cval, nklass, (VALUE)cref);
|
||||||
fbody = NEW_DMETHOD(body);
|
fbody = NEW_DMETHOD(nbody);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
st_insert(data->tbl, mid, (st_data_t)NEW_METHOD(fbody, body->nd_noex));
|
st_insert(RCLASS(nklass)->m_tbl, mid, (st_data_t)NEW_METHOD(fbody, body->nd_noex));
|
||||||
return ST_CONTINUE;
|
return ST_CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,13 +100,8 @@ rb_mod_init_copy(clone, orig)
|
||||||
st_delete(RCLASS(clone)->iv_tbl, (st_data_t*)&id, 0);
|
st_delete(RCLASS(clone)->iv_tbl, (st_data_t*)&id, 0);
|
||||||
}
|
}
|
||||||
if (RCLASS(orig)->m_tbl) {
|
if (RCLASS(orig)->m_tbl) {
|
||||||
struct clone_method_data data;
|
|
||||||
|
|
||||||
RCLASS(clone)->m_tbl = st_init_numtable();
|
RCLASS(clone)->m_tbl = st_init_numtable();
|
||||||
data.tbl = RCLASS(clone)->m_tbl;
|
st_foreach(RCLASS(orig)->m_tbl, clone_method, clone);
|
||||||
data.klass = clone;
|
|
||||||
data.cref = clone;
|
|
||||||
st_foreach(RCLASS(orig)->m_tbl, clone_method, (st_data_t)&data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return clone;
|
return clone;
|
||||||
|
@ -136,15 +122,14 @@ rb_class_init_copy(clone, orig)
|
||||||
}
|
}
|
||||||
|
|
||||||
static VALUE
|
static VALUE
|
||||||
singleton_class_clone_int(obj, cref)
|
singleton_class_clone_int(obj, nklass)
|
||||||
VALUE obj, cref;
|
VALUE obj, nklass;
|
||||||
{
|
{
|
||||||
VALUE klass = RBASIC(obj)->klass;
|
VALUE klass = RBASIC(obj)->klass;
|
||||||
|
|
||||||
if (!FL_TEST(klass, FL_SINGLETON))
|
if (!FL_TEST(klass, FL_SINGLETON))
|
||||||
return klass;
|
return klass;
|
||||||
else {
|
else {
|
||||||
struct clone_method_data data;
|
|
||||||
/* copy singleton(unnamed) class */
|
/* copy singleton(unnamed) class */
|
||||||
NEWOBJ(clone, struct RClass);
|
NEWOBJ(clone, struct RClass);
|
||||||
OBJSETUP(clone, 0, RBASIC(klass)->flags);
|
OBJSETUP(clone, 0, RBASIC(klass)->flags);
|
||||||
|
@ -163,10 +148,7 @@ singleton_class_clone_int(obj, cref)
|
||||||
clone->iv_tbl = st_copy(RCLASS(klass)->iv_tbl);
|
clone->iv_tbl = st_copy(RCLASS(klass)->iv_tbl);
|
||||||
}
|
}
|
||||||
clone->m_tbl = st_init_numtable();
|
clone->m_tbl = st_init_numtable();
|
||||||
data.tbl = clone->m_tbl;
|
st_foreach(RCLASS(klass)->m_tbl, clone_method, NIL_P(nklass) ? (VALUE)clone : nklass);
|
||||||
data.klass = (VALUE)clone;
|
|
||||||
data.cref = cref;
|
|
||||||
st_foreach(RCLASS(klass)->m_tbl, clone_method, (st_data_t)&data);
|
|
||||||
rb_singleton_class_attached(RBASIC(clone)->klass, (VALUE)clone);
|
rb_singleton_class_attached(RBASIC(clone)->klass, (VALUE)clone);
|
||||||
FL_SET(clone, FL_SINGLETON);
|
FL_SET(clone, FL_SINGLETON);
|
||||||
return (VALUE)clone;
|
return (VALUE)clone;
|
||||||
|
@ -177,7 +159,7 @@ VALUE
|
||||||
rb_singleton_class_clone(obj)
|
rb_singleton_class_clone(obj)
|
||||||
VALUE obj;
|
VALUE obj;
|
||||||
{
|
{
|
||||||
return singleton_class_clone_int(obj, 0);
|
return singleton_class_clone_int(obj, Qnil);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
8
eval.c
8
eval.c
|
@ -2242,8 +2242,8 @@ rb_mod_alias_method(mod, newname, oldname)
|
||||||
return mod;
|
return mod;
|
||||||
}
|
}
|
||||||
|
|
||||||
static NODE*
|
NODE *
|
||||||
copy_node_scope(node, rval)
|
rb_copy_node_scope(node, rval)
|
||||||
NODE *node;
|
NODE *node;
|
||||||
NODE *rval;
|
NODE *rval;
|
||||||
{
|
{
|
||||||
|
@ -3955,7 +3955,7 @@ rb_eval(self, n)
|
||||||
noex |= NOEX_NOSUPER;
|
noex |= NOEX_NOSUPER;
|
||||||
}
|
}
|
||||||
|
|
||||||
defn = copy_node_scope(node->nd_defn, ruby_cref);
|
defn = rb_copy_node_scope(node->nd_defn, ruby_cref);
|
||||||
rb_add_method(ruby_class, node->nd_mid, defn, noex);
|
rb_add_method(ruby_class, node->nd_mid, defn, noex);
|
||||||
if (scope_vmode == SCOPE_MODFUNC) {
|
if (scope_vmode == SCOPE_MODFUNC) {
|
||||||
rb_add_method(rb_singleton_class(ruby_class),
|
rb_add_method(rb_singleton_class(ruby_class),
|
||||||
|
@ -3992,7 +3992,7 @@ rb_eval(self, n)
|
||||||
rb_warning("redefine %s", rb_id2name(node->nd_mid));
|
rb_warning("redefine %s", rb_id2name(node->nd_mid));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
defn = copy_node_scope(node->nd_defn, ruby_cref);
|
defn = rb_copy_node_scope(node->nd_defn, ruby_cref);
|
||||||
rb_add_method(klass, node->nd_mid, defn,
|
rb_add_method(klass, node->nd_mid, defn,
|
||||||
NOEX_PUBLIC|(body?body->nd_noex&NOEX_UNDEF:0));
|
NOEX_PUBLIC|(body?body->nd_noex&NOEX_UNDEF:0));
|
||||||
result = Qnil;
|
result = Qnil;
|
||||||
|
|
1
node.h
1
node.h
|
@ -371,6 +371,7 @@ typedef unsigned int rb_event_t;
|
||||||
#define RUBY_EVENT_ALL 0xff
|
#define RUBY_EVENT_ALL 0xff
|
||||||
|
|
||||||
typedef void (*rb_event_hook_func_t) _((rb_event_t,NODE*,VALUE,ID,VALUE));
|
typedef void (*rb_event_hook_func_t) _((rb_event_t,NODE*,VALUE,ID,VALUE));
|
||||||
|
NODE *rb_copy_node_scope _((NODE *, NODE *));
|
||||||
void rb_add_event_hook _((rb_event_hook_func_t,rb_event_t));
|
void rb_add_event_hook _((rb_event_hook_func_t,rb_event_t));
|
||||||
int rb_remove_event_hook _((rb_event_hook_func_t));
|
int rb_remove_event_hook _((rb_event_hook_func_t));
|
||||||
|
|
||||||
|
|
3
parse.y
3
parse.y
|
@ -5736,7 +5736,7 @@ top_local_setup()
|
||||||
rb_mem_clear(vars+i, len-i);
|
rb_mem_clear(vars+i, len-i);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
*vars++ = (VALUE)ruby_scope;
|
*vars++ = 0;
|
||||||
rb_mem_clear(vars, len);
|
rb_mem_clear(vars, len);
|
||||||
}
|
}
|
||||||
ruby_scope->local_vars = vars;
|
ruby_scope->local_vars = vars;
|
||||||
|
@ -5752,6 +5752,7 @@ top_local_setup()
|
||||||
if (!(ruby_scope->flags & SCOPE_CLONE))
|
if (!(ruby_scope->flags & SCOPE_CLONE))
|
||||||
xfree(ruby_scope->local_tbl);
|
xfree(ruby_scope->local_tbl);
|
||||||
}
|
}
|
||||||
|
ruby_scope->local_vars[-1] = 0; /* no reference needed */
|
||||||
ruby_scope->local_tbl = local_tbl();
|
ruby_scope->local_tbl = local_tbl();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -717,6 +717,20 @@ class TestArray < Test::Unit::TestCase
|
||||||
@cls[@cls[@cls[@cls[],@cls[]],@cls[@cls[]],@cls[]],@cls[@cls[@cls[]]]].flatten)
|
@cls[@cls[@cls[@cls[],@cls[]],@cls[@cls[]],@cls[]],@cls[@cls[@cls[]]]].flatten)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_flatten_with_callcc
|
||||||
|
respond_to?(:callcc, true) or require 'continuation'
|
||||||
|
o = Object.new
|
||||||
|
def o.to_ary() callcc {|k| @cont = k; [1,2,3]} end
|
||||||
|
begin
|
||||||
|
assert_equal([10, 20, 1, 2, 3, 30, 1, 2, 3, 40], [10, 20, o, 30, o, 40].flatten)
|
||||||
|
rescue => e
|
||||||
|
else
|
||||||
|
o.instance_eval {@cont}.call
|
||||||
|
end
|
||||||
|
assert_instance_of(RuntimeError, e, '[ruby-dev:34798]')
|
||||||
|
assert_match(/reentered/, e.message, '[ruby-dev:34798]')
|
||||||
|
end
|
||||||
|
|
||||||
def test_hash
|
def test_hash
|
||||||
a1 = @cls[ 'cat', 'dog' ]
|
a1 = @cls[ 'cat', 'dog' ]
|
||||||
a2 = @cls[ 'cat', 'dog' ]
|
a2 = @cls[ 'cat', 'dog' ]
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#define RUBY_VERSION "1.8.7"
|
#define RUBY_VERSION "1.8.7"
|
||||||
#define RUBY_RELEASE_DATE "2008-05-22"
|
#define RUBY_RELEASE_DATE "2008-05-23"
|
||||||
#define RUBY_VERSION_CODE 187
|
#define RUBY_VERSION_CODE 187
|
||||||
#define RUBY_RELEASE_CODE 20080522
|
#define RUBY_RELEASE_CODE 20080523
|
||||||
#define RUBY_PATCHLEVEL 0
|
#define RUBY_PATCHLEVEL 0
|
||||||
|
|
||||||
#define RUBY_VERSION_MAJOR 1
|
#define RUBY_VERSION_MAJOR 1
|
||||||
|
@ -9,7 +9,7 @@
|
||||||
#define RUBY_VERSION_TEENY 7
|
#define RUBY_VERSION_TEENY 7
|
||||||
#define RUBY_RELEASE_YEAR 2008
|
#define RUBY_RELEASE_YEAR 2008
|
||||||
#define RUBY_RELEASE_MONTH 5
|
#define RUBY_RELEASE_MONTH 5
|
||||||
#define RUBY_RELEASE_DAY 22
|
#define RUBY_RELEASE_DAY 23
|
||||||
|
|
||||||
#ifdef RUBY_EXTERN
|
#ifdef RUBY_EXTERN
|
||||||
RUBY_EXTERN const char ruby_version[];
|
RUBY_EXTERN const char ruby_version[];
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue