Scroll to navigation

envz_add(3) Library Functions Manual envz_add(3)

الاسم

envz_add, envz_entry, envz_get, envz_merge, envz_remove, envz_strip - دعم سلاسل محارف البيئة

المكتبة

مكتبة سي المعيارية (libc، -lc)

موجز

#include <envz.h>
error_t envz_add(char **restrict envz, size_t *restrict envz_len,
               const char *restrict name, const char *restrict value);
char *envz_entry(const char *restrict envz, size_t envz_len,
               const char *restrict name);
char *envz_get(const char *restrict envz, size_t envz_len,
               const char *restrict name);
error_t envz_merge(char **restrict envz, size_t *restrict envz_len,
               const char *restrict envz2, size_t envz2_len,
               int override);
void envz_remove(char **restrict envz, size_t *restrict envz_len,
               const char *restrict name);
void envz_strip(char **restrict envz, size_t *restrict envz_len);

الوصف

هذه الدوال خاصة بـ glibc.

مُتجه argz هو مؤشر إلى مخزن محارف مع طول، انظر argz_add(3). مُتجه envz هو مُتجه argz خاص، وهو الذي تكون فيه السلاسل على شكل "name=value". كل شيء بعد أول '=' يُعتبر القيمة. إذا لم يكن هناك '='، تُؤخذ القيمة على أنها NULL. (بينما القيمة في حالة '=' لاحقة هي السلسلة الفارغة "".)

هذه الدوال لمعالجة مُتجهات envz.

envz_add() تُضيف السلسلة "name=value" (في حالة كانت value غير NULL) أو "name" (في حالة كانت value NULL) إلى مُتجه envz (*envz*envz_len) وتُحدّث *envz و *envz_len. إذا وُجد إدخال بنفس name، يُزال.

envz_entry() تبحث عن name في مُتجه envz (envzenvz_len) وتُعيد الإدخال إذا وُجد، أو NULL إذا لم يُوجد.

envz_get() تبحث عن name في مُتجه envz (envzenvz_len) وتُعيد القيمة إذا وُجدت، أو NULL إذا لم تُوجد. (لاحظ أن القيمة يمكن أن تكون NULL أيضًا، أي عندما يكون هناك إدخال لـ name بدون علامة '='.)

envz_merge() تُضيف كل إدخال في envz2 إلى *envz، كما لو كان مع envz_add(). إذا كان override صحيحًا، فستحل القيم في envz2 محل تلك التي بنفس الاسم في *envz، وإلا فلا.

envz_remove() تُزيل الإدخال لـ name من (*envz*envz_len) إذا كان موجودًا.

envz_strip() تُزيل جميع الإدخالات ذات القيمة NULL.

قيمة الإرجاع

جميع دوال envz التي تقوم بتخصيص الذاكرة لها نوع إرجاع error_t (نوع صحيح)، وتُعيد 0 للنجاح، و ENOMEM إذا حدث خطأ في التخصيص.

السمات

للاطلاع على شرح للمصطلحات المستخدمة في هذا القسم، انظر attributes(7).

الواجهة السمة القيمة
envz_add(), envz_entry(), envz_get(), envz_merge(), envz_remove(), envz_strip() سلامة الخيوط MT-Safe

المعايير

GNU.

أمثلة

#include <envz.h>
#include <stdio.h>
#include <stdlib.h>
int
main(int argc, char *argv[], char *envp[])
{

char *str;
size_t e_len = 0;
for (size_t i = 0; envp[i] != NULL; i++)
e_len += strlen(envp[i]) + 1;
str = envz_entry(*envp, e_len, "HOME");
printf("%s\n", str);
str = envz_get(*envp, e_len, "HOME");
printf("%s\n", str);
exit(EXIT_SUCCESS); }

انظر أيضًا

argz_add(3)

ترجمة

تُرجمت هذه الصفحة من الدليل بواسطة زايد السعيدي <zayed.alsaidi@gmail.com>

هذه الترجمة هي وثيقة مجانية؛ راجع رخصة جنو العامة الإصدار 3 أو ما بعده للاطلاع على شروط حقوق النشر. لا توجد أي ضمانات.

إذا وجدت أي أخطاء في ترجمة صفحة الدليل هذه، يرجى إرسال بريد إلكتروني إلى قائمة بريد المترجمين: kde-l10n-ar@kde.org.

8 فبراير 2026 صفحات دليل لينكس (لم تصدر بعد)