class UncaughtThrowError
Wird ausgelöst, wenn throw mit einem Tag aufgerufen wird, dem kein entsprechender catch-Block zugeordnet ist.
throw "foo", "bar"
löst die Ausnahme aus
UncaughtThrowError: uncaught throw "foo"
Öffentliche Klassenmethoden
Source
static VALUE
uncaught_throw_init(int argc, const VALUE *argv, VALUE exc)
{
rb_check_arity(argc, 2, UNLIMITED_ARGUMENTS);
rb_call_super(argc - 2, argv + 2);
rb_ivar_set(exc, id_tag, argv[0]);
rb_ivar_set(exc, id_value, argv[1]);
return exc;
}
Document-class: UncaughtThrowError
Wird ausgelöst, wenn throw mit einem Tag aufgerufen wird, dem kein entsprechender catch-Block zugeordnet ist.
throw "foo", "bar"
löst die Ausnahme aus
UncaughtThrowError: uncaught throw "foo"
Öffentliche Instanzmethoden
Source
static VALUE
uncaught_throw_tag(VALUE exc)
{
return rb_ivar_get(exc, id_tag);
}
Gibt das angeforderte Tag-Objekt zurück.
Source
static VALUE
uncaught_throw_to_s(VALUE exc)
{
VALUE mesg = rb_attr_get(exc, id_mesg);
VALUE tag = uncaught_throw_tag(exc);
return rb_str_format(1, &tag, mesg);
}
Gibt eine formatierte Nachricht mit dem inspizierten Tag zurück.
Source
static VALUE
uncaught_throw_value(VALUE exc)
{
return rb_ivar_get(exc, id_value);
}
Gibt den angeforderten Rückgabewert zurück.