Commit 351106f5 authored by Detlef Riekenberg's avatar Detlef Riekenberg Committed by Alexandre Julliard

winspool: Do not fail in OpenPrinter on pDefault / local print server.

parent b7a62e56
...@@ -132,6 +132,12 @@ static const WCHAR MonitorsW[] = { 'S','y','s','t','e','m','\\', ...@@ -132,6 +132,12 @@ static const WCHAR MonitorsW[] = { 'S','y','s','t','e','m','\\',
'P','r','i','n','t','\\', 'P','r','i','n','t','\\',
'M','o','n','i','t','o','r','s',0}; 'M','o','n','i','t','o','r','s',0};
static const WCHAR PrintersW[] = {'S','y','s','t','e','m','\\',
'C','u', 'r','r','e','n','t','C','o','n','t','r','o','l','S','e','t','\\',
'C','o','n','t','r','o','l','\\',
'P','r','i','n','t','\\',
'P','r','i','n','t','e','r','s',0};
static const WCHAR LocalPortW[] = {'L','o','c','a','l',' ','P','o','r','t',0}; static const WCHAR LocalPortW[] = {'L','o','c','a','l',' ','P','o','r','t',0};
static const WCHAR user_default_reg_key[] = { 'S','o','f','t','w','a','r','e','\\', static const WCHAR user_default_reg_key[] = { 'S','o','f','t','w','a','r','e','\\',
...@@ -776,12 +782,15 @@ static DWORD get_local_monitors(DWORD level, LPBYTE pMonitors, DWORD cbBuf, LPDW ...@@ -776,12 +782,15 @@ static DWORD get_local_monitors(DWORD level, LPBYTE pMonitors, DWORD cbBuf, LPDW
/****************************************************************** /******************************************************************
* get_opened_printer_entry * get_opened_printer_entry
* Get the first place empty in the opened printer table * Get the first place empty in the opened printer table
*
* ToDo:
* - pDefault is ignored
*/ */
static HANDLE get_opened_printer_entry( LPCWSTR name ) static HANDLE get_opened_printer_entry(LPCWSTR name, LPPRINTER_DEFAULTSW pDefault)
{ {
UINT_PTR handle = nb_printer_handles, i; UINT_PTR handle = nb_printer_handles, i;
jobqueue_t *queue = NULL; jobqueue_t *queue = NULL;
opened_printer_t *printer; opened_printer_t *printer = NULL;
EnterCriticalSection(&printer_handles_cs); EnterCriticalSection(&printer_handles_cs);
...@@ -792,9 +801,12 @@ static HANDLE get_opened_printer_entry( LPCWSTR name ) ...@@ -792,9 +801,12 @@ static HANDLE get_opened_printer_entry( LPCWSTR name )
if(handle == nb_printer_handles) if(handle == nb_printer_handles)
handle = i; handle = i;
} }
else if(!queue && !strcmpW(name, printer_handles[i]->name)) else
{
if(!queue && (name) && !lstrcmpW(name, printer_handles[i]->name))
queue = printer_handles[i]->queue; queue = printer_handles[i]->queue;
} }
}
if (handle >= nb_printer_handles) if (handle >= nb_printer_handles)
{ {
...@@ -815,29 +827,45 @@ static HANDLE get_opened_printer_entry( LPCWSTR name ) ...@@ -815,29 +827,45 @@ static HANDLE get_opened_printer_entry( LPCWSTR name )
nb_printer_handles += 16; nb_printer_handles += 16;
} }
if (!(printer = HeapAlloc(GetProcessHeap(), 0, sizeof(*printer)))) if (!(printer = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*printer))))
{ {
handle = 0; handle = 0;
goto end; goto end;
} }
if(name) {
printer->name = HeapAlloc(GetProcessHeap(), 0, (strlenW(name) + 1) * sizeof(WCHAR)); printer->name = HeapAlloc(GetProcessHeap(), 0, (strlenW(name) + 1) * sizeof(WCHAR));
if (!printer->name) {
handle = 0;
goto end;
}
strcpyW(printer->name, name); strcpyW(printer->name, name);
}
if(queue) if(queue)
printer->queue = queue; printer->queue = queue;
else else
{ {
printer->queue = HeapAlloc(GetProcessHeap(), 0, sizeof(*queue)); printer->queue = HeapAlloc(GetProcessHeap(), 0, sizeof(*queue));
if (!printer->queue) {
handle = 0;
goto end;
}
list_init(&printer->queue->jobs); list_init(&printer->queue->jobs);
printer->queue->ref = 0; printer->queue->ref = 0;
} }
InterlockedIncrement(&printer->queue->ref); InterlockedIncrement(&printer->queue->ref);
printer->doc = NULL;
printer_handles[handle] = printer; printer_handles[handle] = printer;
handle++; handle++;
end: end:
LeaveCriticalSection(&printer_handles_cs); LeaveCriticalSection(&printer_handles_cs);
if (!handle && printer) {
/* Something Failed: Free the Buffers */
HeapFree(GetProcessHeap(), 0, printer->name);
if (!queue) HeapFree(GetProcessHeap(), 0, printer->queue);
HeapFree(GetProcessHeap(), 0, printer);
}
return (HANDLE)handle; return (HANDLE)handle;
} }
...@@ -1258,57 +1286,51 @@ BOOL WINAPI OpenPrinterA(LPSTR lpPrinterName,HANDLE *phPrinter, ...@@ -1258,57 +1286,51 @@ BOOL WINAPI OpenPrinterA(LPSTR lpPrinterName,HANDLE *phPrinter,
*| XcvPort: "Servername,XcvPort PortName" *| XcvPort: "Servername,XcvPort PortName"
* *
* BUGS * BUGS
*| Printserver not supported
*| Printer-Object not supported *| Printer-Object not supported
*| XcvMonitor not supported *| XcvMonitor not supported
*| XcvPort not supported *| XcvPort not supported
*| pDefaults not supported *| pDefaults is ignored
* *
*/ */
BOOL WINAPI OpenPrinterW(LPWSTR lpPrinterName,HANDLE *phPrinter, BOOL WINAPI OpenPrinterW(LPWSTR lpPrinterName,HANDLE *phPrinter, LPPRINTER_DEFAULTSW pDefault)
LPPRINTER_DEFAULTSW pDefault)
{ {
HKEY hkeyPrinters, hkeyPrinter; HKEY hkeyPrinters = NULL;
HKEY hkeyPrinter = NULL;
if (!lpPrinterName) { TRACE("(%s, %p, %p)\n", debugstr_w(lpPrinterName), phPrinter, pDefault);
FIXME("(printerName: NULL, pDefault %p Ret: False\n", pDefault); if (pDefault) {
SetLastError(ERROR_INVALID_PARAMETER); FIXME("PRINTER_DEFAULTS ignored => %s,%p,0x%08lx\n",
return FALSE; debugstr_w(pDefault->pDatatype), pDefault->pDevMode, pDefault->DesiredAccess);
} }
TRACE("(printerName: %s, pDefault %p)\n", debugstr_w(lpPrinterName), if(lpPrinterName != NULL)
pDefault); {
/* Check any Printer exists */
/* Check Printer exists */ if(RegCreateKeyW(HKEY_LOCAL_MACHINE, PrintersW, &hkeyPrinters) != ERROR_SUCCESS) {
if(RegCreateKeyA(HKEY_LOCAL_MACHINE, Printers, &hkeyPrinters) !=
ERROR_SUCCESS) {
ERR("Can't create Printers key\n"); ERR("Can't create Printers key\n");
SetLastError(ERROR_FILE_NOT_FOUND); /* ?? */ SetLastError(ERROR_FILE_NOT_FOUND);
return FALSE; return FALSE;
} }
if((lpPrinterName[0] == '\0') || /* explicitly exclude "" */
(RegOpenKeyW(hkeyPrinters, lpPrinterName, &hkeyPrinter) != ERROR_SUCCESS)) {
if(lpPrinterName[0] == '\0' || /* explicitly exclude "" */ WARN("Printer not found in Registry: '%s'\n", debugstr_w(lpPrinterName));
RegOpenKeyW(hkeyPrinters, lpPrinterName, &hkeyPrinter)
!= ERROR_SUCCESS) {
TRACE("Can't find printer %s in registry\n",
debugstr_w(lpPrinterName));
RegCloseKey(hkeyPrinters); RegCloseKey(hkeyPrinters);
SetLastError(ERROR_INVALID_PRINTER_NAME); SetLastError(ERROR_INVALID_PRINTER_NAME);
return FALSE; return FALSE;
} }
RegCloseKey(hkeyPrinter); RegCloseKey(hkeyPrinter);
RegCloseKey(hkeyPrinters); RegCloseKey(hkeyPrinters);
}
if(!phPrinter) {
/* NT: FALSE with ERROR_INVALID_PARAMETER, 9x: TRUE */
SetLastError(ERROR_INVALID_PARAMETER);
return FALSE;
}
if(!phPrinter) /* This seems to be what win95 does anyway */ /* Get the unique handle of the printer or Printserver */
return TRUE; *phPrinter = get_opened_printer_entry(lpPrinterName, pDefault);
return (*phPrinter != 0);
/* Get the unique handle of the printer*/
*phPrinter = get_opened_printer_entry( lpPrinterName );
if (pDefault != NULL)
FIXME("Not handling pDefault\n");
return TRUE;
} }
/****************************************************************** /******************************************************************
......
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