wbemprox: Perform a case insensitive match on path components.
Signed-off-by: Hans Leidekker <hans@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
90b0e94b5b
commit
ce3a0fc290
|
@ -338,8 +338,7 @@ static HRESULT parse_path( const WCHAR *str, struct path **ret )
|
||||||
|
|
||||||
if (*p == '\\')
|
if (*p == '\\')
|
||||||
{
|
{
|
||||||
static const WCHAR cimv2W[] = {'R','O','O','T','\\','C','I','M','V','2'};
|
static const WCHAR cimv2W[] = {'R','O','O','T','\\','C','I','M','V','2',0};
|
||||||
|
|
||||||
WCHAR server[MAX_COMPUTERNAME_LENGTH+1];
|
WCHAR server[MAX_COMPUTERNAME_LENGTH+1];
|
||||||
DWORD server_len = ARRAY_SIZE(server);
|
DWORD server_len = ARRAY_SIZE(server);
|
||||||
|
|
||||||
|
@ -352,8 +351,7 @@ static HRESULT parse_path( const WCHAR *str, struct path **ret )
|
||||||
if (!*p) return WBEM_E_INVALID_OBJECT_PATH;
|
if (!*p) return WBEM_E_INVALID_OBJECT_PATH;
|
||||||
|
|
||||||
len = p - q;
|
len = p - q;
|
||||||
if (!GetComputerNameW( server, &server_len ) || server_len != len
|
if (!GetComputerNameW( server, &server_len ) || server_len != len || wcsnicmp( q, server, server_len ))
|
||||||
|| memcmp( q, server, server_len * sizeof(WCHAR) ))
|
|
||||||
return WBEM_E_NOT_SUPPORTED;
|
return WBEM_E_NOT_SUPPORTED;
|
||||||
|
|
||||||
q = ++p;
|
q = ++p;
|
||||||
|
@ -361,7 +359,7 @@ static HRESULT parse_path( const WCHAR *str, struct path **ret )
|
||||||
if (!*p) return WBEM_E_INVALID_OBJECT_PATH;
|
if (!*p) return WBEM_E_INVALID_OBJECT_PATH;
|
||||||
|
|
||||||
len = p - q;
|
len = p - q;
|
||||||
if (len != ARRAY_SIZE(cimv2W) || memcmp( q, cimv2W, sizeof(cimv2W) ))
|
if (len != ARRAY_SIZE(cimv2W) - 1 || wcsnicmp( q, cimv2W, ARRAY_SIZE(cimv2W) - 1 ))
|
||||||
return WBEM_E_INVALID_NAMESPACE;
|
return WBEM_E_INVALID_NAMESPACE;
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue