rinser bugfix

This commit is contained in:
Joachim Stolberg 2019-05-12 14:45:32 +02:00
parent 4dcabcc4af
commit 68e21afc15
4 changed files with 38 additions and 38 deletions

View File

@ -76,58 +76,48 @@ 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 end
end
return 99
end
local function determine_water_dir(pos)
local lvl = get_water_level(pos)
print(lvl)
if lvl > get_water_level({x=pos.x+1, y=pos.y, z=pos.z}) then
return 2 return 2
end end
elseif ndef3 and ndef3.liquidtype == "flowing" and ndef4 and ndef4.liquidtype == "flowing" then if lvl > get_water_level({x=pos.x-1, y=pos.y, z=pos.z}) then
if node3.param2 > node4.param2 then return 4
return 3 end
elseif node3.param2 < node4.param2 then if lvl > get_water_level({x=pos.x, y=pos.y, z=pos.z+1}) then
return 1 return 1
end end
if lvl > get_water_level({x=pos.x, y=pos.y, z=pos.z-1}) then
return 3
end end
return 0 return 0
end end
end
local function remove_obj(obj)
if obj then
obj:remove()
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)
local dir = determine_water_dir(pos) local dir = determine_water_dir(pos)
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

View File

@ -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

View File

@ -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

View File

@ -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