الفرق بين المراجعتين لصفحة: «Ruby/TracePoint/defined class»
< Ruby | TracePoint
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع <code>defined_class</code> الخاص بالصنف <code>TracePoint</code> في روبي}}</noinclude> تصنيف: Ruby...' |
جميل-بيلوني (نقاش | مساهمات) ط مراجعة وتدقيق. |
||
(مراجعة متوسطة واحدة بواسطة مستخدم واحد آخر غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE: التابع <code>defined_class | <noinclude>{{DISPLAYTITLE: التابع <code>TracePoint.defined_class</code> في روبي}}</noinclude> | ||
[[تصنيف: Ruby]] | [[تصنيف: Ruby]] | ||
[[تصنيف: Ruby Method]] | [[تصنيف: Ruby Method]] | ||
[[تصنيف: Ruby TracePoint]] | [[تصنيف: Ruby TracePoint]] | ||
يُعيد التابع <code>defined_class</code> صنف أو وحدة التابع | يُعيد التابع <code>defined_class</code> صنف أو وحدة التابع المُستدعى.<syntaxhighlight lang="ruby">class C; def foo; end; end | ||
trace = TracePoint.new(:call) do |tp| | |||
p tp.defined_class #=> C | |||
end.enable do | |||
C.new.foo | |||
end</syntaxhighlight>إذا تم تعريف التابع بواسطة وحدة، فستعاد تلك الوحدة.<syntaxhighlight lang="ruby">module M; def foo; end; end | |||
class C; include M; end; | |||
trace = TracePoint.new(:call) do |tp| | |||
p tp.defined_class #=> M | |||
end.enable do | |||
C.new.foo | |||
end</syntaxhighlight>'''ملحوظة''': يُعيد التابع <code>defined_class</code> صنفًا مفردًا (singleton class). | |||
وسيط الكتلة السادس في التابع <code>[[Ruby/Kernel/set_trace_func|Kernel.set_trace_func]]</code> يُمرَّر الصنف الأصليً (original class) للكائن عبر الصنف المفرد. هذا أحد الفوارق بين <code>[[Ruby/Kernel/set_trace_func|Kernel.set_trace_func]]</code> و <code>[[Ruby/TracePoint|TracePoint]]</code>. | |||
==البنية العامة== | |||
<syntaxhighlight lang="ruby">defined_class()</syntaxhighlight> | |||
==القيمة المعادة== | |||
يعاد صنف أو وحدة التابع المُستدعى. | |||
==أمثلة== | ==أمثلة== | ||
مثال على استخدام التابع <code>defined_class</code>: | مثال على استخدام التابع <code>defined_class</code>: | ||
<syntaxhighlight lang="ruby">class C; def foo; end; end | <syntaxhighlight lang="ruby">class C; def self.foo; end; end | ||
trace = TracePoint.new(:call) do |tp| | trace = TracePoint.new(:call) do |tp| | ||
p tp.defined_class #=> C | p tp.defined_class #=> #<Class:C> | ||
end.enable do | end.enable do | ||
C | C.foo | ||
end</syntaxhighlight> | |||
==انظر | ==انظر أيضًا== | ||
* التابع <code>[[Ruby/TracePoint/callee_id|callee_id]]</code>: يُعيد | * التابع <code>[[Ruby/TracePoint/callee_id|callee_id]]</code>: يُعيد اسم الاستدعاء الخاص بالتابع الذي يتم استدعاؤه. | ||
==مصادر== | ==مصادر== | ||
*[http://ruby-doc.org/core-2.5.1/TracePoint.html#method-i-defined_class قسم | *[http://ruby-doc.org/core-2.5.1/TracePoint.html#method-i-defined_class قسم التابع defined_class في الصنف TracePoint في توثيق روبي الرسمي.] |
المراجعة الحالية بتاريخ 05:42، 8 ديسمبر 2018
يُعيد التابع defined_class
صنف أو وحدة التابع المُستدعى.
class C; def foo; end; end
trace = TracePoint.new(:call) do |tp|
p tp.defined_class #=> C
end.enable do
C.new.foo
end
إذا تم تعريف التابع بواسطة وحدة، فستعاد تلك الوحدة.
module M; def foo; end; end
class C; include M; end;
trace = TracePoint.new(:call) do |tp|
p tp.defined_class #=> M
end.enable do
C.new.foo
end
ملحوظة: يُعيد التابع defined_class
صنفًا مفردًا (singleton class).
وسيط الكتلة السادس في التابع Kernel.set_trace_func
يُمرَّر الصنف الأصليً (original class) للكائن عبر الصنف المفرد. هذا أحد الفوارق بين Kernel.set_trace_func
و TracePoint
.
البنية العامة
defined_class()
القيمة المعادة
يعاد صنف أو وحدة التابع المُستدعى.
أمثلة
مثال على استخدام التابع defined_class
:
class C; def self.foo; end; end
trace = TracePoint.new(:call) do |tp|
p tp.defined_class #=> #<Class:C>
end.enable do
C.foo
end
انظر أيضًا
- التابع
callee_id
: يُعيد اسم الاستدعاء الخاص بالتابع الذي يتم استدعاؤه.