table of contents
- trixie-backports 4.31.0-1~bpo13+1
- testing 4.31.0-1
- unstable 4.31.0-1
| mbsnrtowcs(3) | Library Functions Manual | mbsnrtowcs(3) |
الاسم¶
mbsnrtowcs - تحويل سلسلة محارف متعددة البايت إلى سلسلة محارف عريضة
المكتبة¶
مكتبة سي المعيارية (libc، -lc)
موجز¶
#include <wchar.h>
size_t mbsnrtowcs(wchar_t dest[restrict .len], const char **restrict src,
size_t nms, size_t len, mbstate_t *restrict ps);
mbsnrtowcs():
منذ glibc 2.10:
_POSIX_C_SOURCE >= 200809L
قبل glibc 2.10:
_GNU_SOURCE
الوصف¶
الدالة mbsnrtowcs() تشبه الدالة mbsrtowcs(3) ، باستثناء أن عدد البايتات المُراد تحويلها، بدءًا من *src، محدود بـ nms بايت على الأكثر.
إذا لم يكن dest NULL، تُحوّل الدالة mbsnrtowcs() على الأكثر nms بايت من سلسلة المحارف متعددة البايت *src إلى سلسلة محارف عريضة تبدأ عند dest. يُكتب على الأكثر len حرفًا عريضًا إلى dest. تُحدّث حالة الإزاحة *ps. يُنفّذ التحويل فعليًا باستدعاء متكرر لـ mbrtowc(dest, *src, n, ps) حيث n عدد موجب، طالما نجح هذا الاستدعاء، ثم زيادة dest بمقدار 1 و *src بعدد البايتات المستهلكة. يمكن أن يتوقف التحويل لثلاثة أسباب:
- •
- وُجِد تسلسل متعدد البايتات غير صالح. في هذه الحالة، يُترك *src يشير إلى التسلسل غير الصالح، ويُعاد (size_t) -1، ويُضبط errno على EILSEQ.
- •
- حد nms يُجبر على التوقف، أو خُزّن len حرفًا عريضًا غير L'\0' عند dest. في هذه الحالة، يُترك *src يشير إلى تسلسل المحارف متعددة البايت التالي المراد تحويله، ويُعاد عدد المحارف العريضة المكتوبة إلى dest.
- •
- حُوّلت سلسلة المحارف متعددة البايت بالكامل، بما في ذلك الحرف العريض الفارغ الختامي ('\0') (الذي له تأثير جانبي بإعادة *ps إلى الحالة الأولية). في هذه الحالة، يُضبط *src على NULL، ويُعاد عدد المحارف العريضة المكتوبة إلى dest، باستثناء الحرف العريض الفارغ الختامي.
وفقًا لـ POSIX.1، إذا انتهى مخزن الإدخال بحرف غير مكتمل، فمن غير المحدد ما إذا كان التحويل يتوقف عند نهاية الحرف السابق (إن وجد)، أو عند نهاية مخزن الإدخال. يتبنى تطبيق glibc السلوك الأول.
إذا كان dest NULL، يُتجاهل len، ويستمر التحويل كما سبق، باستثناء أن المحارف العريضة المحولة لا تُكتب إلى الذاكرة، ولا يوجد حد لطول الوجهة.
في كلتا الحالتين أعلاه، إذا كان ps NULL، تُستخدم حالة مجهولة ثابتة معروفة فقط للدالة mbsnrtowcs() بدلاً من ذلك.
يجب على المبرمج ضمان وجود مساحة لـ len محرف عريض على الأقل عند dest.
قيمة الإرجاع¶
تُرجع الدالة mbsnrtowcs() عدد المحارف العريضة التي تشكل الجزء المحول من سلسلة المحارف العريضة، دون تضمين الحرف العريض الفارغ الختامي. إذا صودف تسلسل محارف متعددة البايت غير صالح، يُعاد (size_t) -1، ويُضبط errno على EILSEQ.
السمات¶
للاطلاع على شرح للمصطلحات المستخدمة في هذا القسم، انظر attributes(7).
| الواجهة | السمة | القيمة |
| mbsnrtowcs() | سلامة الخيوط | MT-Unsafe race:mbsnrtowcs/!ps |
المعايير¶
POSIX.1-2008.
ملاحظات¶
يعتمد سلوك mbsnrtowcs() على فئة LC_CTYPE من الإعدادات المحلية الحالية.
تمرير NULL كـ ps ليس آمنًا في تعدد الخيوط.
انظر أيضًا¶
ترجمة¶
تُرجمت هذه الصفحة من الدليل بواسطة زايد السعيدي <zayed.alsaidi@gmail.com>
هذه الترجمة هي وثيقة مجانية؛ راجع رخصة جنو العامة الإصدار 3 أو ما بعده للاطلاع على شروط حقوق النشر. لا توجد أي ضمانات.
إذا وجدت أي أخطاء في ترجمة صفحة الدليل هذه، يرجى إرسال بريد إلكتروني إلى قائمة بريد المترجمين: kde-l10n-ar@kde.org.
| 15 يونيو 2024 | صفحات دليل لينكس 6.9.1 |