localspl: Implement fpAddPortEx.
This commit is contained in:
parent
52570539d8
commit
cb6f9bbdb2
@ -1523,6 +1523,70 @@ static BOOL WINAPI fpAddPort(LPWSTR pName, HWND hWnd, LPWSTR pMonitorName)
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* fpAddPortEx [exported through PRINTPROVIDOR]
|
||||||
|
*
|
||||||
|
* Add a Port for a specific Monitor, without presenting a user interface
|
||||||
|
*
|
||||||
|
* PARAMS
|
||||||
|
* pName [I] Servername or NULL (local Computer)
|
||||||
|
* level [I] Structure-Level (1 or 2) for pBuffer
|
||||||
|
* pBuffer [I] PTR to: PORT_INFO_1 or PORT_INFO_2
|
||||||
|
* pMonitorName [I] Name of the Monitor that manage the Port
|
||||||
|
*
|
||||||
|
* RETURNS
|
||||||
|
* Success: TRUE
|
||||||
|
* Failure: FALSE
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static BOOL WINAPI fpAddPortEx(LPWSTR pName, DWORD level, LPBYTE pBuffer, LPWSTR pMonitorName)
|
||||||
|
{
|
||||||
|
PORT_INFO_2W * pi2;
|
||||||
|
monitor_t * pm;
|
||||||
|
DWORD lres;
|
||||||
|
DWORD res;
|
||||||
|
|
||||||
|
pi2 = (PORT_INFO_2W *) pBuffer;
|
||||||
|
|
||||||
|
TRACE("(%s, %d, %p, %s): %s %s %s\n", debugstr_w(pName), level, pBuffer,
|
||||||
|
debugstr_w(pMonitorName), debugstr_w(pi2 ? pi2->pPortName : NULL),
|
||||||
|
debugstr_w(((level > 1) && pi2) ? pi2->pMonitorName : NULL),
|
||||||
|
debugstr_w(((level > 1) && pi2) ? pi2->pDescription : NULL));
|
||||||
|
|
||||||
|
lres = copy_servername_from_name(pName, NULL);
|
||||||
|
if (lres) {
|
||||||
|
FIXME("server %s not supported\n", debugstr_w(pName));
|
||||||
|
SetLastError(ERROR_INVALID_PARAMETER);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((level < 1) || (level > 2)) {
|
||||||
|
SetLastError(ERROR_INVALID_LEVEL);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((!pi2) || (!pMonitorName) || (!pMonitorName[0])) {
|
||||||
|
SetLastError(ERROR_INVALID_PARAMETER);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* load the Monitor */
|
||||||
|
pm = monitor_load(pMonitorName, NULL);
|
||||||
|
if (pm && pm->monitor && pm->monitor->pfnAddPortEx) {
|
||||||
|
res = pm->monitor->pfnAddPortEx(pName, level, pBuffer, pMonitorName);
|
||||||
|
TRACE("got %d with %u (%s)\n", res, GetLastError(), debugstr_w(pm->dllname));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FIXME("not implemented for %s (monitor %p: %s)\n",
|
||||||
|
debugstr_w(pMonitorName), pm, pm ? debugstr_w(pm->dllname) : NULL);
|
||||||
|
SetLastError(ERROR_INVALID_PARAMETER);
|
||||||
|
res = FALSE;
|
||||||
|
}
|
||||||
|
monitor_unload(pm);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* fpAddPrinterDriverEx [exported through PRINTPROVIDOR]
|
* fpAddPrinterDriverEx [exported through PRINTPROVIDOR]
|
||||||
*
|
*
|
||||||
@ -2098,7 +2162,7 @@ void setup_provider(void)
|
|||||||
NULL, /* fpGetPrinterDriverEx */
|
NULL, /* fpGetPrinterDriverEx */
|
||||||
NULL, /* fpFindFirstPrinterChangeNotification */
|
NULL, /* fpFindFirstPrinterChangeNotification */
|
||||||
NULL, /* fpFindClosePrinterChangeNotification */
|
NULL, /* fpFindClosePrinterChangeNotification */
|
||||||
NULL, /* fpAddPortEx */
|
fpAddPortEx,
|
||||||
NULL, /* fpShutDown */
|
NULL, /* fpShutDown */
|
||||||
NULL, /* fpRefreshPrinterChangeNotification */
|
NULL, /* fpRefreshPrinterChangeNotification */
|
||||||
NULL, /* fpOpenPrinterEx */
|
NULL, /* fpOpenPrinterEx */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user