X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fenv%2Fsetenv.c;h=c5226b6d3c52fee58e34c86e1183804420e3af91;hb=c0058ab465e950c2c3302d2b62e21cc0b494224b;hp=03e165c8b332223f92d81d65088b1b288c5e4a42;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01;p=musl diff --git a/src/env/setenv.c b/src/env/setenv.c index 03e165c8..c5226b6d 100644 --- a/src/env/setenv.c +++ b/src/env/setenv.c @@ -2,30 +2,41 @@ #include #include -int __putenv(char *s, int a); +void __env_rm_add(char *old, char *new) +{ + static char **env_alloced; + static size_t env_alloced_n; + for (size_t i=0; i < env_alloced_n; i++) + if (env_alloced[i] == old) { + env_alloced[i] = new; + free(old); + return; + } else if (!env_alloced[i] && new) { + env_alloced[i] = new; + new = 0; + } + if (!new) return; + char **t = realloc(env_alloced, sizeof *t * (env_alloced_n+1)); + if (!t) return; + (env_alloced = t)[env_alloced_n++] = new; +} int setenv(const char *var, const char *value, int overwrite) { char *s; - int l1, l2; + size_t l1, l2; - if (strchr(var, '=')) { + if (!var || !(l1 = __strchrnul(var, '=') - var) || var[l1]) { errno = EINVAL; return -1; } if (!overwrite && getenv(var)) return 0; - l1 = strlen(var); l2 = strlen(value); s = malloc(l1+l2+2); + if (!s) return -1; memcpy(s, var, l1); s[l1] = '='; - memcpy(s+l1+1, value, l2); - s[l1+l2+1] = 0; - if (__putenv(s, 1)) { - free(s); - errno = ENOMEM; - return -1; - } - return 0; + memcpy(s+l1+1, value, l2+1); + return __putenv(s, l1, s); }