summaryrefslogtreecommitdiff
path: root/struct.c
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-07-07 03:47:31 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-07-07 03:47:31 +0000
commit8d8c42770ca5e5b147ab6de767dccfff82713b2d (patch)
tree423d2872cd14c7bfe8ffe551280f0c487705811e /struct.c
parentea5adc4c3901bfa801bad71134f282f0151cfb33 (diff)
merge revision(s) 45462,45463,45466: [Backport #9684]
* struct.c (not_a_member): extract name error and use same error messages. based on the patch by Marcus Stollsteimer <sto.mar AT web.de> at [ruby-core:61721]. [Bug #9684] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@46741 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'struct.c')
-rw-r--r--struct.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/struct.c b/struct.c
index 9f2155aeee..7af7944c9d 100644
--- a/struct.c
+++ b/struct.c
@@ -87,6 +87,13 @@ rb_struct_members_m(VALUE obj)
return rb_struct_s_members_m(rb_obj_class(obj));
}
+NORETURN(static void not_a_member(ID id));
+static void
+not_a_member(ID id)
+{
+ rb_name_error(id, "`%"PRIsVALUE"' is not a struct member", QUOTE_ID(id));
+}
+
VALUE
rb_struct_getmember(VALUE obj, ID id)
{
@@ -103,7 +110,7 @@ rb_struct_getmember(VALUE obj, ID id)
return ptr[i];
}
}
- rb_name_error(id, "%s is not struct member", rb_id2name(id));
+ not_a_member(id);
UNREACHABLE;
}
@@ -153,6 +160,7 @@ rb_struct_set(VALUE obj, VALUE val)
{
VALUE members, slot, *ptr, *ptr_members;
long i, len;
+ ID fid = rb_frame_this_func();
members = rb_struct_members(obj);
ptr_members = RARRAY_PTR(members);
@@ -161,12 +169,11 @@ rb_struct_set(VALUE obj, VALUE val)
ptr = RSTRUCT_PTR(obj);
for (i=0; i<len; i++) {
slot = ptr_members[i];
- if (rb_id_attrset(SYM2ID(slot)) == rb_frame_this_func()) {
+ if (rb_id_attrset(SYM2ID(slot)) == fid) {
return ptr[i] = val;
}
}
- rb_name_error(rb_frame_this_func(), "`%s' is not a struct member",
- rb_id2name(rb_frame_this_func()));
+ not_a_member(fid);
UNREACHABLE;
}