Skip to content

Commit

Permalink
proc.c: include symbol name
Browse files Browse the repository at this point in the history
* proc.c (proc_to_s): include the original symbol name in string
  form.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@51988 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
nobu committed Sep 30, 2015
1 parent c2310ba commit 66296d3
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 3 deletions.
1 change: 1 addition & 0 deletions internal.h
Expand Up @@ -1109,6 +1109,7 @@ VALUE rb_external_str_with_enc(VALUE str, rb_encoding *eenc);
#define is_ascii_string(str) (rb_enc_str_coderange(str) == ENC_CODERANGE_7BIT)
#define is_broken_string(str) (rb_enc_str_coderange(str) == ENC_CODERANGE_BROKEN)
size_t rb_str_memsize(VALUE);
VALUE rb_sym_proc_call(VALUE args, VALUE sym, int argc, VALUE *argv, VALUE passed_proc);

/* struct.c */
VALUE rb_struct_init_copy(VALUE copy, VALUE s);
Expand Down
5 changes: 5 additions & 0 deletions proc.c
Expand Up @@ -1059,6 +1059,7 @@ proc_to_s(VALUE self)
const char *cname = rb_obj_classname(self);
const rb_iseq_t *iseq;
const char *is_lambda;
const struct vm_ifunc *ifunc;

GetProcPtr(self, proc);
iseq = proc->block.iseq;
Expand All @@ -1073,6 +1074,10 @@ proc_to_s(VALUE self)
str = rb_sprintf("#<%s:%p@%"PRIsVALUE":%d%s>", cname, (void *)self,
iseq->body->location.path, first_lineno, is_lambda);
}
else if ((ifunc = (struct vm_ifunc *)iseq)->func == rb_sym_proc_call) {
str = rb_sprintf("#<%s:%p(&%+"PRIsVALUE")%s>", cname, (void *)self,
ID2SYM((ID)ifunc->data), is_lambda);
}
else {
str = rb_sprintf("#<%s:%p%s>", cname, (void *)proc->block.iseq,
is_lambda);
Expand Down
6 changes: 3 additions & 3 deletions string.c
Expand Up @@ -8915,8 +8915,8 @@ sym_to_sym(VALUE sym)
return sym;
}

static VALUE
sym_call(VALUE args, VALUE sym, int argc, VALUE *argv, VALUE passed_proc)
VALUE
rb_sym_proc_call(VALUE args, VALUE sym, int argc, VALUE *argv, VALUE passed_proc)
{
VALUE obj;

Expand Down Expand Up @@ -8959,7 +8959,7 @@ sym_to_proc(VALUE sym)
return aryp[index + 1];
}
else {
proc = rb_proc_new(sym_call, (VALUE)id);
proc = rb_proc_new(rb_sym_proc_call, (VALUE)id);
rb_block_clear_env_self(proc);
aryp[index] = sym;
aryp[index + 1] = proc;
Expand Down

0 comments on commit 66296d3

Please sign in to comment.