الفرق بين المراجعتين ل"Ruby/Symbol/casecmp"
اذهب إلى التنقل
اذهب إلى البحث
(أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: التابع <code>casecmp</code> الخاص بالصنف <code>Symbol</code> في روبي}}</noinclude> تصنيف: Ruby تصن...') |
جميل-بيلوني (نقاش | مساهمات) ط (مراجعة وتدقيق.) |
||
(مراجعة متوسطة واحدة بواسطة مستخدم واحد آخر غير معروضة) | |||
سطر 1: | سطر 1: | ||
− | <noinclude>{{DISPLAYTITLE: التابع <code>casecmp | + | <noinclude>{{DISPLAYTITLE: التابع <code>Symbol.casecmp</code> في روبي}}</noinclude> |
[[تصنيف: Ruby]] | [[تصنيف: Ruby]] | ||
[[تصنيف: Ruby Method]] | [[تصنيف: Ruby Method]] | ||
[[تصنيف: Ruby Symbol]] | [[تصنيف: Ruby Symbol]] | ||
− | التابع <code>casecmp</code> هو نسخة غير حساسة لحالة الأحرف | + | يقارن التابع <code>casecmp</code> بين رمزين بشكل غير حساس لحالة الأحرف. هذا التابع هو نسخة غير حساسة لحالة الأحرف (Case-insensitive) من المعامل <code>[[Ruby/Symbol/compar operator|<=>]]</code>. في الوقت الحالي، لا تعمل الحساسية لحالة الأحرف إلا على الأحرف <code>A-Z/a-z</code>، وليس على كل محارف اليونيكود. هذا السلوك مختلف عن التابع <code>[[Ruby/Symbol/casecmp-3F|casecmp?]]</code>. |
− | |||
− | |||
− | |||
− | |||
==البنية العامة== | ==البنية العامة== | ||
<syntaxhighlight lang="ruby">casecmp(other_symbol)→ -1, 0, +1, or nil</syntaxhighlight> | <syntaxhighlight lang="ruby">casecmp(other_symbol)→ -1, 0, +1, or nil</syntaxhighlight> | ||
==المعاملات== | ==المعاملات== | ||
===<code>other_symbol</code>=== | ===<code>other_symbol</code>=== | ||
− | ==القيمة | + | الرمز المراد التحقق من مقارنته مع الرمز المعطى. |
+ | |||
+ | ==القيمة المعادة== | ||
+ | تعاد القيمة <code>-1</code> أو <code>0</code> أو <code>+1</code> أو بناءً على ما إذا كان الرمز أصغر من أو يساوي أو أكبر من <code>other_symbol</code>. أو تُعاد القيمة <code>nil</code> إذا كان لل[[Ruby/Symbol|رمزين]] ترميزات غير متوافقة، أو إن لم يكن <code>other_symbol</code> [[Ruby/Symbol|رمزً]]ا. | ||
+ | |||
==أمثلة== | ==أمثلة== | ||
− | مثال على استخدام التابع <code>casecmp</code>: | + | مثال على استخدام التابع <code>casecmp</code>:<syntaxhighlight lang="ruby">:aBcDeF.casecmp(:abcde) #=> 1 |
− | <syntaxhighlight lang="ruby">:aBcDeF.casecmp(:abcde) #=> 1 | ||
:aBcDeF.casecmp(:abcdef) #=> 0 | :aBcDeF.casecmp(:abcdef) #=> 0 | ||
:aBcDeF.casecmp(:abcdefg) #=> -1 | :aBcDeF.casecmp(:abcdefg) #=> -1 | ||
− | :abcdef.casecmp(:ABCDEF) #=> 0</syntaxhighlight> | + | :abcdef.casecmp(:ABCDEF) #=> 0 |
− | ==انظر | + | |
− | * التابع <code>[[Ruby/Symbol/capitalize|capitalize]]</code>: | + | :foo.casecmp(2) #=> nil |
− | * التابع <code>[[Ruby/Symbol/casecmp-3F|casecmp?]]</code>: | + | "\u{e4 f6 fc}".encode("ISO-8859-1").to_sym.casecmp(:"\u{c4 d6 dc}") #=> nil</syntaxhighlight> |
+ | ==انظر أيضًا== | ||
+ | *التابع <code>[[Ruby/Symbol/capitalize|capitalize]]</code>: يشبه التعبير <code>sym.to_s.capitalize.intern</code>. | ||
+ | *التابع <code>[[Ruby/Symbol/casecmp-3F|casecmp?]]</code>: يتحقق إن كان ال[[Ruby/Symbol|رمز]] الذي استُدعي معه والرمز المُمرَّر إليه متساويين بعد طي حالة الترميز الموحد (Unicode case folding). | ||
==مصادر== | ==مصادر== | ||
− | *[http://ruby-doc.org/core-2.5.1/Symbol.html#method-i-casecmp قسم | + | *[http://ruby-doc.org/core-2.5.1/Symbol.html#method-i-casecmp قسم التابع casecmp في الصنف Symbol في توثيق روبي الرسمي.] |
المراجعة الحالية بتاريخ 09:03، 5 ديسمبر 2018
يقارن التابع casecmp
بين رمزين بشكل غير حساس لحالة الأحرف. هذا التابع هو نسخة غير حساسة لحالة الأحرف (Case-insensitive) من المعامل <=>
. في الوقت الحالي، لا تعمل الحساسية لحالة الأحرف إلا على الأحرف A-Z/a-z
، وليس على كل محارف اليونيكود. هذا السلوك مختلف عن التابع casecmp?
.
البنية العامة
casecmp(other_symbol)→ -1, 0, +1, or nil
المعاملات
other_symbol
الرمز المراد التحقق من مقارنته مع الرمز المعطى.
القيمة المعادة
تعاد القيمة -1
أو 0
أو +1
أو بناءً على ما إذا كان الرمز أصغر من أو يساوي أو أكبر من other_symbol
. أو تُعاد القيمة nil
إذا كان للرمزين ترميزات غير متوافقة، أو إن لم يكن other_symbol
رمزًا.
أمثلة
مثال على استخدام التابع casecmp
:
:aBcDeF.casecmp(:abcde) #=> 1
:aBcDeF.casecmp(:abcdef) #=> 0
:aBcDeF.casecmp(:abcdefg) #=> -1
:abcdef.casecmp(:ABCDEF) #=> 0
:foo.casecmp(2) #=> nil
"\u{e4 f6 fc}".encode("ISO-8859-1").to_sym.casecmp(:"\u{c4 d6 dc}") #=> nil
انظر أيضًا
- التابع
capitalize
: يشبه التعبيرsym.to_s.capitalize.intern
. - التابع
casecmp?
: يتحقق إن كان الرمز الذي استُدعي معه والرمز المُمرَّر إليه متساويين بعد طي حالة الترميز الموحد (Unicode case folding).