rinser bugfix
This commit is contained in:
parent
4dcabcc4af
commit
68e21afc15
@ -76,49 +76,40 @@ local function allow_metadata_inventory_take(pos, listname, index, stack, player
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
local function determine_water_dir(pos)
|
local function get_water_level(pos)
|
||||||
local pos1 = {x=pos.x+1, y=pos.y, z=pos.z}
|
|
||||||
local pos2 = {x=pos.x-1, y=pos.y, z=pos.z}
|
|
||||||
local pos3 = {x=pos.x, y=pos.y, z=pos.z+1}
|
|
||||||
local pos4 = {x=pos.x, y=pos.y, z=pos.z-1}
|
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
local node1 = minetest.get_node(pos1)
|
|
||||||
local node2 = minetest.get_node(pos2)
|
|
||||||
local node3 = minetest.get_node(pos3)
|
|
||||||
local node4 = minetest.get_node(pos4)
|
|
||||||
local ndef1 = minetest.registered_nodes[node1.name]
|
|
||||||
local ndef2 = minetest.registered_nodes[node2.name]
|
|
||||||
local ndef3 = minetest.registered_nodes[node3.name]
|
|
||||||
local ndef4 = minetest.registered_nodes[node4.name]
|
|
||||||
|
|
||||||
if minetest.get_item_group(node.name, "water") > 0 then
|
if minetest.get_item_group(node.name, "water") > 0 then
|
||||||
if ndef1 and ndef1.liquidtype == "flowing" and ndef2 and ndef2.liquidtype == "flowing" then
|
local ndef = minetest.registered_nodes[node.name]
|
||||||
if node1.param2 > node2.param2 then
|
if ndef and ndef.liquidtype == "flowing" then
|
||||||
return 4
|
return node.param2
|
||||||
elseif node1.param2 < node2.param2 then
|
|
||||||
return 2
|
|
||||||
end
|
|
||||||
elseif ndef3 and ndef3.liquidtype == "flowing" and ndef4 and ndef4.liquidtype == "flowing" then
|
|
||||||
if node3.param2 > node4.param2 then
|
|
||||||
return 3
|
|
||||||
elseif node3.param2 < node4.param2 then
|
|
||||||
return 1
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return 0
|
return 99
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function remove_obj(obj)
|
local function determine_water_dir(pos)
|
||||||
if obj then
|
local lvl = get_water_level(pos)
|
||||||
obj:remove()
|
print(lvl)
|
||||||
|
if lvl > get_water_level({x=pos.x+1, y=pos.y, z=pos.z}) then
|
||||||
|
return 2
|
||||||
end
|
end
|
||||||
|
if lvl > get_water_level({x=pos.x-1, y=pos.y, z=pos.z}) then
|
||||||
|
return 4
|
||||||
|
end
|
||||||
|
if lvl > get_water_level({x=pos.x, y=pos.y, z=pos.z+1}) then
|
||||||
|
return 1
|
||||||
|
end
|
||||||
|
if lvl > get_water_level({x=pos.x, y=pos.y, z=pos.z-1}) then
|
||||||
|
return 3
|
||||||
|
end
|
||||||
|
return 0
|
||||||
end
|
end
|
||||||
|
|
||||||
local function set_velocity(obj, pos, vel)
|
local function set_velocity(obj, pos, vel)
|
||||||
if obj and vel then
|
obj:set_acceleration({x = 0, y = 0, z = 0})
|
||||||
|
local p = obj:get_pos()
|
||||||
|
obj:set_pos({x=p.x, y=p.y-0.3, z=p.z})
|
||||||
obj:set_velocity(vel)
|
obj:set_velocity(vel)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function add_object(pos, name)
|
local function add_object(pos, name)
|
||||||
@ -126,8 +117,7 @@ local function add_object(pos, name)
|
|||||||
if dir then
|
if dir then
|
||||||
local obj = minetest.add_item(pos, ItemStack(name))
|
local obj = minetest.add_item(pos, ItemStack(name))
|
||||||
local vel = vector.multiply(tubelib2.Dir6dToVector[dir], 0.3)
|
local vel = vector.multiply(tubelib2.Dir6dToVector[dir], 0.3)
|
||||||
minetest.after(0.8, set_velocity, obj, pos, vel)
|
minetest.after(0.3, set_velocity, obj, pos, vel)
|
||||||
minetest.after(20, remove_obj, obj)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -140,6 +130,14 @@ local function get_random_gravel_ore()
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function washing(pos, trd, mem, inv)
|
local function washing(pos, trd, mem, inv)
|
||||||
|
-- for testing purposes
|
||||||
|
if inv:contains_item("src", ItemStack("default:stick")) then
|
||||||
|
add_object({x=pos.x, y=pos.y+1, z=pos.z}, "default:stick")
|
||||||
|
inv:remove_item("src", ItemStack("default:stick"))
|
||||||
|
trd.State:keep_running(pos, mem, COUNTDOWN_TICKS)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local src = ItemStack("techage:sieved_gravel")
|
local src = ItemStack("techage:sieved_gravel")
|
||||||
local dst = ItemStack("default:sand")
|
local dst = ItemStack("default:sand")
|
||||||
if inv:contains_item("src", src) then
|
if inv:contains_item("src", src) then
|
||||||
|
@ -391,6 +391,7 @@ end
|
|||||||
|
|
||||||
-- command interface
|
-- command interface
|
||||||
function NodeStates:on_receive_message(pos, topic, payload)
|
function NodeStates:on_receive_message(pos, topic, payload)
|
||||||
|
local mem = tubelib2.get_mem(pos)
|
||||||
if topic == "on" then
|
if topic == "on" then
|
||||||
self:start(pos, tubelib2.get_mem(pos))
|
self:start(pos, tubelib2.get_mem(pos))
|
||||||
return true
|
return true
|
||||||
|
@ -64,7 +64,7 @@ local function node_timer(pos, elapsed)
|
|||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
if inv then
|
if inv then
|
||||||
if not pull_push_item(pos, meta) then
|
if not pull_push_item(pos, meta) then
|
||||||
scan_for_objects(pos, inv)
|
scan_for_objects({x=pos.x, y=pos.y+1, z=pos.z}, inv)
|
||||||
push_item(pos, inv, meta)
|
push_item(pos, inv, meta)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -20,7 +20,8 @@ local function destroy_node(itemstack, placer, pointed_thing)
|
|||||||
if pointed_thing.type == "node" then
|
if pointed_thing.type == "node" then
|
||||||
local pos = pointed_thing.under
|
local pos = pointed_thing.under
|
||||||
if not minetest.is_protected(pos, placer:get_player_name()) then
|
if not minetest.is_protected(pos, placer:get_player_name()) then
|
||||||
M(pos):set_int("techage_aging", 999999)
|
local mem = tubelib2.get_mem(pos)
|
||||||
|
mem.techage_aging = 999999
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -28,7 +29,7 @@ end
|
|||||||
local function repair_node(itemstack, user, pointed_thing)
|
local function repair_node(itemstack, user, pointed_thing)
|
||||||
local pos = pointed_thing.under
|
local pos = pointed_thing.under
|
||||||
if pos then
|
if pos then
|
||||||
if tubelib.repair_node(pos) then
|
if techage.repair_node(pos) then
|
||||||
minetest.chat_send_player(user:get_player_name(), "[TechAge] Node repaired")
|
minetest.chat_send_player(user:get_player_name(), "[TechAge] Node repaired")
|
||||||
itemstack:take_item()
|
itemstack:take_item()
|
||||||
return itemstack
|
return itemstack
|
||||||
|
Loading…
Reference in New Issue
Block a user