diff options
Diffstat (limited to 'src/lib/libc/stdlib/setenv.c')
-rw-r--r-- | src/lib/libc/stdlib/setenv.c | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/src/lib/libc/stdlib/setenv.c b/src/lib/libc/stdlib/setenv.c index 89d1e88911..089ab92d38 100644 --- a/src/lib/libc/stdlib/setenv.c +++ b/src/lib/libc/stdlib/setenv.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: setenv.c,v 1.12 2010/06/29 04:09:34 naddy Exp $ */ | 1 | /* $OpenBSD: setenv.c,v 1.13 2010/08/23 22:31:50 millert Exp $ */ |
2 | /* | 2 | /* |
3 | * Copyright (c) 1987 Regents of the University of California. | 3 | * Copyright (c) 1987 Regents of the University of California. |
4 | * All rights reserved. | 4 | * All rights reserved. |
@@ -47,7 +47,7 @@ putenv(char *str) | |||
47 | { | 47 | { |
48 | char **P, *cp; | 48 | char **P, *cp; |
49 | size_t cnt; | 49 | size_t cnt; |
50 | int offset; | 50 | int offset = 0; |
51 | 51 | ||
52 | for (cp = str; *cp && *cp != '='; ++cp) | 52 | for (cp = str; *cp && *cp != '='; ++cp) |
53 | ; | 53 | ; |
@@ -57,7 +57,13 @@ putenv(char *str) | |||
57 | } | 57 | } |
58 | 58 | ||
59 | if (__findenv(str, (int)(cp - str), &offset) != NULL) { | 59 | if (__findenv(str, (int)(cp - str), &offset) != NULL) { |
60 | environ[offset] = str; | 60 | environ[offset++] = str; |
61 | /* could be set multiple times */ | ||
62 | while (__findenv(str, (int)(cp - str), &offset)) { | ||
63 | for (P = &environ[offset];; ++P) | ||
64 | if (!(*P = *(P + 1))) | ||
65 | break; | ||
66 | } | ||
61 | return (0); | 67 | return (0); |
62 | } | 68 | } |
63 | 69 | ||
@@ -84,9 +90,9 @@ putenv(char *str) | |||
84 | int | 90 | int |
85 | setenv(const char *name, const char *value, int rewrite) | 91 | setenv(const char *name, const char *value, int rewrite) |
86 | { | 92 | { |
87 | char *C; | 93 | char *C, **P; |
88 | const char *np; | 94 | const char *np; |
89 | int l_value, offset; | 95 | int l_value, offset = 0; |
90 | 96 | ||
91 | for (np = name; *np && *np != '='; ++np) | 97 | for (np = name; *np && *np != '='; ++np) |
92 | ; | 98 | ; |
@@ -99,6 +105,7 @@ setenv(const char *name, const char *value, int rewrite) | |||
99 | 105 | ||
100 | l_value = strlen(value); | 106 | l_value = strlen(value); |
101 | if ((C = __findenv(name, (int)(np - name), &offset)) != NULL) { | 107 | if ((C = __findenv(name, (int)(np - name), &offset)) != NULL) { |
108 | int tmpoff = offset + 1; | ||
102 | if (!rewrite) | 109 | if (!rewrite) |
103 | return (0); | 110 | return (0); |
104 | #if 0 /* XXX - existing entry may not be writable */ | 111 | #if 0 /* XXX - existing entry may not be writable */ |
@@ -108,9 +115,14 @@ setenv(const char *name, const char *value, int rewrite) | |||
108 | return (0); | 115 | return (0); |
109 | } | 116 | } |
110 | #endif | 117 | #endif |
118 | /* could be set multiple times */ | ||
119 | while (__findenv(name, (int)(np - name), &tmpoff)) { | ||
120 | for (P = &environ[tmpoff];; ++P) | ||
121 | if (!(*P = *(P + 1))) | ||
122 | break; | ||
123 | } | ||
111 | } else { /* create new slot */ | 124 | } else { /* create new slot */ |
112 | size_t cnt; | 125 | size_t cnt; |
113 | char **P; | ||
114 | 126 | ||
115 | for (P = environ; *P != NULL; P++) | 127 | for (P = environ; *P != NULL; P++) |
116 | ; | 128 | ; |
@@ -143,7 +155,7 @@ unsetenv(const char *name) | |||
143 | { | 155 | { |
144 | char **P; | 156 | char **P; |
145 | const char *np; | 157 | const char *np; |
146 | int offset; | 158 | int offset = 0; |
147 | 159 | ||
148 | if (!name || !*name) { | 160 | if (!name || !*name) { |
149 | errno = EINVAL; | 161 | errno = EINVAL; |