الفرق بين المراجعتين لصفحة: «Ruby/Symbol/casecmp»
لا ملخص تعديل |
جميل-بيلوني (نقاش | مساهمات) ط مراجعة وتدقيق. |
||
سطر 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> هو نسخة غير حساسة لحالة الأحرف (Case-insensitive) | يقارن التابع <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|رمزً]]ا. | |||
==أمثلة== | ==أمثلة== | ||
سطر 23: | سطر 21: | ||
:foo.casecmp(2) #=> nil | :foo.casecmp(2) #=> nil | ||
"\u{e4 f6 fc}".encode("ISO-8859-1").to_sym.casecmp(:"\u{c4 d6 dc}") #=> nil</syntaxhighlight> | "\u{e4 f6 fc}".encode("ISO-8859-1").to_sym.casecmp(:"\u{c4 d6 dc}") #=> nil</syntaxhighlight> | ||
==انظر | ==انظر أيضًا== | ||
*التابع <code>[[Ruby/Symbol/capitalize|capitalize]]</code>: | *التابع <code>[[Ruby/Symbol/capitalize|capitalize]]</code>: يشبه التعبير <code>sym.to_s.capitalize.intern</code>. | ||
*التابع <code>[[Ruby/Symbol/casecmp-3F|casecmp?]]</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).