Commit 18448aa2 authored by Piotr Caban's avatar Piotr Caban Committed by Alexandre Julliard

msvcrt: Improve error handling in _wgetenv_s.

(cherry picked from commit 667d889d)
parent 07d01fde
...@@ -56,15 +56,12 @@ char * CDECL getenv(const char *name) ...@@ -56,15 +56,12 @@ char * CDECL getenv(const char *name)
return getenv_helper(name); return getenv_helper(name);
} }
/********************************************************************* static wchar_t * wgetenv_helper(const wchar_t *name)
* _wgetenv (MSVCRT.@)
*/
wchar_t * CDECL _wgetenv(const wchar_t *name)
{ {
wchar_t **env; wchar_t **env;
size_t len; size_t len;
if (!MSVCRT_CHECK_PMT(name != NULL)) return NULL; if (!name) return NULL;
len = wcslen(name); len = wcslen(name);
/* Initialize the _wenviron array if it's not already created. */ /* Initialize the _wenviron array if it's not already created. */
...@@ -85,6 +82,16 @@ wchar_t * CDECL _wgetenv(const wchar_t *name) ...@@ -85,6 +82,16 @@ wchar_t * CDECL _wgetenv(const wchar_t *name)
} }
/********************************************************************* /*********************************************************************
* _wgetenv (MSVCRT.@)
*/
wchar_t * CDECL _wgetenv(const wchar_t *name)
{
if (!MSVCRT_CHECK_PMT(name != NULL)) return NULL;
return wgetenv_helper(name);
}
/*********************************************************************
* _putenv (MSVCRT.@) * _putenv (MSVCRT.@)
*/ */
int CDECL _putenv(const char *str) int CDECL _putenv(const char *str)
...@@ -306,25 +313,21 @@ int CDECL getenv_s(size_t *ret_len, char* buffer, size_t len, const char *varnam ...@@ -306,25 +313,21 @@ int CDECL getenv_s(size_t *ret_len, char* buffer, size_t len, const char *varnam
/****************************************************************** /******************************************************************
* _wgetenv_s (MSVCRT.@) * _wgetenv_s (MSVCRT.@)
*/ */
int CDECL _wgetenv_s(size_t *pReturnValue, wchar_t *buffer, size_t numberOfElements, int CDECL _wgetenv_s(size_t *ret_len, wchar_t *buffer, size_t len,
const wchar_t *varname) const wchar_t *varname)
{ {
wchar_t *e; wchar_t *e;
if (!MSVCRT_CHECK_PMT(pReturnValue != NULL)) return EINVAL; if (!MSVCRT_CHECK_PMT(ret_len != NULL)) return EINVAL;
if (!MSVCRT_CHECK_PMT(!(buffer == NULL && numberOfElements > 0))) return EINVAL; *ret_len = 0;
if (!MSVCRT_CHECK_PMT(varname != NULL)) return EINVAL; if (!MSVCRT_CHECK_PMT((buffer && len > 0) || (!buffer && !len))) return EINVAL;
if (buffer) buffer[0] = 0;
if (!(e = wgetenv_helper(varname))) return 0;
*ret_len = wcslen(e) + 1;
if (!len) return 0;
if (len < *ret_len) return ERANGE;
if (!(e = _wgetenv(varname)))
{
*pReturnValue = 0;
return *_errno() = EINVAL;
}
*pReturnValue = wcslen(e) + 1;
if (numberOfElements < *pReturnValue)
{
return *_errno() = ERANGE;
}
wcscpy(buffer, e); wcscpy(buffer, e);
return 0; return 0;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment