Commit 6a1ce3c1 authored by Alexandre Julliard's avatar Alexandre Julliard

schedsvc: Only restart the directory watch once we've received data.

parent 5bd1b6f4
...@@ -47,9 +47,17 @@ static DWORD WINAPI tasks_monitor_thread(void *arg) ...@@ -47,9 +47,17 @@ static DWORD WINAPI tasks_monitor_thread(void *arg)
static const WCHAR tasksW[] = { '\\','T','a','s','k','s','\\',0 }; static const WCHAR tasksW[] = { '\\','T','a','s','k','s','\\',0 };
WCHAR path[MAX_PATH]; WCHAR path[MAX_PATH];
HANDLE htasks, hport, htimer; HANDLE htasks, hport, htimer;
JOBOBJECT_ASSOCIATE_COMPLETION_PORT info; JOBOBJECT_ASSOCIATE_COMPLETION_PORT job_info;
OVERLAPPED ov; OVERLAPPED ov;
LARGE_INTEGER period; LARGE_INTEGER period;
struct
{
FILE_NOTIFY_INFORMATION data;
WCHAR name_buffer[MAX_PATH];
} info;
/* the buffer must be DWORD aligned */
C_ASSERT(!(sizeof(info) & 3));
TRACE("Starting...\n"); TRACE("Starting...\n");
...@@ -91,9 +99,9 @@ static DWORD WINAPI tasks_monitor_thread(void *arg) ...@@ -91,9 +99,9 @@ static DWORD WINAPI tasks_monitor_thread(void *arg)
return -1; return -1;
} }
info.CompletionKey = hjob_queue; job_info.CompletionKey = hjob_queue;
info.CompletionPort = hport; job_info.CompletionPort = hport;
if (!SetInformationJobObject(hjob_queue, JobObjectAssociateCompletionPortInformation, &info, sizeof(info))) if (!SetInformationJobObject(hjob_queue, JobObjectAssociateCompletionPortInformation, &job_info, sizeof(job_info)))
{ {
ERR("SetInformationJobObject failed\n"); ERR("SetInformationJobObject failed\n");
return -1; return -1;
...@@ -102,29 +110,16 @@ static DWORD WINAPI tasks_monitor_thread(void *arg) ...@@ -102,29 +110,16 @@ static DWORD WINAPI tasks_monitor_thread(void *arg)
memset(&ov, 0, sizeof(ov)); memset(&ov, 0, sizeof(ov));
ov.hEvent = CreateEventW(NULL, FALSE, FALSE, NULL); ov.hEvent = CreateEventW(NULL, FALSE, FALSE, NULL);
memset(&info, 0, sizeof(info));
ReadDirectoryChangesW(htasks, &info, sizeof(info), FALSE,
FILE_NOTIFY_CHANGE_FILE_NAME | FILE_NOTIFY_CHANGE_SIZE | FILE_NOTIFY_CHANGE_LAST_WRITE,
NULL, &ov, NULL);
for (;;) for (;;)
{ {
struct
{
FILE_NOTIFY_INFORMATION data;
WCHAR name_buffer[MAX_PATH];
} info;
HANDLE events[4]; HANDLE events[4];
DWORD ret; DWORD ret;
/* the buffer must be DWORD aligned */
C_ASSERT(!(sizeof(info) & 3));
memset(&info, 0, sizeof(info));
ret = ReadDirectoryChangesW(htasks, &info, sizeof(info), FALSE,
FILE_NOTIFY_CHANGE_FILE_NAME | FILE_NOTIFY_CHANGE_SIZE | FILE_NOTIFY_CHANGE_LAST_WRITE,
NULL, &ov, NULL);
if (!ret) break;
if (info.data.NextEntryOffset)
FIXME("got multiple entries\n");
events[0] = done_event; events[0] = done_event;
events[1] = htimer; events[1] = htimer;
events[2] = hport; events[2] = hport;
...@@ -160,6 +155,9 @@ static DWORD WINAPI tasks_monitor_thread(void *arg) ...@@ -160,6 +155,9 @@ static DWORD WINAPI tasks_monitor_thread(void *arg)
continue; continue;
} }
if (info.data.NextEntryOffset)
FIXME("got multiple entries\n");
/* Directory change notification */ /* Directory change notification */
info.data.FileName[info.data.FileNameLength/sizeof(WCHAR)] = 0; info.data.FileName[info.data.FileNameLength/sizeof(WCHAR)] = 0;
...@@ -204,6 +202,11 @@ static DWORD WINAPI tasks_monitor_thread(void *arg) ...@@ -204,6 +202,11 @@ static DWORD WINAPI tasks_monitor_thread(void *arg)
if (!SetWaitableTimer(htimer, &period, 0, NULL, NULL, FALSE)) if (!SetWaitableTimer(htimer, &period, 0, NULL, NULL, FALSE))
ERR("SetWaitableTimer failed\n"); ERR("SetWaitableTimer failed\n");
} }
memset(&info, 0, sizeof(info));
if (!ReadDirectoryChangesW(htasks, &info, sizeof(info), FALSE,
FILE_NOTIFY_CHANGE_FILE_NAME | FILE_NOTIFY_CHANGE_SIZE | FILE_NOTIFY_CHANGE_LAST_WRITE,
NULL, &ov, NULL)) break;
} }
CancelWaitableTimer(htimer); CancelWaitableTimer(htimer);
......
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