mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-22 14:48:29 +00:00
This commit is contained in:
parent
27b73038eb
commit
081c20dc33
@ -31,7 +31,7 @@ slowbash = {
|
||||
local source = config.source .. event.pathbasename
|
||||
local target = config.target .. event.pathbasename
|
||||
log("Normal", "create from ", source, " -> ", target)
|
||||
return shell(prefix..[[cp "$1" "$2"]], source, target)
|
||||
return shell(prefix..[[cp -r "$1" "$2"]], source, target)
|
||||
end,
|
||||
|
||||
onModify = function(config, event)
|
||||
@ -39,14 +39,14 @@ slowbash = {
|
||||
local source = config.source .. event.pathbasename
|
||||
local target = config.target .. event.pathbasename
|
||||
log("Normal", "modify from ", source, " -> ", target)
|
||||
return shell(prefix..[[cp "$1" "$2"]], source, target)
|
||||
return shell(prefix..[[cp -r "$1" "$2"]], source, target)
|
||||
end,
|
||||
|
||||
onDelete = function(config, event)
|
||||
-- similar for deletes
|
||||
local target = config.target .. event.pathbasename
|
||||
log("Normal", "delete ", target)
|
||||
return shell(prefix..[[rm "$1"]], target)
|
||||
return shell(prefix..[[rm -rf "$1"]], target)
|
||||
end,
|
||||
}
|
||||
|
||||
|
51
lsyncd.c
51
lsyncd.c
@ -346,6 +346,7 @@ printlogf0(lua_State *L,
|
||||
lua_pop(L, 1);
|
||||
return;
|
||||
}
|
||||
|
||||
/*****************************************************************************
|
||||
* Simple memory management
|
||||
****************************************************************************/
|
||||
@ -562,13 +563,26 @@ l_exec(lua_State *L)
|
||||
pid_t pid;
|
||||
int i;
|
||||
char const **argv = s_calloc(argc + 2, sizeof(char *));
|
||||
|
||||
if (check_logcat("Exec") >= settings.log_level) {
|
||||
lua_pushvalue(L, 1);
|
||||
for(i = 1; i <= argc; i++) {
|
||||
lua_pushstring(L, " [");
|
||||
lua_pushvalue(L, i + 1);
|
||||
lua_pushstring(L, "]");
|
||||
}
|
||||
lua_concat(L, 3 * argc + 1);
|
||||
logstring0(LOG_DEBUG, "Exec", luaL_checkstring(L, -1));
|
||||
lua_pop(L, 1);
|
||||
}
|
||||
|
||||
|
||||
argv[0] = binary;
|
||||
for(i = 1; i <= argc; i++) {
|
||||
argv[i] = luaL_checkstring(L, i + 1);
|
||||
}
|
||||
argv[i] = NULL;
|
||||
|
||||
|
||||
pid = fork();
|
||||
|
||||
if (pid == 0) {
|
||||
@ -1180,38 +1194,11 @@ masterloop(lua_State *L)
|
||||
lua_pop(L, 1);
|
||||
}
|
||||
|
||||
/* writes status of lsyncd in a file */
|
||||
/* this is not a real loop, it will only be runned once max.
|
||||
* this is just using break as comfortable jump down. */
|
||||
while (settings.statusfile) {
|
||||
int fd = open(settings.statusfile,
|
||||
O_WRONLY | O_CREAT | O_TRUNC, 0664);
|
||||
if (fd < 0) {
|
||||
printlogf(L, "Error",
|
||||
"Cannot open statusfile '%s' for writing.",
|
||||
settings.statusfile);
|
||||
break;
|
||||
}
|
||||
/* calls the lua runner to write the status. */
|
||||
printlogf(L, "Call", "lysncd_status_report()");
|
||||
lua_getglobal(L, "lsyncd_call_error");
|
||||
lua_getglobal(L, "lsyncd_status_report");
|
||||
lua_pushinteger(L, fd);
|
||||
if (lua_pcall(L, 1, 0, -3)) {
|
||||
exit(-1); // ERRNO
|
||||
}
|
||||
lua_pop(L, 1);
|
||||
|
||||
/* TODO */
|
||||
fsync(fd);
|
||||
close(fd);
|
||||
break;
|
||||
}
|
||||
|
||||
/* lets the runner spawn new processes */
|
||||
printlogf(L, "Call", "lsyncd_alarm()");
|
||||
/* lets the runner do stuff every cycle,
|
||||
* like starting new processes, writing the statusfile etc. */
|
||||
printlogf(L, "Call", "lsyncd_cycle()");
|
||||
lua_getglobal(L, "lsyncd_call_error");
|
||||
lua_getglobal(L, "lsyncd_alarm");
|
||||
lua_getglobal(L, "lsyncd_cycle");
|
||||
lua_pushinteger(L, times(NULL));
|
||||
if (lua_pcall(L, 1, 0, -3)) {
|
||||
exit(-1); // ERRNO
|
||||
|
100
lsyncd.lua
100
lsyncd.lua
@ -416,44 +416,36 @@ local Inotifies = (function()
|
||||
-----
|
||||
-- Adds watches for a directory including all subdirectories.
|
||||
--
|
||||
-- @param root root directory to observer
|
||||
-- @param origin link to the observer to be notified.
|
||||
-- Note: Inotifies should handle this opaquely
|
||||
-- @param recurse true if recursing into subdirs
|
||||
-- or the relative path to root for recurse
|
||||
--
|
||||
local function add(root, origin, recurse)
|
||||
log("Function", "Inotifies.add(", root, ", ", origin, ", ", recurse, ")")
|
||||
-- register watch and receive watch descriptor
|
||||
local dir
|
||||
if type(recurse) == "string" then
|
||||
dir = root..recurse
|
||||
else
|
||||
dir = root
|
||||
if recurse then
|
||||
recurse = ""
|
||||
end
|
||||
end
|
||||
local wd = lsyncd.add_watch(dir);
|
||||
-- @param root+path directory to observe
|
||||
-- @param recurse true if recursing into subdirs or
|
||||
-- the relative path to root for recursed inotifies
|
||||
-- @param origin link to the observer to be notified.
|
||||
-- Note: Inotifies should handle this opaquely
|
||||
local function add(root, path, recurse, origin)
|
||||
log("Function",
|
||||
"Inotifies.add(",root,", ",path,", ",recurse,", ",origin,")")
|
||||
-- registers watch
|
||||
local wd = lsyncd.add_watch(root .. path);
|
||||
if wd < 0 then
|
||||
-- failed adding the watch
|
||||
log("Error", "Failure adding watch ", dir, " -> ignored ")
|
||||
log("Error","Failure adding watch ",dir," -> ignored ")
|
||||
return
|
||||
end
|
||||
|
||||
local ilist = wdlist[wd]
|
||||
if not ilist then
|
||||
ilist = Array.new()
|
||||
wdlist[wd] = ilist
|
||||
if not wdlist[wd] then
|
||||
wdlist[wd] = Array.new()
|
||||
end
|
||||
local inotify = { root = root, path = recurse, origin = origin }
|
||||
table.insert(ilist, inotify)
|
||||
table.insert(wdlist[wd], {
|
||||
root = root,
|
||||
path = path,
|
||||
recurse = recurse,
|
||||
origin = origin
|
||||
})
|
||||
|
||||
-- registers and adds watches for all subdirectories
|
||||
if recurse then
|
||||
local subdirs = lsyncd.sub_dirs(dir)
|
||||
local subdirs = lsyncd.sub_dirs(root .. path)
|
||||
for _, dirname in ipairs(subdirs) do
|
||||
add(root, origin, recurse..dirname.."/")
|
||||
add(root, path..dirname.."/", true, origin)
|
||||
end
|
||||
end
|
||||
end
|
||||
@ -503,7 +495,7 @@ local Inotifies = (function()
|
||||
-- adds subdirs for new directories
|
||||
if inotify.recurse and isdir then
|
||||
if ename == "Create" then
|
||||
add(inotify.root, inotify.origin, pathname)
|
||||
add(inotify.root, pathname, true, inotify.origin)
|
||||
elseif ename == "Delete" then
|
||||
-- TODO
|
||||
end
|
||||
@ -514,15 +506,16 @@ local Inotifies = (function()
|
||||
-----
|
||||
-- Writes a status report about inotifies to a filedescriptor
|
||||
--
|
||||
local function status_report(fd)
|
||||
local w = lsyncd.writefd
|
||||
w(fd, "Watching ", wdlist:size(), " directories\n")
|
||||
local function status_report(f)
|
||||
f:write("Watching ",wdlist:size()," directories\n")
|
||||
for wd, v in wdlist:iwalk() do
|
||||
w(fd, " ", wd, ": ")
|
||||
f:write(" ",wd,": ")
|
||||
local sep = ""
|
||||
for _, v in ipairs(v) do
|
||||
w(fd, "(", v.root, "/", (v.path) or ")")
|
||||
f:write(v.root,"/",v.path or "",sep)
|
||||
sep = ", "
|
||||
end
|
||||
w(fd, "\n")
|
||||
f:write("\n")
|
||||
end
|
||||
end
|
||||
|
||||
@ -629,7 +622,7 @@ local Inlet, inlet_control = (function()
|
||||
|
||||
pathbasename = function()
|
||||
if string.byte(delay.pathname, -1) == 47 then
|
||||
return string.sub(delay.pathname, 1, -1)
|
||||
return string.sub(delay.pathname, 1, -2)
|
||||
else
|
||||
return delay.pathname
|
||||
end
|
||||
@ -702,21 +695,34 @@ end
|
||||
----
|
||||
-- Called from core to get a status report written into a file descriptor
|
||||
--
|
||||
function lsyncd_status_report(fd)
|
||||
local w = lsyncd.writefd
|
||||
w(fd, "Lsyncd status report at ", os.date(), "\n\n")
|
||||
Inotifies.status_report(fd)
|
||||
local function write_statusfile()
|
||||
local f, err = io.open(settings.statusfile, "w")
|
||||
if not f then
|
||||
log("Error", "Cannot open statusfile '"..settings.statusfile..
|
||||
"' :"..err)
|
||||
return
|
||||
end
|
||||
f:write("Lsyncd status report at ", os.date(), "\n\n")
|
||||
Inotifies.status_report(f)
|
||||
f:close()
|
||||
end
|
||||
|
||||
----
|
||||
-- Called from core everytime at the latest of an
|
||||
-- expired alarm (or more often)
|
||||
-- Called from core everytime a masterloop cycle runs through.
|
||||
-- This happens in case of
|
||||
-- * an expired alarm.
|
||||
-- * a returned child process.
|
||||
-- * received inotify events.
|
||||
-- * received a HUP or TERM signal.
|
||||
--
|
||||
-- @param now the time now
|
||||
-- @param now the current kernel time (in jiffies)
|
||||
--
|
||||
function lsyncd_alarm(now)
|
||||
function lsyncd_cycle(now)
|
||||
-- goes through all targets and spawns more actions
|
||||
-- if possible
|
||||
if settings.statusfile then
|
||||
write_statusfile()
|
||||
end
|
||||
for _, o in Origins.iwalk() do
|
||||
if o.processes:size() < o.config.max_processes then
|
||||
local delays = o.delays
|
||||
@ -856,7 +862,7 @@ function lsyncd_initialize()
|
||||
have_startup = true
|
||||
end
|
||||
-- adds the dir watch inclusively all subdirs
|
||||
Inotifies.add(o.source, o, true)
|
||||
Inotifies.add(o.source, "", true, o)
|
||||
end
|
||||
|
||||
-- from now on use logging as configured instead of stdout/err.
|
||||
@ -904,7 +910,7 @@ function lsyncd_get_alarm()
|
||||
end
|
||||
end
|
||||
end
|
||||
log("Debug", "lysncd_get_alarm returns: ", have_alarm, ", ", alarm)
|
||||
log("Debug", "lysncd_get_alarm returns: ",have_alarm,", ",alarm)
|
||||
return have_alarm, alarm
|
||||
end
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user