الصنف Exception في روبي
تُستخدَم الكائنات السليلة من الصنف Exception للتواصل بين التّابع Kernel.raise وتصريحات rescue في الكتل (blocks) من الشكل begin...end. تَحمل كائنات الصنف Exception معلوماتٍ عن الاستثناء المَرمي مثل نوعه (اسم صنف الاستثناء)، وسلسلةً نصيّةً وصفيّةً اختياريّة، ومعلوماتِ تتبّعٍ اختيارية. قد تضيف الأصناف الفرعية من الصنف Exception معلوماتٍ إضافيّةٍ مثل NameError.name.
قد تُنشِئ البرامج أصنافًا فرعيّةً (subclasses) من الصنف Exception، تكون عادةً StandardError أو RuntimeError، لتوفير أصنافٍ مخصصّةٍ وإضافة معلوماتٍ إضافية. ألقِ نظرةً على قائمة الأصناف الفرعية في الأسفل من أجل قيم raise و rescue الافتراضية .
عندما يُرمى استثناءٌ ولكن لم يُتعامل معه بعد (في الكتل rescue، و ensure، و at_exit، و END)، يحتوي المتغيّر العام $! على الاستثناء الحالي، بينما يحتوي $@على مصفوفة التتبع المعاكس (backtrace) للاستثناء الحالي.
يُستحسن أن تمتلك المكتبة صنفًا فرعيًّا واحدًا إما StandardError أو RuntimeError وأن تمتلك أنواع استثناءات محددة ترث منه . هذا يسمح للمستخدم بإنقاذ الاستثناء ذي النوع العام (generic exception) وبالتالي إمساك (catch) كل الاستثناءات التي قد ترميها المكتبة حتى إذا أضافت الإصدارات المستقبلية للمكتبة أصنافًا فرعيّةً جديدةً للصنف Exception.
ألقٍ نظرة على المثال التالي:
class MyLibrary
class Error < RuntimeError
end
class WidgetError < Error
end
class FrobError < Error
end
end
للتعامل مع الصنفين الفرعيِّين WidgetError و FrobError يمكن لمستخدم المكتبة تنفيذ rescue على MyLibrary::Error.
الأصناف الفرعيّة المضمّنة في الصنف Exception هي:
NoMemoryErrorScriptErrorLoadErrorNotImplementedErrorSyntaxError
SecurityErrorSignalExceptionInterrupt
StandardError – default for rescueArgumentErrorUncaughtThrowError
EncodingErrorFiberErrorIOErrorEOFError
IndexErrorKeyErrorStopIteration
LocalJumpErrorNameErrorNoMethodError
RangeErrorFloatDomainError
RegexpErrorRuntimeError – default for raiseFrozenError
SystemCallErrorErrno::*
ThreadErrorTypeErrorZeroDivisionError
SystemExitSystemStackErrorfatal – impossible to rescue
توابع الصنف العامة (Public Class Methods)
exception
يُعيد المُستقبل (receiver) إن لم يمرَّر إليه أي وسيط، أو إذا كان الوسيط الممرر إليه هو نفسه المُستقبل. خلاف ذلك، يُنشئ كائن استثناءٍ جديد (exception object) من الصنف نفسه على أنّه المستقبل، ولكن مع رسالةٍ مساوية إلى string.to_str.
new
يُنشئ كائنًا جديدًا من النّوع Exception، ويمرِّر رسالةً اختياريًّا إليه.
?to_tty
يتحقّق فيما إذا كانت رسائل الاستثناء ستُرسل إلى الطرفية tty.
توابع الكائن العامة (Public Instance Methods)
==
يتحقق من تساوي كائني استثناء مع بعضهما بعضًا.
backtrace
يُعيد أيَّ تتبّعٍ عكسيٍّ (backtrace) مرتبطٍ بالاستثناء.
backtrace_locations
يُعيد أي تتبع عكسي (backtrace) مرتبط بالاستثناء. هذا التّابع شبيه للتّابع backtrace، ولكن backtrace هو مصفوفة من Thread::Backtrace::Location.
cause
يُعيد الاستثناء السابق (!$) عندما يُرمى هذا الاستثناء.
exception
يُعيد المُستقبل (receiver) إن لم يمرَّر إليه أي وسيط، أو إذا كان الوسيط الممرر إليه هو نفسه المُستقبل. خلاف ذلك، يُنشئ كائن استثناءٍ جديد (exception object) من الصنف نفسه على أنّه المستقبل، ولكن مع رسالةٍ مساوية إلى string.to_str.
full_message
يُعيد سلسلةً نصيةً منسّقةً من الاستثناء.
inspect
يُعيد اسم صنف الاستثناء ورسالته.
message
يُعيد ناتج استدعاء التّابع exception.to_s. ويُعيد هذا عادةً رسالة الاستثناء أو اسمه.
set_backtrace
يضبط معلومات المصفوفة backtrace الخاصة بكائن الاستثناء.
to_s
يُعيد رسالة الاستثناء (أو اسم الاستثناء إذا لم يتم تعيين أي رسالة).