Detlef Riekenberg : spoolss: Implement GetPrinterDriverDirectoryW.
Alexandre Julliard
julliard at winehq.org
Fri Feb 27 10:02:37 CST 2009
Module: wine
Branch: master
Commit: 8f8dbcd82f3e716338810b424a2ab7787da738d2
URL: http://source.winehq.org/git/wine.git/?a=commit;h=8f8dbcd82f3e716338810b424a2ab7787da738d2
Author: Detlef Riekenberg <wine.dev at web.de>
Date: Fri Feb 27 05:31:23 2009 +0100
spoolss: Implement GetPrinterDriverDirectoryW.
---
dlls/spoolss/router.c | 55 +++++++++++++++++++++++++++++++++++++++++++++
dlls/spoolss/spoolss.spec | 2 +-
2 files changed, 56 insertions(+), 1 deletions(-)
diff --git a/dlls/spoolss/router.c b/dlls/spoolss/router.c
index f4e8e96..28871b1 100644
--- a/dlls/spoolss/router.c
+++ b/dlls/spoolss/router.c
@@ -399,3 +399,58 @@ BOOL WINAPI EnumPortsW(LPWSTR pName, DWORD Level, LPBYTE pPorts, DWORD cbBuf,
return (res == ROUTER_SUCCESS);
}
+
+/******************************************************************
+ * GetPrinterDriverDirectoryW (spoolss.@)
+ *
+ * Return the PATH for the Printer-Drivers
+ *
+ * PARAMS
+ * pName [I] Servername or NULL (local Computer)
+ * pEnvironment [I] Printing-Environment or NULL (Default)
+ * Level [I] Structure-Level (must be 1)
+ * pDriverDirectory [O] PTR to Buffer that receives the Result
+ * cbBuf [I] Size of Buffer at pDriverDirectory
+ * pcbNeeded [O] PTR to DWORD that receives the size in Bytes used /
+ * required for pDriverDirectory
+ *
+ * RETURNS
+ * Success: TRUE and in pcbNeeded the Bytes used in pDriverDirectory
+ * Failure: FALSE and in pcbNeeded the Bytes required for pDriverDirectory,
+ * if cbBuf is too small
+ *
+ * Native Values returned in pDriverDirectory on Success:
+ *| NT(Windows NT x86): "%winsysdir%\\spool\\DRIVERS\\w32x86"
+ *| NT(Windows x64): "%winsysdir%\\spool\\DRIVERS\\x64"
+ *| NT(Windows 4.0): "%winsysdir%\\spool\\DRIVERS\\win40"
+ *| win9x(Windows 4.0): "%winsysdir%"
+ *
+ * "%winsysdir%" is the Value from GetSystemDirectoryW()
+ *
+ */
+BOOL WINAPI GetPrinterDriverDirectoryW(LPWSTR pName, LPWSTR pEnvironment,
+ DWORD Level, LPBYTE pDriverDirectory, DWORD cbBuf, LPDWORD pcbNeeded)
+{
+ backend_t * pb;
+ DWORD res = ROUTER_UNKNOWN;
+
+ TRACE("(%s, %s, %d, %p, %d, %p)\n", debugstr_w(pName),
+ debugstr_w(pEnvironment), Level, pDriverDirectory, cbBuf, pcbNeeded);
+
+ if (pcbNeeded) *pcbNeeded = 0;
+
+ pb = backend_first(pName);
+ if (pb && pb->fpGetPrinterDriverDirectory)
+ res = pb->fpGetPrinterDriverDirectory(pName, pEnvironment, Level,
+ pDriverDirectory, cbBuf, pcbNeeded);
+ else
+ {
+ SetLastError(ERROR_PROC_NOT_FOUND);
+ }
+
+ TRACE("got %u with %u (%u byte)\n",
+ res, GetLastError(), pcbNeeded ? *pcbNeeded : 0);
+
+ return (res == ROUTER_SUCCESS);
+
+}
diff --git a/dlls/spoolss/spoolss.spec b/dlls/spoolss/spoolss.spec
index 2b5fc19..010b490 100644
--- a/dlls/spoolss/spoolss.spec
+++ b/dlls/spoolss/spoolss.spec
@@ -68,7 +68,7 @@
@ stub GetPrintProcessorDirectoryW
@ stub GetPrinterDataExW
@ stub GetPrinterDataW
-@ stub GetPrinterDriverDirectoryW
+@ stdcall GetPrinterDriverDirectoryW(wstr wstr long ptr long ptr)
@ stub GetPrinterDriverExW
@ stub GetPrinterDriverW
@ stub GetPrinterW
More information about the wine-cvs
mailing list