2016-11-13 14:42:57 +01:00
|
|
|
local WNOA = "wrong number of arguments"
|
|
|
|
local UAT = "unsupported argument type"
|
|
|
|
local SE = "error with cmd-cmd executing: "
|
2016-12-29 14:14:20 +01:00
|
|
|
local STRL = "attempt on exceeding maximum string length"
|
2016-11-13 14:42:57 +01:00
|
|
|
|
|
|
|
local s
|
|
|
|
s = {
|
2016-12-28 13:44:53 +01:00
|
|
|
mov = function(params)
|
2016-11-13 14:42:57 +01:00
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
return true, params[2]
|
|
|
|
end,
|
|
|
|
|
2016-12-31 17:16:16 +01:00
|
|
|
getvar = function(params, faden)
|
|
|
|
local p = params[1]
|
|
|
|
if type(p) ~= "string" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
|
|
|
p = faden.vars[p]
|
|
|
|
return true, {p, params[2] and p ~= nil}
|
|
|
|
end,
|
|
|
|
|
2016-12-29 14:14:20 +01:00
|
|
|
add = function(params, faden)
|
2016-11-13 14:42:57 +01:00
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p1,p2 = unpack(params)
|
|
|
|
local t1 = type(p1)
|
|
|
|
local t2 = type(p2)
|
|
|
|
if t1 ~= t2 then
|
|
|
|
return false, "different argument types"
|
|
|
|
end
|
|
|
|
|
|
|
|
if t1 == "number" then
|
|
|
|
return true, p1 + p2
|
|
|
|
end
|
2016-12-28 18:27:41 +01:00
|
|
|
if t1 == "boolean" then
|
|
|
|
return true, p1 and p2
|
|
|
|
end
|
2016-12-29 14:14:20 +01:00
|
|
|
if #p1 + #p2 > faden.strlen_max then
|
|
|
|
return false, STRL
|
|
|
|
end
|
2016-12-28 18:27:41 +01:00
|
|
|
return true, p1 .. p2
|
|
|
|
end,
|
|
|
|
|
|
|
|
mul = function(params)
|
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p1,p2 = unpack(params)
|
|
|
|
local t1 = type(p1)
|
|
|
|
local t2 = type(p2)
|
|
|
|
if t1 == "string"
|
|
|
|
and t2 == "number" then
|
2016-12-29 14:14:20 +01:00
|
|
|
if #p1 * p2 > faden.strlen_max then
|
|
|
|
return false, STRL
|
|
|
|
end
|
2016-12-28 18:27:41 +01:00
|
|
|
return true, p1:rep(p2)
|
|
|
|
end
|
|
|
|
if t1 ~= t2 then
|
|
|
|
return false, "different argument types"
|
|
|
|
end
|
|
|
|
|
|
|
|
if t1 == "number" then
|
|
|
|
return true, p1 * p2
|
|
|
|
end
|
|
|
|
if t1 == "boolean" then
|
|
|
|
return true, p1 or p2
|
2016-11-13 14:42:57 +01:00
|
|
|
end
|
|
|
|
return false, UAT
|
|
|
|
end,
|
|
|
|
|
2016-12-28 18:27:41 +01:00
|
|
|
neg = function(params)
|
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local v = params[1]
|
|
|
|
local t = type(v)
|
|
|
|
if t == "number" then
|
|
|
|
return true, -v
|
|
|
|
end
|
|
|
|
if t == "boolean" then
|
|
|
|
return true, not v
|
|
|
|
end
|
|
|
|
return true, v:rev()
|
|
|
|
end,
|
|
|
|
|
|
|
|
inv = function(params)
|
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p = params[1]
|
|
|
|
if type(p) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
|
|
|
return true, 1 / p
|
|
|
|
end,
|
|
|
|
|
|
|
|
mod = function(params)
|
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p1,p2 = unpack(params)
|
|
|
|
if type(p1) ~= "number" or type(p2) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
|
|
|
return true, p1 % p2
|
|
|
|
end,
|
|
|
|
|
2016-11-13 14:42:57 +01:00
|
|
|
jmp = function(params, faden)
|
2016-12-29 22:48:40 +01:00
|
|
|
local pcnt = #params
|
|
|
|
if pcnt == 2 then
|
|
|
|
if not params[2] then
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
elseif pcnt ~= 1 then
|
2016-11-13 14:42:57 +01:00
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p = params[1]
|
|
|
|
if type(p) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
|
|
|
if p < 1
|
|
|
|
or p%1 ~= 0
|
|
|
|
or p > #faden.liste + 1 then
|
|
|
|
return false, "jump target out of range"
|
|
|
|
end
|
|
|
|
faden.ip = p-1
|
2016-12-28 22:05:48 +01:00
|
|
|
if not s.usleep({0}, faden) then
|
2016-11-13 14:42:57 +01:00
|
|
|
error(SE)
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
2016-12-29 14:14:20 +01:00
|
|
|
call = function(params, faden)
|
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local subsucc,msg = s.push(faden.ip + 1, faden)
|
|
|
|
if not subsucc then
|
|
|
|
return false, SE .. msg
|
|
|
|
end
|
|
|
|
subsucc,msg = s.jmp(params, faden)
|
|
|
|
if not subsucc then
|
|
|
|
return false, SE .. msg
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
|
|
|
ret = function(_, faden)
|
|
|
|
local subsucc,msg = s.pop({true}, faden)
|
|
|
|
if not subsucc then
|
|
|
|
return false, SE .. msg
|
|
|
|
end
|
2016-12-31 17:16:16 +01:00
|
|
|
subsucc,msg = s.jmp(msg, faden)
|
2016-12-29 14:14:20 +01:00
|
|
|
if not subsucc then
|
|
|
|
return false, SE .. msg
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
2016-11-13 14:42:57 +01:00
|
|
|
push = function(params, faden)
|
|
|
|
local pc = #params
|
|
|
|
if pc == 0 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
for i = 1,pc do
|
|
|
|
faden.stack[faden.sp] = params[i]
|
|
|
|
faden.sp = faden.sp-1
|
|
|
|
end
|
|
|
|
if faden.sp < 0 then
|
|
|
|
return false, "stack overflow"
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
|
|
|
pop = function(params, faden)
|
|
|
|
local pc = #params
|
|
|
|
if pc == 0 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local rt = {}
|
|
|
|
for i = 1,pc do
|
|
|
|
faden.sp = faden.sp+1
|
|
|
|
rt[i] = faden.stack[faden.sp]
|
|
|
|
end
|
|
|
|
if faden.sp > faden.sb then
|
|
|
|
return false, "stack underflow"
|
|
|
|
end
|
|
|
|
return true, rt
|
|
|
|
end,
|
|
|
|
|
2016-12-28 13:44:53 +01:00
|
|
|
equal = function(params)
|
2016-11-13 14:42:57 +01:00
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
return true, params[1] == params[2]
|
|
|
|
end,
|
|
|
|
|
2016-12-28 13:44:53 +01:00
|
|
|
less = function(params)
|
2016-11-13 14:42:57 +01:00
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
2016-12-29 22:37:03 +01:00
|
|
|
local p1,p2 = unpack(params)
|
2016-12-31 17:16:16 +01:00
|
|
|
local t1 = type(p1)
|
|
|
|
local t2 = type(p2)
|
|
|
|
if t1 ~= t2 then
|
|
|
|
return false, "different argument types"
|
|
|
|
end
|
|
|
|
|
|
|
|
if t1 ~= "number"
|
|
|
|
and t1 ~= "string" then
|
2016-11-13 14:42:57 +01:00
|
|
|
return false, UAT
|
|
|
|
end
|
2016-12-29 22:37:03 +01:00
|
|
|
return true, p1 < p2
|
2016-11-13 14:42:57 +01:00
|
|
|
end,
|
|
|
|
|
2016-12-28 22:05:48 +01:00
|
|
|
usleep = function(params, faden)
|
2016-11-13 14:42:57 +01:00
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p = params[1]
|
|
|
|
if type(p) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
2016-12-28 22:05:48 +01:00
|
|
|
faden.rebirth = minetest.get_us_time() + p
|
2016-11-13 14:42:57 +01:00
|
|
|
faden:stop()
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
2016-12-29 14:14:20 +01:00
|
|
|
sleep = function(params, faden)
|
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p = params[1]
|
|
|
|
if type(p) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
2017-01-03 14:44:06 +01:00
|
|
|
local subsucc,msg = s.usleep({p * 1000000}, faden)
|
2016-12-29 14:14:20 +01:00
|
|
|
if not subsucc then
|
|
|
|
return false, SE .. msg
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
2016-12-28 18:47:28 +01:00
|
|
|
get_us_time = function()
|
|
|
|
return true, minetest.get_us_time()
|
|
|
|
end,
|
|
|
|
|
2016-12-28 18:27:41 +01:00
|
|
|
tostring = function(params)
|
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
return true, tostring(params[1])
|
|
|
|
end,
|
|
|
|
|
|
|
|
print = function(params, faden)
|
|
|
|
for i = 1,#params do
|
|
|
|
params[i] = tostring(params[i])
|
|
|
|
end
|
|
|
|
faden.log = faden.log .. table.concat(params, "\t") .. "\n"
|
|
|
|
return true
|
|
|
|
end,
|
|
|
|
|
2016-11-13 14:42:57 +01:00
|
|
|
flush = function(params, faden)
|
|
|
|
return faden:flush(params)
|
|
|
|
end,
|
|
|
|
}
|
2016-12-28 18:27:41 +01:00
|
|
|
|
2016-12-29 14:14:20 +01:00
|
|
|
local so_math_fcts = {"sin", "asin", "cos", "acos", "tan", "atan", "exp", "log",
|
2016-12-28 18:27:41 +01:00
|
|
|
"abs", "sign", "floor", "ceil"}
|
|
|
|
for i = 1,#so_math_fcts do
|
|
|
|
i = so_math_fcts[i]
|
|
|
|
s[i] = function(params)
|
|
|
|
if #params ~= 1 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p = params[1]
|
|
|
|
if type(p) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
|
|
|
return true, math[i](p)
|
|
|
|
end
|
|
|
|
end
|
2016-12-29 14:14:20 +01:00
|
|
|
|
|
|
|
local to_math_fcts = {"pow"}
|
|
|
|
for i = 1,#to_math_fcts do
|
|
|
|
i = to_math_fcts[i]
|
|
|
|
s[i] = function(params)
|
|
|
|
if #params ~= 2 then
|
|
|
|
return false, WNOA
|
|
|
|
end
|
|
|
|
local p1,p2 = unpack(params)
|
|
|
|
if type(p1) ~= "number"
|
|
|
|
or type(p2) ~= "number" then
|
|
|
|
return false, UAT
|
|
|
|
end
|
|
|
|
return true, math[i](p1, p2)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-11-13 14:42:57 +01:00
|
|
|
return s
|