table of contents
| 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 (envz, envz_len) وتُعيد الإدخال إذا وُجد، أو NULL إذا لم يُوجد.
envz_get() تبحث عن name في مُتجه envz (envz, envz_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);
}
انظر أيضًا¶
ترجمة¶
تُرجمت هذه الصفحة من الدليل بواسطة زايد السعيدي <zayed.alsaidi@gmail.com>
هذه الترجمة هي وثيقة مجانية؛ راجع رخصة جنو العامة الإصدار 3 أو ما بعده للاطلاع على شروط حقوق النشر. لا توجد أي ضمانات.
إذا وجدت أي أخطاء في ترجمة صفحة الدليل هذه، يرجى إرسال بريد إلكتروني إلى قائمة بريد المترجمين: kde-l10n-ar@kde.org.
| 8 فبراير 2026 | صفحات دليل لينكس (لم تصدر بعد) |