summaryrefslogtreecommitdiff
path: root/struct.c
diff options
context:
space:
mode:
authork0kubun <k0kubun@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-12-12 15:03:45 +0000
committerk0kubun <k0kubun@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-12-12 15:03:45 +0000
commit8411f58ed70c1e6dc4e35589c94fd231c4e384d2 (patch)
tree88b3a8e1b77e3bbf916d1758c8656b587fb3a013 /struct.c
parent1dcdb868765c88af741772223702cb98d97c6b2c (diff)
downloadruby-8411f58ed70c1e6dc4e35589c94fd231c4e384d2.tar.gz
struct.c: show `keyword_init: true` on inspect
for debugging if it's specified for the Struct class. This follows up r61137. We don't provide a method to check it because I don't think of any use case, but showing this to inspect would be helpful for debugging if someone is debugging whether keyword_init is properly enabled or not. In this commit, I didn't show `keyword_init: false` because of backward compatibility. Ideally any application should not depend on the behavior of inspect, but I don't have strong motivation to break it too. [close GH-1773] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@61181 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'struct.c')
-rw-r--r--struct.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/struct.c b/struct.c
index 056fd29ae8..e025228828 100644
--- a/struct.c
+++ b/struct.c
@@ -295,6 +295,16 @@ define_aset_method(VALUE nstr, VALUE name, VALUE off)
}
static VALUE
+rb_struct_s_inspect(VALUE klass)
+{
+ VALUE inspect = rb_class_name(klass);
+ if (RTEST(struct_ivar_get(klass, id_keyword_init))) {
+ rb_str_cat_cstr(inspect, "(keyword_init: true)");
+ }
+ return inspect;
+}
+
+static VALUE
setup_struct(VALUE nstr, VALUE members)
{
const VALUE *ptr_members;
@@ -306,6 +316,7 @@ setup_struct(VALUE nstr, VALUE members)
rb_define_singleton_method(nstr, "new", rb_class_new_instance, -1);
rb_define_singleton_method(nstr, "[]", rb_class_new_instance, -1);
rb_define_singleton_method(nstr, "members", rb_struct_s_members_m, 0);
+ rb_define_singleton_method(nstr, "inspect", rb_struct_s_inspect, 0);
ptr_members = RARRAY_CONST_PTR(members);
len = RARRAY_LEN(members);
for (i=0; i< len; i++) {