winspool: Remove unvarying unicode parameter from WINSPOOL_GetStringFromReg.

This commit is contained in:
Jeremy White 2009-12-01 10:46:27 -06:00 committed by Alexandre Julliard
parent b378e0a3d4
commit c0238d96b4
1 changed files with 36 additions and 60 deletions

View File

@ -3224,34 +3224,26 @@ static BOOL get_filename_from_reg(HKEY hkey, LPCWSTR driverdir, DWORD dirlen, LP
* WINSPOOL_GetStringFromReg * WINSPOOL_GetStringFromReg
* *
* Get ValueName from hkey storing result in ptr. buflen is space left in ptr * Get ValueName from hkey storing result in ptr. buflen is space left in ptr
* String is stored either as unicode or ascii. * String is stored as unicode.
* Bit of a hack here to get the ValueName if we want ascii.
*/ */
static BOOL WINSPOOL_GetStringFromReg(HKEY hkey, LPCWSTR ValueName, LPBYTE ptr, static BOOL WINSPOOL_GetStringFromReg(HKEY hkey, LPCWSTR ValueName, LPBYTE ptr,
DWORD buflen, DWORD *needed, DWORD buflen, DWORD *needed)
BOOL unicode)
{ {
DWORD sz = buflen, type; DWORD sz = buflen, type;
LONG ret; LONG ret;
if(unicode)
ret = RegQueryValueExW(hkey, ValueName, 0, &type, ptr, &sz); ret = RegQueryValueExW(hkey, ValueName, 0, &type, ptr, &sz);
else {
LPSTR ValueNameA = strdupWtoA(ValueName);
ret = RegQueryValueExA(hkey, ValueNameA, 0, &type, ptr, &sz);
HeapFree(GetProcessHeap(),0,ValueNameA);
}
if(ret != ERROR_SUCCESS && ret != ERROR_MORE_DATA) { if(ret != ERROR_SUCCESS && ret != ERROR_MORE_DATA) {
WARN("Got ret = %d\n", ret); WARN("Got ret = %d\n", ret);
*needed = 0; *needed = 0;
return FALSE; return FALSE;
} }
/* add space for terminating '\0' */ /* add space for terminating '\0' */
sz += unicode ? sizeof(WCHAR) : 1; sz += sizeof(WCHAR);
*needed = sz; *needed = sz;
if (ptr) if (ptr)
TRACE("%s: %s\n", debugstr_w(ValueName), unicode ? debugstr_w((LPCWSTR)ptr) : debugstr_a((LPCSTR)ptr)); TRACE("%s: %s\n", debugstr_w(ValueName), debugstr_w((LPCWSTR)ptr));
return TRUE; return TRUE;
} }
@ -3384,8 +3376,7 @@ static BOOL WINSPOOL_GetPrinter_1(HKEY hkeyPrinter, PRINTER_INFO_1W *pi1,
*pcbNeeded = 0; *pcbNeeded = 0;
if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi1->pName = (LPWSTR)ptr; pi1->pName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3396,8 +3387,7 @@ static BOOL WINSPOOL_GetPrinter_1(HKEY hkeyPrinter, PRINTER_INFO_1W *pi1,
} }
/* FIXME: pDescription should be something like "Name,Driver_Name,". */ /* FIXME: pDescription should be something like "Name,Driver_Name,". */
if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi1->pDescription = (LPWSTR)ptr; pi1->pDescription = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3407,8 +3397,7 @@ static BOOL WINSPOOL_GetPrinter_1(HKEY hkeyPrinter, PRINTER_INFO_1W *pi1,
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, DescriptionW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, DescriptionW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi1->pComment = (LPWSTR)ptr; pi1->pComment = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3439,8 +3428,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
*pcbNeeded = 0; *pcbNeeded = 0;
if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pPrinterName = (LPWSTR)ptr; pi2->pPrinterName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3449,8 +3437,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, Share_NameW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, Share_NameW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pShareName = (LPWSTR)ptr; pi2->pShareName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3459,8 +3446,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, PortW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, PortW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pPortName = (LPWSTR)ptr; pi2->pPortName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3469,8 +3455,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, Printer_DriverW, ptr, left, if(WINSPOOL_GetStringFromReg(hkeyPrinter, Printer_DriverW, ptr, left, &size)) {
&size, TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pDriverName = (LPWSTR)ptr; pi2->pDriverName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3479,8 +3464,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, DescriptionW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, DescriptionW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pComment = (LPWSTR)ptr; pi2->pComment = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3489,8 +3473,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, LocationW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, LocationW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pLocation = (LPWSTR)ptr; pi2->pLocation = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3520,8 +3503,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, Separator_FileW, ptr, left, if(WINSPOOL_GetStringFromReg(hkeyPrinter, Separator_FileW, ptr, left, &size)) {
&size, TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pSepFile = (LPWSTR)ptr; pi2->pSepFile = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3530,8 +3512,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, Print_ProcessorW, ptr, left, if(WINSPOOL_GetStringFromReg(hkeyPrinter, Print_ProcessorW, ptr, left, &size)) {
&size, TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pPrintProcessor = (LPWSTR)ptr; pi2->pPrintProcessor = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3540,8 +3521,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, DatatypeW, ptr, left, if(WINSPOOL_GetStringFromReg(hkeyPrinter, DatatypeW, ptr, left, &size)) {
&size, TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pDatatype = (LPWSTR)ptr; pi2->pDatatype = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3550,8 +3530,7 @@ static BOOL WINSPOOL_GetPrinter_2(HKEY hkeyPrinter, PRINTER_INFO_2W *pi2,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, ParametersW, ptr, left, if(WINSPOOL_GetStringFromReg(hkeyPrinter, ParametersW, ptr, left, &size)) {
&size, TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi2->pParameters = (LPWSTR)ptr; pi2->pParameters = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3589,8 +3568,7 @@ static BOOL WINSPOOL_GetPrinter_4(HKEY hkeyPrinter, PRINTER_INFO_4W *pi4,
*pcbNeeded = 0; *pcbNeeded = 0;
if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi4->pPrinterName = (LPWSTR)ptr; pi4->pPrinterName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3623,8 +3601,7 @@ static BOOL WINSPOOL_GetPrinter_5(HKEY hkeyPrinter, PRINTER_INFO_5W *pi5,
*pcbNeeded = 0; *pcbNeeded = 0;
if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, NameW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi5->pPrinterName = (LPWSTR)ptr; pi5->pPrinterName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3633,8 +3610,7 @@ static BOOL WINSPOOL_GetPrinter_5(HKEY hkeyPrinter, PRINTER_INFO_5W *pi5,
space = FALSE; space = FALSE;
*pcbNeeded += size; *pcbNeeded += size;
} }
if(WINSPOOL_GetStringFromReg(hkeyPrinter, PortW, ptr, left, &size, if(WINSPOOL_GetStringFromReg(hkeyPrinter, PortW, ptr, left, &size)) {
TRUE)) {
if(space && size <= left) { if(space && size <= left) {
pi5->pPortName = (LPWSTR)ptr; pi5->pPortName = (LPWSTR)ptr;
ptr += size; ptr += size;
@ -3671,7 +3647,7 @@ static BOOL WINSPOOL_GetPrinter_7(HKEY hkeyPrinter, PRINTER_INFO_7W *pi7, LPBYTE
*pcbNeeded = 0; *pcbNeeded = 0;
if (! WINSPOOL_GetStringFromReg(hkeyPrinter, ObjectGUIDW, ptr, left, &size, TRUE)) if (! WINSPOOL_GetStringFromReg(hkeyPrinter, ObjectGUIDW, ptr, left, &size))
{ {
ptr = NULL; ptr = NULL;
size = sizeof(pi7->pszObjectGUID); size = sizeof(pi7->pszObjectGUID);
@ -4315,20 +4291,20 @@ static BOOL WINSPOOL_GetDriverInfoFromReg(
} }
/* .pMonitorName is the optional Language Monitor */ /* .pMonitorName is the optional Language Monitor */
if (WINSPOOL_GetStringFromReg(hkeyDriver, MonitorW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, MonitorW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if (*pcbNeeded <= cbBuf) if (*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, MonitorW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, MonitorW, strPtr, size, &size);
if (di) di->pMonitorName = (LPWSTR)strPtr; if (di) di->pMonitorName = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;
} }
/* .pDefaultDataType */ /* .pDefaultDataType */
if (WINSPOOL_GetStringFromReg(hkeyDriver, DatatypeW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, DatatypeW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if(*pcbNeeded <= cbBuf) if(*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, DatatypeW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, DatatypeW, strPtr, size, &size);
if (di) di->pDefaultDataType = (LPWSTR)strPtr; if (di) di->pDefaultDataType = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;
@ -4341,10 +4317,10 @@ static BOOL WINSPOOL_GetDriverInfoFromReg(
} }
/* .pszzPreviousNames */ /* .pszzPreviousNames */
if (WINSPOOL_GetStringFromReg(hkeyDriver, Previous_NamesW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, Previous_NamesW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if(*pcbNeeded <= cbBuf) if(*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, Previous_NamesW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, Previous_NamesW, strPtr, size, &size);
if (di) di->pszzPreviousNames = (LPWSTR)strPtr; if (di) di->pszzPreviousNames = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;
@ -4360,40 +4336,40 @@ static BOOL WINSPOOL_GetDriverInfoFromReg(
TRACE("%s: DriverDate + DriverVersion not supported\n", debugstr_w(DriverName)); TRACE("%s: DriverDate + DriverVersion not supported\n", debugstr_w(DriverName));
/* .pszMfgName */ /* .pszMfgName */
if (WINSPOOL_GetStringFromReg(hkeyDriver, ManufacturerW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, ManufacturerW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if(*pcbNeeded <= cbBuf) if(*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, ManufacturerW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, ManufacturerW, strPtr, size, &size);
if (di) di->pszMfgName = (LPWSTR)strPtr; if (di) di->pszMfgName = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;
} }
/* .pszOEMUrl */ /* .pszOEMUrl */
if (WINSPOOL_GetStringFromReg(hkeyDriver, OEM_UrlW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, OEM_UrlW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if(*pcbNeeded <= cbBuf) if(*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, OEM_UrlW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, OEM_UrlW, strPtr, size, &size);
if (di) di->pszOEMUrl = (LPWSTR)strPtr; if (di) di->pszOEMUrl = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;
} }
/* .pszHardwareID */ /* .pszHardwareID */
if (WINSPOOL_GetStringFromReg(hkeyDriver, HardwareIDW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, HardwareIDW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if(*pcbNeeded <= cbBuf) if(*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, HardwareIDW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, HardwareIDW, strPtr, size, &size);
if (di) di->pszHardwareID = (LPWSTR)strPtr; if (di) di->pszHardwareID = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;
} }
/* .pszProvider */ /* .pszProvider */
if (WINSPOOL_GetStringFromReg(hkeyDriver, ProviderW, strPtr, 0, &size, TRUE)) { if (WINSPOOL_GetStringFromReg(hkeyDriver, ProviderW, strPtr, 0, &size)) {
*pcbNeeded += size; *pcbNeeded += size;
if(*pcbNeeded <= cbBuf) if(*pcbNeeded <= cbBuf)
WINSPOOL_GetStringFromReg(hkeyDriver, ProviderW, strPtr, size, &size, TRUE); WINSPOOL_GetStringFromReg(hkeyDriver, ProviderW, strPtr, size, &size);
if (di) di->pszProvider = (LPWSTR)strPtr; if (di) di->pszProvider = (LPWSTR)strPtr;
strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL; strPtr = (pDriverStrings) ? pDriverStrings + (*pcbNeeded) : NULL;