summaryrefslogtreecommitdiffstats
path: root/lib/libc/stdlib
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>2012-10-03 04:46:58 +0000
committerache <ache@FreeBSD.org>2012-10-03 04:46:58 +0000
commitcbaa91b07562a45d7a37b3fbaba57b77cbe94468 (patch)
tree95069d0b688fbfba33a5138446e584e2e06eb02a /lib/libc/stdlib
parentd142b7417c2aa871313728dddcbf50ce59f963b0 (diff)
downloadFreeBSD-src-cbaa91b07562a45d7a37b3fbaba57b77cbe94468.zip
FreeBSD-src-cbaa91b07562a45d7a37b3fbaba57b77cbe94468.tar.gz
Optimize prev. commit for speed.
1) Don't iterate the loop from the environment array beginning each time, iterate it under the last place we deactivate instead. 2) Call __rebuild_environ() not on each iteration but once, only at the end of whole loop (of course, only in case if something is changed). MFC after: 1 week
Diffstat (limited to 'lib/libc/stdlib')
-rw-r--r--lib/libc/stdlib/getenv.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/lib/libc/stdlib/getenv.c b/lib/libc/stdlib/getenv.c
index 37602a9..47963d5 100644
--- a/lib/libc/stdlib/getenv.c
+++ b/lib/libc/stdlib/getenv.c
@@ -662,6 +662,7 @@ unsetenv(const char *name)
{
int envNdx;
size_t nameLen;
+ int newEnvActive;
/* Check for malformed name. */
if (name == NULL || (nameLen = __strleneq(name)) == 0) {
@@ -674,15 +675,18 @@ unsetenv(const char *name)
return (-1);
/* Deactivate specified variable. */
- envNdx = envVarsTotal - 1;
/* Remove all occurrences. */
+ envNdx = envVarsTotal - 1;
+ newEnvActive = envActive;
while (__findenv(name, nameLen, &envNdx, true) != NULL) {
envVars[envNdx].active = false;
if (envVars[envNdx].putenv)
__remove_putenv(envNdx);
- __rebuild_environ(envActive - 1);
- envNdx = envVarsTotal - 1;
+ envNdx--;
+ newEnvActive--;
}
+ if (newEnvActive != envActive)
+ __rebuild_environ(newEnvActive);
return (0);
}
OpenPOWER on IntegriCloud