steed/stead/xact.lua

68 lines
1.5 KiB
Lua
Raw Normal View History

2010-06-25 12:31:54 +03:00
xact = function(n, f) -- just simple action!
2010-06-07 16:06:00 +03:00
local v = {};
2010-06-25 12:31:54 +03:00
if type(n) ~= 'string' or (type(f) ~= 'string' and not isCode(f)) then
error ("Wrong parameter to xact.", 2)
end
v.nam = n
v.act = f;
2010-06-27 08:37:32 +03:00
v = obj(v);
2010-06-25 12:31:54 +03:00
v.save = function(self, name, h, need)
if need then
local f = self.xact;
if isCode(f) then
f = stead.string.format("code %q", stead.functions[f].code);
else
f = stead.string.format("%q", f);
end
h:write(stead.string.format("%s = xact(%q, %s);\n", name, self.nam, f))
end
savemembers(h, self, name, false);
end
2010-06-07 16:06:00 +03:00
return v
end
2010-06-27 08:37:32 +03:00
__do_xact = function(str)
2010-06-25 12:31:54 +03:00
local aarg = {}
local function parg(v)
stead.table.insert(aarg, v);
return ''
end
2010-06-07 16:06:00 +03:00
local xrefrep = function(str)
local s = stead.string.gsub(str,'[{}]','');
2010-06-25 12:31:54 +03:00
local o,d, a;
local i = s:find(":", 1, true);
aarg = {}
if i then
o = s:sub(1, i - 1);
d = s:sub(i + 1);
i = o:find("(", 1, true);
if i then
a = o:sub(i);
o = o:sub(1, i - 1);
a:gsub('[^,()]+', parg);
end
2010-06-27 08:37:32 +03:00
if o == '' then
2010-06-27 08:51:14 +03:00
error("Empty link: "..s, 3);
2010-06-27 08:37:32 +03:00
end
2010-06-25 12:31:54 +03:00
else
2010-06-27 08:51:14 +03:00
error("Wrong link: "..s, 3);
2010-06-25 12:31:54 +03:00
end
local oo = objs():srch(o)
2010-06-25 12:31:54 +03:00
if not oo then
oo = ref(o)
2010-06-25 12:31:54 +03:00
end
return xref(d, ref(oo), unpack(aarg));
2010-06-07 16:06:00 +03:00
end
if type(str) ~= 'string' then return end
local s = stead.string.gsub(str,'{[^}]+}', xrefrep);
return s;
end
2010-06-27 08:37:32 +03:00
stead.fmt = stead.hook(stead.fmt, function(f, ...)
local r = f(unpack(arg))
if type(r) == 'string' and stead.state then
r = __do_xact(r);
end
return r;
2010-06-25 12:31:54 +03:00
end)