VirtualBox

source: vbox/trunk/src/VBox/Runtime/r3/win/env-win.cpp@ 67663

Last change on this file since 67663 was 62477, checked in by vboxsync, 8 years ago

(C) 2016

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 7.9 KB
Line 
1/* $Id: env-win.cpp 62477 2016-07-22 18:27:37Z vboxsync $ */
2/** @file
3 * IPRT - Environment, Posix.
4 */
5
6/*
7 * Copyright (C) 2006-2016 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28/*********************************************************************************************************************************
29* Header Files *
30*********************************************************************************************************************************/
31#include <iprt/env.h>
32
33#include <iprt/alloca.h>
34#include <iprt/assert.h>
35#include <iprt/string.h>
36#include <iprt/mem.h>
37
38#include <stdlib.h>
39#include <errno.h>
40
41
42RTDECL(bool) RTEnvExistsBad(const char *pszVar)
43{
44 return RTEnvGetBad(pszVar) != NULL;
45}
46
47
48RTDECL(bool) RTEnvExist(const char *pszVar)
49{
50 return RTEnvExistsBad(pszVar);
51}
52
53
54RTDECL(bool) RTEnvExistsUtf8(const char *pszVar)
55{
56 AssertReturn(strchr(pszVar, '=') == NULL, false);
57
58 PRTUTF16 pwszVar;
59 int rc = RTStrToUtf16(pszVar, &pwszVar);
60 AssertRCReturn(rc, false);
61 bool fRet = _wgetenv(pwszVar) != NULL;
62 RTUtf16Free(pwszVar);
63 return fRet;
64}
65
66
67RTDECL(const char *) RTEnvGetBad(const char *pszVar)
68{
69 AssertReturn(strchr(pszVar, '=') == NULL, NULL);
70 return getenv(pszVar);
71}
72
73
74RTDECL(const char *) RTEnvGet(const char *pszVar)
75{
76 return RTEnvGetBad(pszVar);
77}
78
79RTDECL(int) RTEnvGetUtf8(const char *pszVar, char *pszValue, size_t cbValue, size_t *pcchActual)
80{
81 AssertPtrReturn(pszVar, VERR_INVALID_POINTER);
82 AssertPtrNullReturn(pszValue, VERR_INVALID_POINTER);
83 AssertReturn(pszValue || !cbValue, VERR_INVALID_PARAMETER);
84 AssertPtrNullReturn(pcchActual, VERR_INVALID_POINTER);
85 AssertReturn(pcchActual || (pszValue && cbValue), VERR_INVALID_PARAMETER);
86 AssertReturn(strchr(pszVar, '=') == NULL, VERR_ENV_INVALID_VAR_NAME);
87
88 if (pcchActual)
89 *pcchActual = 0;
90
91 PRTUTF16 pwszVar;
92 int rc = RTStrToUtf16(pszVar, &pwszVar);
93 AssertRCReturn(rc, rc);
94
95 /** @todo Consider _wgetenv_s or GetEnvironmentVariableW here to avoid the
96 * potential race with a concurrent _wputenv/_putenv. */
97 PCRTUTF16 pwszValue = _wgetenv(pwszVar);
98 RTUtf16Free(pwszVar);
99 if (pwszValue)
100 {
101 if (cbValue)
102 rc = RTUtf16ToUtf8Ex(pwszValue, RTSTR_MAX, &pszValue, cbValue, pcchActual);
103 else
104 rc = RTUtf16CalcUtf8LenEx(pwszValue, RTSTR_MAX, pcchActual);
105 }
106 else
107 rc = VERR_ENV_VAR_NOT_FOUND;
108 return rc;
109}
110
111
112RTDECL(int) RTEnvPutBad(const char *pszVarEqualValue)
113{
114 /** @todo putenv is a source memory leaks. deal with this on a per system basis. */
115 if (!putenv((char *)pszVarEqualValue))
116 return 0;
117 return RTErrConvertFromErrno(errno);
118}
119
120
121RTDECL(int) RTEnvPut(const char *pszVarEqualValue)
122{
123 return RTEnvPutBad(pszVarEqualValue);
124}
125
126
127RTDECL(int) RTEnvPutUtf8(const char *pszVarEqualValue)
128{
129 PRTUTF16 pwszVarEqualValue;
130 int rc = RTStrToUtf16(pszVarEqualValue, &pwszVarEqualValue);
131 if (RT_SUCCESS(rc))
132 {
133 if (!_wputenv(pwszVarEqualValue))
134 rc = VINF_SUCCESS;
135 else
136 rc = RTErrConvertFromErrno(errno);
137 RTUtf16Free(pwszVarEqualValue);
138 }
139 return rc;
140}
141
142
143
144RTDECL(int) RTEnvSetBad(const char *pszVar, const char *pszValue)
145{
146 AssertMsgReturn(strchr(pszVar, '=') == NULL, ("'%s'\n", pszVar), VERR_ENV_INVALID_VAR_NAME);
147
148 /* make a local copy and feed it to putenv. */
149 const size_t cchVar = strlen(pszVar);
150 const size_t cchValue = strlen(pszValue);
151 char *pszTmp = (char *)alloca(cchVar + cchValue + 2 + !*pszValue);
152 memcpy(pszTmp, pszVar, cchVar);
153 pszTmp[cchVar] = '=';
154 if (*pszValue)
155 memcpy(pszTmp + cchVar + 1, pszValue, cchValue + 1);
156 else
157 {
158 pszTmp[cchVar + 1] = ' '; /* wrong, but putenv will remove it otherwise. */
159 pszTmp[cchVar + 2] = '\0';
160 }
161
162 if (!putenv(pszTmp))
163 return 0;
164 return RTErrConvertFromErrno(errno);
165}
166
167
168RTDECL(int) RTEnvSet(const char *pszVar, const char *pszValue)
169{
170 return RTEnvSetBad(pszVar, pszValue);
171}
172
173RTDECL(int) RTEnvSetUtf8(const char *pszVar, const char *pszValue)
174{
175 AssertReturn(strchr(pszVar, '=') == NULL, VERR_ENV_INVALID_VAR_NAME);
176
177 size_t cwcVar;
178 int rc = RTStrCalcUtf16LenEx(pszVar, RTSTR_MAX, &cwcVar);
179 if (RT_SUCCESS(rc))
180 {
181 size_t cwcValue;
182 rc = RTStrCalcUtf16LenEx(pszVar, RTSTR_MAX, &cwcValue);
183 if (RT_SUCCESS(rc))
184 {
185 PRTUTF16 pwszTmp = (PRTUTF16)RTMemTmpAlloc((cwcVar + 1 + cwcValue + 1) * sizeof(RTUTF16));
186 if (pwszTmp)
187 {
188 rc = RTStrToUtf16Ex(pszVar, RTSTR_MAX, &pwszTmp, cwcVar + 1, NULL);
189 if (RT_SUCCESS(rc))
190 {
191 PRTUTF16 pwszTmpValue = &pwszTmp[cwcVar];
192 *pwszTmpValue++ = '=';
193 rc = RTStrToUtf16Ex(pszValue, RTSTR_MAX, &pwszTmpValue, cwcValue + 1, NULL);
194 if (RT_SUCCESS(rc))
195 {
196 if (!_wputenv(pwszTmp))
197 rc = VINF_SUCCESS;
198 else
199 rc = RTErrConvertFromErrno(errno);
200 }
201 }
202 RTMemTmpFree(pwszTmp);
203 }
204 else
205 rc = VERR_NO_TMP_MEMORY;
206 }
207 }
208 return rc;
209}
210
211
212RTDECL(int) RTEnvUnsetBad(const char *pszVar)
213{
214 AssertReturn(strchr(pszVar, '=') == NULL, VERR_ENV_INVALID_VAR_NAME);
215
216 /*
217 * Check that it exists first.
218 */
219 if (!RTEnvExist(pszVar))
220 return VINF_ENV_VAR_NOT_FOUND;
221
222 /*
223 * Ok, try remove it.
224 */
225#ifdef RT_OS_WINDOWS
226 /* Use putenv(var=) since Windows does not have unsetenv(). */
227 size_t cchVar = strlen(pszVar);
228 char *pszBuf = (char *)alloca(cchVar + 2);
229 memcpy(pszBuf, pszVar, cchVar);
230 pszBuf[cchVar] = '=';
231 pszBuf[cchVar + 1] = '\0';
232
233 if (!putenv(pszBuf))
234 return VINF_SUCCESS;
235
236#else
237 /* This is the preferred function as putenv() like used above does neither work on Solaris nor on Darwin. */
238 if (!unsetenv((char*)pszVar))
239 return VINF_SUCCESS;
240#endif
241
242 return RTErrConvertFromErrno(errno);
243}
244
245
246RTDECL(int) RTEnvUnset(const char *pszVar)
247{
248 return RTEnvUnsetBad(pszVar);
249}
250
251
252RTDECL(int) RTEnvUnsetUtf8(const char *pszVar)
253{
254 AssertReturn(strchr(pszVar, '=') == NULL, VERR_ENV_INVALID_VAR_NAME);
255
256 size_t cwcVar;
257 int rc = RTStrCalcUtf16LenEx(pszVar, RTSTR_MAX, &cwcVar);
258 if (RT_SUCCESS(rc))
259 {
260 PRTUTF16 pwszTmp = (PRTUTF16)RTMemTmpAlloc((cwcVar + 1 + 1) * sizeof(RTUTF16));
261 if (pwszTmp)
262 {
263 rc = RTStrToUtf16Ex(pszVar, RTSTR_MAX, &pwszTmp, cwcVar + 1, NULL);
264 if (RT_SUCCESS(rc))
265 {
266 pwszTmp[cwcVar] = '=';
267 pwszTmp[cwcVar + 1] = '\0';
268 if (!_wputenv(pwszTmp))
269 rc = VINF_SUCCESS;
270 else
271 rc = RTErrConvertFromErrno(errno);
272 }
273 RTMemTmpFree(pwszTmp);
274 }
275 }
276 return rc;
277}
278
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette