2016-09-09 22:49:51 +02:00
|
|
|
print("initialize Starting QA Block")
|
|
|
|
|
2016-10-19 08:31:19 +02:00
|
|
|
-- settings
|
|
|
|
local defaultmodule = "same_recipe"
|
|
|
|
local print_to_chat = true
|
2016-09-13 00:49:18 +02:00
|
|
|
|
2016-10-19 08:31:19 +02:00
|
|
|
-- constants
|
2016-09-13 00:49:18 +02:00
|
|
|
local filepath = minetest.get_modpath("qa_block").."/checks/"
|
|
|
|
|
2016-10-19 08:31:19 +02:00
|
|
|
-- redefine print, copy all output to chat
|
|
|
|
if print_to_chat then
|
|
|
|
old_print = print
|
|
|
|
print = function(...)
|
|
|
|
local outsting = ""
|
|
|
|
local out
|
|
|
|
local x
|
|
|
|
for x, out in ipairs(arg) do
|
|
|
|
outsting = (outsting..tostring(out)..'\t')
|
|
|
|
end
|
|
|
|
old_print(outsting)
|
|
|
|
minetest.chat_send_all(outsting)
|
|
|
|
end
|
|
|
|
end
|
2016-09-13 00:49:18 +02:00
|
|
|
|
2016-10-19 08:31:19 +02:00
|
|
|
-- execute a module
|
2016-09-13 00:49:18 +02:00
|
|
|
local function do_module( module )
|
2016-09-13 14:14:32 +02:00
|
|
|
print("QA checks started")
|
2016-09-13 00:49:18 +02:00
|
|
|
--- TODO: some selectoin of executed check
|
|
|
|
local file = filepath..module..".lua"
|
|
|
|
|
|
|
|
local f=io.open(file,"r")
|
|
|
|
if not f then
|
2016-09-13 14:14:32 +02:00
|
|
|
print("file "..file.." not found")
|
2016-09-13 00:49:18 +02:00
|
|
|
else
|
|
|
|
io.close(f)
|
|
|
|
local compiled
|
|
|
|
local executed
|
|
|
|
local err
|
|
|
|
local compiled, err = loadfile(file)
|
|
|
|
if not compiled then
|
2016-09-13 14:14:32 +02:00
|
|
|
print("syntax error in module file"..file)
|
|
|
|
print(err)
|
2016-09-13 00:49:18 +02:00
|
|
|
else
|
|
|
|
executed, err = pcall(compiled)
|
|
|
|
if not executed then
|
2016-09-13 14:14:32 +02:00
|
|
|
print("runtime error appears")
|
|
|
|
print(err)
|
2016-09-13 00:49:18 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-09-13 14:14:32 +02:00
|
|
|
print("QA checks finished")
|
2016-09-13 00:49:18 +02:00
|
|
|
end
|
2016-09-09 22:49:51 +02:00
|
|
|
|
2016-10-19 08:31:19 +02:00
|
|
|
|
2016-09-12 20:59:29 +02:00
|
|
|
minetest.register_chatcommand("qa_block", {
|
2016-09-13 00:49:18 +02:00
|
|
|
params = "<checkmodule>",
|
2016-09-12 20:59:29 +02:00
|
|
|
description = "Perform qa block check",
|
|
|
|
privs = {interact = true},
|
2016-09-13 00:49:18 +02:00
|
|
|
func = function(name, param)
|
|
|
|
if param and param ~= "" then
|
|
|
|
do_module(param)
|
|
|
|
else
|
|
|
|
do_module(defaultmodule)
|
|
|
|
end
|
|
|
|
return true, "QA checks finished."
|
2016-09-12 20:59:29 +02:00
|
|
|
end,
|
|
|
|
})
|
|
|
|
|
2016-09-09 22:49:51 +02:00
|
|
|
minetest.register_node("qa_block:block", {
|
|
|
|
description = "Check mods quality starter block",
|
2016-10-19 08:31:19 +02:00
|
|
|
tiles = {"default_dirt.png","default_stone.png","default_sand.png"},
|
|
|
|
groups = {cracky = 3},
|
|
|
|
sounds = default.node_sound_stone_defaults()
|
2016-09-09 22:49:51 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
minetest.register_on_placenode(function (pos, node)
|
2016-10-19 08:31:19 +02:00
|
|
|
if node.name == "qa_block:block" then
|
2016-09-09 22:49:51 +02:00
|
|
|
|
|
|
|
--- TODO: some selectoin of executed check
|
2016-09-13 00:49:18 +02:00
|
|
|
do_module(defaultmodule)
|
2016-09-09 22:49:51 +02:00
|
|
|
minetest.env:add_node(pos, {name="air"})
|
2016-10-19 08:31:19 +02:00
|
|
|
end
|
2016-09-09 22:49:51 +02:00
|
|
|
end)
|