This commit is contained in:
Axel Kittenberger 2010-11-13 13:44:51 +00:00
parent 0daab1ff64
commit 550c47f8ef
2 changed files with 45 additions and 59 deletions

View File

@ -21,39 +21,16 @@ bash = {
maxProcesses = 3,
onStartup = function(event)
log("Normal", "cp -r from ", event.source, " -> ", event.target)
spawnShell(event,
[[if [ "$(ls -A $1)" ]; then cp -r "$1"* "$2"; fi]],
event.source, event.target)
end,
onStartup =
[[if [ "$(ls -A $1)" ]; then cp -r ^source* ^target; fi]],
onCreate = function(event)
local s = event.sourcePathname
local t = event.targetPathname
log("Normal", "Spawning Create ", s," -> ",t)
spawnShell(event, prefix..[[cp -r "$1" "$2"]], s, t)
end,
onCreate = prefix..[[cp -r ^sourcePathname ^targetPathname]],
onModify = function(event)
local s = event.sourcePathname
local t = event.targetPathname
log("Normal", "Spawning Modify ",s," -> ",t)
spawnShell(event, prefix..[[cp -r "$1" "$2"]], s, t)
end,
onModify = prefix..[[cp -r ^sourcePathname ^targetPathname]],
onDelete = function(event)
local t = event.targetPathname
log("Normal", "Spawning Delete of ",t)
spawnShell(event, prefix..[[rm -rf "$1"]], t)
end,
onDelete = prefix..[[rm -rf ^targetPathname]],
onMove = function(originEvent, destinationEvent)
local t = originEvent.targetPathname
local d = destinationEvent.targetPathname
log("Normal", "Spawning Move from ",t," to ",d)
spawnShell(originEvent, prefix..[[mv "$1" "$2"]], t, d)
end,
onMove = prefix..[[mv ^o.targetPathname ^d.targetPathname]],
}
sync{bash, source="src", target="dst/"}

View File

@ -563,7 +563,7 @@ local Inlet, InletControl = (function()
event.etype)
return
end
delay.sync:removeDelay(delay)
sync:removeDelay(delay)
end
-----
@ -622,17 +622,18 @@ local Inlet, InletControl = (function()
-- public interface.
-- this one is split, one for user one for runner.
return {
createBlanketEvent = createBlanketEvent,
discardEvent = discardEvent,
getEvent = getEvent,
getEvents = getEvents,
getConfig = getConfig,
createBlanketEvent = createBlanketEvent,
}, {
setSync = setSync,
getSync = getSync,
getDelay = getDelay,
getDelayList = getDelayList,
d2e = d2e,
dl2el = dl2el,
getDelay = getDelay,
getDelayList = getDelayList,
getSync = getSync,
setSync = setSync,
}
end)()
@ -1314,12 +1315,12 @@ local Inotifies = (function()
}
end)()
------
-- Writes functions for the user for layer 3 configuration.
--
local functionWriter = (function()
-----
-- all variables for layer 3
transVars = {
{ "%^pathname", "event.pathname" , 1, },
@ -1382,7 +1383,7 @@ local functionWriter = (function()
--
-- TODO this has a little too much coding blocks.
--
function translateBinary(str)
local function translateBinary(str)
-- splits the string
local args = splitStr(str)
@ -1449,17 +1450,22 @@ local functionWriter = (function()
-----
-- Translates a call using a shell to a lua function
--
function translateShell(str)
local function translateShell(str)
local argn = 1
local args = {}
local cmd = str
local lc = str
-- true if there is a second event
local haveEvent2 = false
for _, v in ipairs(transVars) do
local occur = false
cmd = string.gsub(cmd, v[1],
function() occur = true; return '$'..argn end)
function()
occur = true
return '"$'..argn..'"'
end)
lc = string.gsub(lc, v[1], ']]..'..v[2]..'..[[')
if occur then
argn = argn + 1
table.insert(args, v[2])
@ -1475,7 +1481,7 @@ local functionWriter = (function()
ft = "function(event, event2)\n"
end
ft = ft .. ' log("Normal", "Event " .. event.etype ..\n'
ft = ft .. " [[ spawns action '" .. str .. '\']])\n'
ft = ft .. " [[ spawns shell '" .. lc .. '\']])\n'
ft = ft .. " spawnShell(event, [[" .. cmd .. "]]"
for _, v in ipairs(args) do
ft = ft .. ",\n " .. v
@ -1486,7 +1492,7 @@ local functionWriter = (function()
-----
-- writes a lua function for a layer 3 user script.
function translate(str)
local function translate(str)
-- trim spaces
str = string.match(str, "^%s*(.-)%s*$")
@ -1496,7 +1502,7 @@ local functionWriter = (function()
else
ft = translateShell(str)
end
log("FWrite","translated ",str," to ",ft)
log("FWrite","translated [[",str,"]] to \n",ft)
return ft
end
@ -1504,7 +1510,7 @@ local functionWriter = (function()
-- public interface
--
return {translate = translate}
end()
end)()
----
@ -1753,6 +1759,23 @@ function runner.initialize()
lsyncdStatus = "run";
lsyncd.configure("running");
local ufuncs = {
"onAttrib", "onCreate", "onDelete",
"onModify", "onMove", "onStartup"
}
-- translates layer 3 scripts
for _, s in Syncs.iwalk() do
-- checks if any user functions is a layer 3 string.
local config = s.config
for _, fn in ipairs(ufuncs) do
if type(config[fn]) == 'string' then
local ft = functionWriter.translate(config[fn])
config[fn] = assert(loadstring("return " .. ft))()
end
end
end
-- runs through the syncs table filled by user calling directory()
for _, s in Syncs.iwalk() do
Inotifies.add(s.source, "", true, s)
@ -2068,20 +2091,6 @@ default = {
init = function(inlet)
local config = inlet.getConfig()
-- user functions
local ufuncs = {
"onAttrib", "onCreate", "onDelete",
"onModify", "onMove"}
-- checks if any user functions is a layer 3 string.
for _, fn in ipairs(funcs) do
if type(config[fn]) == 'string' then
local ft = functionWriter.translate(config[fn])
config[fn] = loadstring("return" .. ft)
end
end
if not config.action and not config.onAttrib and
not config.onCreate and not config.onModify and
not config.onDelete and not config.onMove
-- calls a startup if given by user script.
if type(config.onStartup) == "function" then