From 0e744c3291e83874c2e4845c80f8cc8e6134a338 Mon Sep 17 00:00:00 2001 From: nobu Date: Thu, 18 Jun 2015 04:32:50 +0000 Subject: error.c: NameError#receiver * error.c (name_err_receiver): add NameError#receiver method. [Feature #10881] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@50945 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- error.c | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'error.c') diff --git a/error.c b/error.c index 07b04a1036..602ee401c7 100644 --- a/error.c +++ b/error.c @@ -1247,6 +1247,22 @@ name_err_mesg_load(VALUE klass, VALUE str) return str; } +/* + * call-seq: + * name_error.receiver -> object + * + * Return the receiver associated with this NameError exception. + */ + +static VALUE +name_err_receiver(VALUE self) +{ + VALUE *ptr, mesg = rb_attr_get(self, id_mesg); + + TypedData_Get_Struct(mesg, VALUE, &name_err_mesg_data_type, ptr); + return ptr[1]; +} + /* * call-seq: * no_method_error.args -> obj @@ -1878,6 +1894,7 @@ Init_Exception(void) rb_eNameError = rb_define_class("NameError", rb_eStandardError); rb_define_method(rb_eNameError, "initialize", name_err_initialize, -1); rb_define_method(rb_eNameError, "name", name_err_name, 0); + rb_define_method(rb_eNameError, "receiver", name_err_receiver, 0); rb_cNameErrorMesg = rb_define_class_under(rb_eNameError, "message", rb_cData); rb_define_singleton_method(rb_cNameErrorMesg, "!", rb_name_err_mesg_new, NAME_ERR_MESG_COUNT); rb_define_method(rb_cNameErrorMesg, "==", name_err_mesg_equal, 1); -- cgit v1.2.3