Exception: NoMethodError
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
|
|
Instance Chain:
|
|
Inherits: |
NameError
|
Defined in: | error.c, error.c |
Overview
Raised when a method is called on a receiver which doesn’t have it defined and also fails to respond with method_missing
.
"hello".to_ary
raises the exception:
NoMethodError: undefined method `to_ary' for an instance of String
Class Attribute Summary
::Exception
- Inherited
.to_tty? | Returns |
Class Method Summary
-
.new(msg = nil, name = nil, args = nil, private = false, receiver: nil) ⇒ no_method_error
constructor
Construct a
NoMethodError
exception for a method of the given name called with the given arguments.
::NameError
- Inherited
.new | Construct a new |
::Exception
- Inherited
.exception | Returns an exception object of the same class as |
.new | Returns a new exception object. |
Instance Attribute Summary
-
#private_call? ⇒ Boolean
readonly
Return true if the caused method was called as private.
Instance Method Summary
-
#args ⇒ Object
Return the arguments passed in as the third parameter to the constructor.
::NameError
- Inherited
#local_variables | Return a list of the local variable names defined where this |
#name | Return the name associated with this |
#receiver | Return the receiver associated with this |
::Exception
- Inherited
#== | Returns whether |
#backtrace | Returns the backtrace (the list of code locations that led to the exception), as an array of strings. |
#backtrace_locations | Returns the backtrace (the list of code locations that led to the exception), as an array of |
#cause | Returns the previous value of global variable |
#detailed_message | Returns the message string with enhancements: |
#exception | Returns an exception object of the same class as |
#full_message | Returns an enhanced message string: |
#inspect | Returns a string representation of |
#message | Returns |
#set_backtrace | Sets the backtrace value for |
#to_s | Returns a string representation of |
Constructor Details
.new(msg = nil, name = nil, args = nil, private = false, receiver: nil) ⇒ no_method_error
Construct a NoMethodError
exception for a method of the given name called with the given arguments. The name may be accessed using the #name
method on the resulting object, and the arguments using the #args method.
If private argument were passed, it designates method was attempted to call in private context, and can be accessed with #private_call? method.
receiver argument stores an object whose method was called.
# File 'error.c', line 2492
static VALUE nometh_err_initialize(int argc, VALUE *argv, VALUE self) { int priv; VALUE args, options; argc = rb_scan_args(argc, argv, "*:", NULL, &options); priv = (argc > 3) && (--argc, RTEST(argv[argc])); args = (argc > 2) ? argv[--argc] : Qnil; if (!NIL_P(options)) argv[argc++] = options; rb_call_super_kw(argc, argv, RB_PASS_CALLED_KEYWORDS); return nometh_err_init_attr(self, args, priv); }
Instance Attribute Details
#private_call? ⇒ Boolean
(readonly)
Return true if the caused method was called as private.
# File 'error.c', line 2776
static VALUE nometh_err_private_call_p(VALUE self) { return rb_attr_get(self, id_private_call_p); }
Instance Method Details
#args ⇒ Object
Return the arguments passed in as the third parameter to the constructor.
# File 'error.c', line 2763
static VALUE nometh_err_args(VALUE self) { return rb_attr_get(self, id_args); }