turtle: improve coordinate handling and task scheduling
This commit is contained in:
parent
cd1805ce25
commit
0df741ab4c
@ -23,13 +23,21 @@ end
|
||||
local function parse_relative_coord(c)
|
||||
end
|
||||
|
||||
-- x or {x,y,z}
|
||||
function turtle.optcoord(x, y, z)
|
||||
local pos = x
|
||||
if y and z then
|
||||
pos = turtle.coord(x, y, z)
|
||||
function turtle.ordercoord(c)
|
||||
if c.x == nil then
|
||||
return {x = c[1], y = c[2], z = c[3]}
|
||||
else
|
||||
return c
|
||||
end
|
||||
end
|
||||
|
||||
-- x or {x,y,z} or {x=x,y=y,z=z}
|
||||
function turtle.optcoord(x, y, z)
|
||||
if y and z then
|
||||
return turtle.coord(x, y, z)
|
||||
else
|
||||
return turtle.ordercoord(x)
|
||||
end
|
||||
return pos
|
||||
end
|
||||
|
||||
-- swap x and y if x > y
|
||||
@ -132,6 +140,11 @@ end
|
||||
function turtle.dircoord(f, y, r)
|
||||
local rot = minetest.localplayer:get_yaw() % 360
|
||||
|
||||
local coord = turtle.optcoord(f, y, r)
|
||||
local f = coord.x
|
||||
local y = coord.y
|
||||
local r = coord.z
|
||||
|
||||
if between(rot, 315, 360) or between(rot, 0, 45) then -- north
|
||||
return turtle.relcoord(r, y, f)
|
||||
elseif between(rot, 135, 225) then -- south
|
||||
@ -281,17 +294,36 @@ turtle.states = {}
|
||||
turtle.states_available = false
|
||||
|
||||
function turtle.schedule(name, state)
|
||||
if type(name) == "table" then
|
||||
error("turtle.schedule: first parameter should be the task's name")
|
||||
return
|
||||
end
|
||||
|
||||
turtle.states[#turtle.states + 1] = {name = name, state = state}
|
||||
turtle.states_available = true
|
||||
end
|
||||
|
||||
function turtle.kill_symbolic(name)
|
||||
local dead = {}
|
||||
|
||||
for i, v in ipairs(turtle.states) do
|
||||
if v.name == name then
|
||||
dead[#dead + 1] = i
|
||||
end
|
||||
end
|
||||
|
||||
for i, v in ipairs(dead) do
|
||||
table.remove(turtle.states, v)
|
||||
end
|
||||
end
|
||||
|
||||
function turtle.run_states(dtime)
|
||||
if turtle.states_available then
|
||||
local dead = {}
|
||||
|
||||
for i, v in ipairs(turtle.states) do
|
||||
local ret = tlang.step(v.state)
|
||||
if ret ~= true then
|
||||
if ret ~= true and ret ~= nil then
|
||||
if type(ret) == "string" then
|
||||
minetest.display_chat_message("Turtle/tlang ERROR in " .. v.name .. ": " .. ret)
|
||||
end
|
||||
@ -317,3 +349,9 @@ minetest.register_chatcommand("tlang", {
|
||||
turtle.schedule("chat_script", state)
|
||||
end
|
||||
})
|
||||
|
||||
minetest.register_chatcommand("tkill", {
|
||||
description = "Kill tlang task.",
|
||||
params = "<task name>",
|
||||
func = turtle.kill_symbolic
|
||||
})
|
||||
|
Loading…
x
Reference in New Issue
Block a user