X-Git-Url: https://git.saurik.com/apple/libc.git/blobdiff_plain/1f2f436a38f7ae2d39a943ad2898d8fed4ed2e58..065eae9f38780a3602538caa52399f41f061a88e:/stdlib/FreeBSD/getenv.c?ds=inline diff --git a/stdlib/FreeBSD/getenv.c b/stdlib/FreeBSD/getenv.c index b1e034a..47b60df 100644 --- a/stdlib/FreeBSD/getenv.c +++ b/stdlib/FreeBSD/getenv.c @@ -36,8 +36,9 @@ __FBSDID("$FreeBSD: src/lib/libc/stdlib/getenv.c,v 1.8 2007/05/01 16:02:41 ache #include #include #include +#include -inline char *__findenv(const char *, int *); +__private_extern__ char *__findenv(const char *, int *, char **); /* * __findenv -- @@ -48,12 +49,12 @@ inline char *__findenv(const char *, int *); * * This routine *should* be a static; don't use it. */ -inline char * -__findenv(name, offset) +__private_extern__ char * +__findenv(name, offset, environ) const char *name; int *offset; + char **environ; { - extern char **environ; int len, i; const char *np; char **p, *cp; @@ -75,6 +76,19 @@ __findenv(name, offset) return (NULL); } +/* + * _getenvp -- SPI using an arbitrary pointer to string array (the array must + * have been created with malloc) and an env state, created by _allocenvstate(). + * Returns ptr to value associated with name, if any, else NULL. + */ +char * +_getenvp(const char *name, char ***envp, void *state __unused) +{ + int offset; + + return (__findenv(name, &offset, *envp)); +} + /* * getenv -- * Returns ptr to value associated with name, if any, else NULL. @@ -85,5 +99,5 @@ getenv(name) { int offset; - return (__findenv(name, &offset)); + return (__findenv(name, &offset, *_NSGetEnviron())); }