التابع Encoding::Converter.putback في روبي
يُعيد التّابع putback
البايتات التي ستُحوَّل. يمكن استدعاء هذا التابع بشكل متسلسل (call-seq).
ec.putback -> string
ec.putback(max_numbytes) -> string
تنتج البايتات من الخطأ invalid_byte_sequence
. عند حصول هذا الخطأ تهمل بعض البايتات ويخزَّن بعضها الآخر مؤقتًا بانتظار تحويلها لاحقًا. البايتات التي سيعيدها التابع هي الأخير (أي البايتات المخزنة). يمكن مراقبة وتتبع هذه الحالة باستخدام التّابع Encoding::InvalidByteSequenceError.readagain_bytes
والتّابع primitive_errinfo
.
البنية العامة
putback(p1 = v1)
أمثلة
مثالٌ عن استخدام التابع putback:
ec = Encoding::Converter.new("utf-16le", "iso-8859-1")
src = "\x00\xd8\x61\x00"
dst = ""
p ec.primitive_convert(src, dst) #=> :invalid_byte_sequence
p ec.primitive_errinfo #=> [:invalid_byte_sequence, "UTF-16LE", "UTF-8", "\x00\xD8", "a\x00"]
p ec.putback #=> "a\x00"
p ec.putback #=> "" # لم يعد هنالك المزيد من البايتات لإعادتها
انظر أيضًا
- التّابع replacement::: يُعيد سلسلة الاستبدال النصية.
- التّابع replacement: يضبط سلسلة الاستبدال النصية.
- التّابع inspect: يُعيد نسخةً قابلةً للطباعة من كائن الصنف Encoding::Converter.
- التّابع primitive_errinfo: يُعيد معلوماتٍ مهمّةً حول آخر خطأٍ حدث في مصفوفة مكونة من خمسة عناصر.