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

من موسوعة حسوب
< Ruby‏ | Encoding
لا ملخص تعديل
لا ملخص تعديل
سطر 1: سطر 1:
{{DISPLAYTITLE:التابع <code>Encoding.compatible?</code> في روبي}}
{{DISPLAYTITLE:التابع <code>?Encoding.compatible</code> في روبي}}
يتحقّق التابع <code>compatible?</code>‎ من توافق كائنين مع بعضهما بعضًا.
يتحقّق التابع <code>compatible?</code>‎ من توافق كائنين مع بعضهما بعضًا.



مراجعة 12:04، 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: يتحقّق من التّرميز الزّائف.

مصادر