Fixed RegQueryValueExA and marked as implemented.

svn path=/trunk/; revision=6312
This commit is contained in:
Filip Navara 2003-10-14 18:18:27 +00:00
parent 47419d0b98
commit 3889a8a8dd

View file

@ -1,4 +1,4 @@
/* $Id: reg.c,v 1.30 2003/08/30 14:46:29 hbirr Exp $ /* $Id: reg.c,v 1.31 2003/10/14 18:18:27 navaraf Exp $
* *
* COPYRIGHT: See COPYING in the top level directory * COPYRIGHT: See COPYING in the top level directory
* PROJECT: ReactOS system libraries * PROJECT: ReactOS system libraries
@ -19,7 +19,7 @@
#include <windows.h> #include <windows.h>
#include <wchar.h> #include <wchar.h>
#define NDEBUG //#define NDEBUG
#include <debug.h> #include <debug.h>
/* DEFINES ******************************************************************/ /* DEFINES ******************************************************************/
@ -2180,7 +2180,7 @@ RegQueryValueExW (HKEY hKey,
/************************************************************************ /************************************************************************
* RegQueryValueExA * RegQueryValueExA
* *
* @unimplemented * @implemented
*/ */
LONG LONG
STDCALL STDCALL
@ -2192,69 +2192,65 @@ RegQueryValueExA(
LPBYTE lpData, LPBYTE lpData,
LPDWORD lpcbData) LPDWORD lpcbData)
{ {
WCHAR ValueNameBuffer[MAX_PATH+1];
UNICODE_STRING ValueName; UNICODE_STRING ValueName;
UNICODE_STRING ValueData; UNICODE_STRING ValueData;
ANSI_STRING AnsiString; ANSI_STRING AnsiString;
LONG ErrorCode; LONG ErrorCode;
DWORD ResultSize;
DWORD Type;
/* FIXME: HKEY_PERFORMANCE_DATA is special, see MS SDK */ if ((lpData) && (!lpcbData))
{
if ((lpData) && (!lpcbData)) {
SetLastError(ERROR_INVALID_PARAMETER); SetLastError(ERROR_INVALID_PARAMETER);
return ERROR_INVALID_PARAMETER; return ERROR_INVALID_PARAMETER;
} }
RtlInitUnicodeString(&ValueData, NULL);
if (lpData) { if (lpData)
ValueData.MaximumLength = *lpcbData * sizeof(WCHAR); {
ValueData.Length = ValueData.MaximumLength = *lpcbData * sizeof(WCHAR);
ValueData.Buffer = RtlAllocateHeap( ValueData.Buffer = RtlAllocateHeap(
ProcessHeap, ProcessHeap,
0, 0,
ValueData.MaximumLength); ValueData.Length);
if (!ValueData.Buffer) { if (!ValueData.Buffer)
{
SetLastError(ERROR_OUTOFMEMORY); SetLastError(ERROR_OUTOFMEMORY);
return ERROR_OUTOFMEMORY; return ERROR_OUTOFMEMORY;
} }
} }
RtlInitAnsiString(&AnsiString, (LPSTR)lpValueName); else
RtlInitUnicodeString(&ValueName, NULL); {
ValueName.Buffer = &ValueNameBuffer[0]; ValueData.Buffer = NULL;
ValueName.MaximumLength = sizeof(ValueNameBuffer);
RtlAnsiStringToUnicodeString(&ValueName, &AnsiString, FALSE);
if (lpcbData) {
ResultSize = *lpcbData;
} else {
ResultSize = 0;
} }
RtlCreateUnicodeStringFromAsciiz(&ValueName, (LPSTR)lpValueName);
ErrorCode = RegQueryValueExW( ErrorCode = RegQueryValueExW(
hKey, hKey,
ValueName.Buffer, ValueName.Buffer,
lpReserved, lpReserved,
&Type, lpType,
(LPBYTE)ValueData.Buffer, (LPBYTE)ValueData.Buffer,
&ResultSize); (LPDWORD)&ValueData.Length);
if ((ErrorCode == ERROR_SUCCESS) && (ValueData.Buffer != NULL)) {
if (lpType) { if ((ErrorCode == ERROR_SUCCESS) && (ValueData.Buffer != NULL))
*lpType = Type; {
} if (lpType && ((*lpType == REG_SZ) || (*lpType == REG_MULTI_SZ) || (*lpType == REG_EXPAND_SZ)))
if ((Type == REG_SZ) || (Type == REG_MULTI_SZ) || (Type == REG_EXPAND_SZ)) { {
ValueData.Length = ResultSize;
RtlInitAnsiString(&AnsiString, NULL); RtlInitAnsiString(&AnsiString, NULL);
AnsiString.Buffer = lpData; AnsiString.Buffer = lpData;
AnsiString.MaximumLength = *lpcbData; AnsiString.MaximumLength = *lpcbData;
RtlUnicodeStringToAnsiString(&AnsiString, &ValueData, FALSE); RtlUnicodeStringToAnsiString(&AnsiString, &ValueData, FALSE);
*lpcbData = ValueData.Length / sizeof(WCHAR);
} else { } else {
RtlMoveMemory(lpData, ValueData.Buffer, ResultSize); RtlMoveMemory(lpData, ValueData.Buffer, *lpcbData);
*lpcbData = ValueData.Length;
} }
} }
if (lpcbData) {
*lpcbData = ResultSize; if (ValueData.Buffer)
} {
if (ValueData.Buffer) {
RtlFreeHeap(ProcessHeap, 0, ValueData.Buffer); RtlFreeHeap(ProcessHeap, 0, ValueData.Buffer);
} }
return ErrorCode; return ErrorCode;
} }