Fixed windows dirmonitor issues.
This commit is contained in:
parent
444b3e3c66
commit
6f65168b0d
|
@ -36,20 +36,20 @@ function dirwatch:watch(directory, bool)
|
||||||
if not self.watched[directory] and not self.scanned[directory] then
|
if not self.watched[directory] and not self.scanned[directory] then
|
||||||
if PLATFORM == "Windows" then
|
if PLATFORM == "Windows" then
|
||||||
if not self.windows_watch_top or directory:find(self.windows_watch_top, 1, true) ~= 1 then
|
if not self.windows_watch_top or directory:find(self.windows_watch_top, 1, true) ~= 1 then
|
||||||
-- Get the highest level of directory that is common to this directory, and the original.
|
-- Get the highest level of directory that is common to this directory, and the original.
|
||||||
local target = directory
|
local target = directory
|
||||||
while self.windows_watch_top and self.windows_watch_top:find(target, 1, true) ~= 1 do
|
while self.windows_watch_top and self.windows_watch_top:find(target, 1, true) ~= 1 do
|
||||||
target = common.dirname(target)
|
target = common.dirname(target)
|
||||||
end
|
end
|
||||||
if target ~= self.windows_watch_top then
|
if target ~= self.windows_watch_top then
|
||||||
local value = self.monitor:watch(target)
|
local value = self.monitor:watch(target)
|
||||||
if value and value < 0 then
|
if value and value < 0 then
|
||||||
return self:scan(directory)
|
return self:scan(directory)
|
||||||
|
end
|
||||||
|
self.windows_watch_top = target
|
||||||
|
end
|
||||||
end
|
end
|
||||||
self.windows_watch_top = target
|
|
||||||
self.windows_watch_count = self.windows_watch_count + 1
|
self.windows_watch_count = self.windows_watch_count + 1
|
||||||
end
|
|
||||||
end
|
|
||||||
self.watched[directory] = true
|
self.watched[directory] = true
|
||||||
else
|
else
|
||||||
local value = self.monitor:watch(directory)
|
local value = self.monitor:watch(directory)
|
||||||
|
|
|
@ -65,7 +65,7 @@ static int f_dirmonitor_watch(lua_State *L) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static int f_dirmonitor_unwatch(lua_State *L) {
|
static int f_dirmonitor_unwatch(lua_State *L) {
|
||||||
remove_dirmonitor(*(struct dirmonitor**)luaL_checkudata(L, 1, API_TYPE_DIRMONITOR), luaL_checknumber(L, 2));
|
remove_dirmonitor(*(struct dirmonitor**)luaL_checkudata(L, 1, API_TYPE_DIRMONITOR), lua_tonumber(L, 2));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
struct dirmonitor {
|
struct dirmonitor {
|
||||||
HANDLE handle;
|
HANDLE handle;
|
||||||
char buffer[8192];
|
char buffer[64512];
|
||||||
OVERLAPPED overlapped;
|
OVERLAPPED overlapped;
|
||||||
bool running;
|
bool running;
|
||||||
};
|
};
|
||||||
|
@ -52,8 +52,8 @@ int check_dirmonitor_win32(struct dirmonitor* monitor, int (*change_callback)(in
|
||||||
|
|
||||||
monitor->running = false;
|
monitor->running = false;
|
||||||
|
|
||||||
for (FILE_NOTIFY_INFORMATION* info = (FILE_NOTIFY_INFORMATION*)monitor->buffer; (char*)info < monitor->buffer + sizeof(monitor->buffer); info = (FILE_NOTIFY_INFORMATION*)((char*)info) + info->NextEntryOffset) {
|
for (FILE_NOTIFY_INFORMATION* info = (FILE_NOTIFY_INFORMATION*)monitor->buffer; (char*)info < monitor->buffer + sizeof(monitor->buffer); info = (FILE_NOTIFY_INFORMATION*)(((char*)info) + info->NextEntryOffset)) {
|
||||||
change_callback(info->FileNameLength, (char*)info->FileName, data);
|
change_callback(info->FileNameLength / sizeof(WCHAR), (char*)info->FileName, data);
|
||||||
if (!info->NextEntryOffset)
|
if (!info->NextEntryOffset)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -74,4 +74,4 @@ int add_dirmonitor_win32(struct dirmonitor* monitor, const char* path) {
|
||||||
|
|
||||||
void remove_dirmonitor_win32(struct dirmonitor* monitor, int fd) {
|
void remove_dirmonitor_win32(struct dirmonitor* monitor, int fd) {
|
||||||
close_monitor_handle(monitor);
|
close_monitor_handle(monitor);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue