الفرق بين المراجعتين لصفحة: «Ruby/Encoding/compatible-3F»

من موسوعة حسوب
< Ruby‏ | Encoding
إضافة كامل الصفحة
 
طلا ملخص تعديل
سطر 43: سطر 43:


== انظر أيضًا ==
== انظر أيضًا ==
* التابع ?ascii_compatible: يتحقّق من توافق ترميز محدد مع الترميز ASCII.
* التابع <code>[[Ruby/Encoding/ascii compatible-3F|?ascii_compatible]]</code>: يتحقّق من توافق ترميز محدد مع الترميز ASCII.
* التّابع ?dummy: يتحقّق من التّرميز الزّائف.
* التّابع <code>[[Ruby/Encoding/dummy-3F|?dummy]]</code>: يتحقّق من التّرميز الزّائف.


== مصادر ==
== مصادر ==

مراجعة 10:14، 8 أكتوبر 2018


يتحقّق التابع compatible?‎ من توافق كائنين مع بعضهما بعضًا.

إذا كان نوع كلا الكائنين سلسلة نصية (string)، فإنهما يكونان متوافقين عندما يكونان قابلين للتسلسل (Concatenation).

أمَّا إن لم يكن هذان الكائنان سلسلةً نصيةً، فسيُعدُّ كلاهما متوافقين عندما يملكان ترميزًا وكان:

  • كلا الترميزين متوافق مع الترميز US-ASCII، أو
  • أحد هذان التّرميزان هو ترميز من النوع 7-bit.

البنية العامة

compatible?(obj1, obj2)  enc or nil

المعاملات

obj1

الكائن الأول المراد التحقق من توافقه مع الكائن obj2.

obj2

الكائن الثاني المراد التحقق من توافقه مع الكائن obj1.

القيم المعادة

يعاد ترميز السلسلة النصية المتسلسلة (concatenated string) عندما تكون السلسلتان  obj1 و obj2 متوافقين، أو تعاد القيمة nil العدمية خلاف ذلك.

أمثلة

بعض الأمثلة عن استخدام التابع compatible?‎:

Encoding.compatible?("\xa1".force_encoding("iso-8859-1"), "b")

#=> #<Encoding:ISO-8859-1>

Encoding.compatible?(

 "\xa1".force_encoding("iso-8859-1"),

 "\xa1\xa1".force_encoding("euc-jp"))

#=> nil

انظر أيضًا

  • التابع ?ascii_compatible: يتحقّق من توافق ترميز محدد مع الترميز ASCII.
  • التّابع ?dummy: يتحقّق من التّرميز الزّائف.

مصادر