winspool: Manage loaded monitors in a list.

This commit is contained in:
Detlef Riekenberg 2006-09-02 22:55:25 +02:00 committed by Alexandre Julliard
parent 1e177382a3
commit ec1c7cc0d3
1 changed files with 41 additions and 4 deletions

View File

@ -66,6 +66,18 @@
WINE_DEFAULT_DEBUG_CHANNEL(winspool); WINE_DEFAULT_DEBUG_CHANNEL(winspool);
/* ############################### */
static CRITICAL_SECTION monitor_handles_cs;
static CRITICAL_SECTION_DEBUG monitor_handles_cs_debug =
{
0, 0, &monitor_handles_cs,
{ &monitor_handles_cs_debug.ProcessLocksList, &monitor_handles_cs_debug.ProcessLocksList },
0, 0, { (DWORD_PTR)(__FILE__ ": monitor_handles_cs") }
};
static CRITICAL_SECTION monitor_handles_cs = { &monitor_handles_cs_debug, -1, 0, 0, 0, 0 };
static CRITICAL_SECTION printer_handles_cs; static CRITICAL_SECTION printer_handles_cs;
static CRITICAL_SECTION_DEBUG printer_handles_cs_debug = static CRITICAL_SECTION_DEBUG printer_handles_cs_debug =
{ {
@ -78,6 +90,7 @@ static CRITICAL_SECTION printer_handles_cs = { &printer_handles_cs_debug, -1, 0,
/* ############################### */ /* ############################### */
typedef struct { typedef struct {
struct list entry;
LPWSTR name; LPWSTR name;
LPWSTR dllname; LPWSTR dllname;
PMONITORUI monitorUI; PMONITORUI monitorUI;
@ -121,6 +134,8 @@ typedef struct {
/* ############################### */ /* ############################### */
static struct list monitor_handles = LIST_INIT( monitor_handles );
static opened_printer_t **printer_handles; static opened_printer_t **printer_handles;
static int nb_printer_handles; static int nb_printer_handles;
static LONG next_job_id = 1; static LONG next_job_id = 1;
@ -833,11 +848,19 @@ static void monitor_unload(monitor_t * pm)
{ {
TRACE("%p (refcount: %ld) %s\n", pm, pm->refcount, debugstr_w(pm->name)); TRACE("%p (refcount: %ld) %s\n", pm, pm->refcount, debugstr_w(pm->name));
EnterCriticalSection(&monitor_handles_cs);
if (pm->refcount) pm->refcount--;
if (pm->refcount == 0) {
list_remove(&pm->entry);
FreeLibrary(pm->hdll); FreeLibrary(pm->hdll);
HeapFree(GetProcessHeap(), 0, pm->name); HeapFree(GetProcessHeap(), 0, pm->name);
HeapFree(GetProcessHeap(), 0, pm->dllname); HeapFree(GetProcessHeap(), 0, pm->dllname);
HeapFree(GetProcessHeap(), 0, pm); HeapFree(GetProcessHeap(), 0, pm);
} }
LeaveCriticalSection(&monitor_handles_cs);
}
/****************************************************************** /******************************************************************
* monitor_load [internal] * monitor_load [internal]
@ -857,15 +880,28 @@ static monitor_t * monitor_load(LPWSTR name, LPWSTR dllname)
DWORD (WINAPI *pInitializeMonitor) (LPWSTR); DWORD (WINAPI *pInitializeMonitor) (LPWSTR);
monitor_t * pm = NULL; monitor_t * pm = NULL;
monitor_t * cursor;
LPWSTR regroot = NULL; LPWSTR regroot = NULL;
LPWSTR driver = dllname; LPWSTR driver = dllname;
TRACE("(%s, %s)\n", debugstr_w(name), debugstr_w(dllname)); TRACE("(%s, %s)\n", debugstr_w(name), debugstr_w(dllname));
/* Is the Monitor already loaded? */ /* Is the Monitor already loaded? */
EnterCriticalSection(&monitor_handles_cs);
LIST_FOR_EACH_ENTRY(cursor, &monitor_handles, monitor_t, entry)
{
if (lstrcmpW(name, cursor->name) == 0) {
pm = cursor;
break;
}
}
if (pm == NULL) {
pm = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(monitor_t)); pm = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(monitor_t));
if (pm == NULL) goto cleanup; if (pm == NULL) goto cleanup;
list_add_tail(&monitor_handles, &pm->entry);
}
pm->refcount++;
if (pm->name == NULL) { if (pm->name == NULL) {
/* Load the monitor */ /* Load the monitor */
@ -961,6 +997,7 @@ static monitor_t * monitor_load(LPWSTR name, LPWSTR dllname)
} }
} }
cleanup: cleanup:
LeaveCriticalSection(&monitor_handles_cs);
if (driver != dllname) HeapFree(GetProcessHeap(), 0, driver); if (driver != dllname) HeapFree(GetProcessHeap(), 0, driver);
HeapFree(GetProcessHeap(), 0, regroot); HeapFree(GetProcessHeap(), 0, regroot);
TRACE("=> %p\n", pm); TRACE("=> %p\n", pm);