tubelib_addon3 with "high performance" nodes added
@ -298,6 +298,20 @@ function tubelib.unpull_items(pos, side, items, player_name)
|
||||
return false
|
||||
end
|
||||
|
||||
function tubelib.pull_stack(pos, side, player_name)
|
||||
local npos, facedir = get_neighbor_pos(pos, side)
|
||||
if npos == nil then return end
|
||||
local nside, node = get_node_side(npos, facedir)
|
||||
local name = Name2Name[node.name]
|
||||
if tubelib_NodeDef[name] then
|
||||
if tubelib_NodeDef[name].on_pull_stack then
|
||||
return tubelib_NodeDef[name].on_pull_stack(npos, nside, player_name)
|
||||
elseif tubelib_NodeDef[name].on_pull_item then
|
||||
return tubelib_NodeDef[name].on_pull_item(npos, nside, player_name)
|
||||
end
|
||||
end
|
||||
return nil
|
||||
end
|
||||
|
||||
-------------------------------------------------------------------
|
||||
-- Server side helper functions
|
||||
@ -379,6 +393,20 @@ function tubelib.get_num_items(meta, listname, num)
|
||||
return nil
|
||||
end
|
||||
|
||||
function tubelib.get_stack(meta, listname)
|
||||
local inv = meta:get_inventory()
|
||||
local item = tubelib.get_item(meta, listname)
|
||||
if item and inv:contains_item(listname, item) then
|
||||
-- try to remove a complete stack
|
||||
item:set_count(98)
|
||||
local taken = inv:remove_item(listname, item)
|
||||
-- add the already removed
|
||||
taken:set_count(taken:get_count() + 1)
|
||||
return taken
|
||||
end
|
||||
return item
|
||||
end
|
||||
|
||||
-- Return "full", "loaded", or "empty" depending
|
||||
-- on the number of fuel stack items.
|
||||
-- Function only works on fuel inventories with one stacks/99 items
|
||||
|
@ -33,21 +33,6 @@ local function allow_metadata_inventory_take(pos, listname, index, stack, player
|
||||
return stack:get_count()
|
||||
end
|
||||
|
||||
local function get_stack(meta, list)
|
||||
local inv = meta:get_inventory()
|
||||
local item = tubelib.get_item(meta, list)
|
||||
if item and inv:contains_item(list, item) then
|
||||
-- try to remove a complete stack
|
||||
item:set_count(98)
|
||||
local taken = inv:remove_item(list, item)
|
||||
-- add the already removed
|
||||
taken:set_count(taken:get_count() + 1)
|
||||
return taken
|
||||
end
|
||||
return item
|
||||
end
|
||||
|
||||
|
||||
local function formspec()
|
||||
return "size[12,10]"..
|
||||
default.gui_bg..
|
||||
@ -111,16 +96,20 @@ minetest.register_node("tubelib_addons3:chest", {
|
||||
minetest.register_craft({
|
||||
output = "tubelib_addons3:chest",
|
||||
recipe = {
|
||||
{"", "default:steel_ingot", ""},
|
||||
{"tubelib_addons1:chest", "default:gold_ingot", "tubelib_addons1:chest"},
|
||||
{"", "default:tin_ingot", ""},
|
||||
}
|
||||
{"default:tin_ingot", "tubelib_addons1:chest", ""},
|
||||
{"tubelib_addons1:chest", "default:gold_ingot", ""},
|
||||
{"", "", ""},
|
||||
},
|
||||
})
|
||||
|
||||
tubelib.register_node("tubelib_addons3:chest", {}, {
|
||||
on_pull_stack = function(pos, side)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.get_stack(meta, "main")
|
||||
end,
|
||||
on_pull_item = function(pos, side)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return get_stack(meta, "main")
|
||||
return tubelib.get_item(meta, "main")
|
||||
end,
|
||||
on_push_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
|
@ -446,9 +446,9 @@ minetest.register_node("tubelib_addons3:distributor_active", {
|
||||
minetest.register_craft({
|
||||
output = "tubelib_addons3:distributor",
|
||||
recipe = {
|
||||
{"", "default:steel_ingot", ""},
|
||||
{"default:gold_ingot", "tubelib:distributor", "default:tin_ingot"},
|
||||
{"", "default:steel_ingot", ""},
|
||||
{"default:tin_ingot", "tubelib:distributor", ""},
|
||||
{"tubelib:distributor", "default:gold_ingot", ""},
|
||||
{"", "", ""},
|
||||
},
|
||||
})
|
||||
|
||||
|
@ -10,6 +10,7 @@
|
||||
|
||||
]]--
|
||||
|
||||
dofile(minetest.get_modpath("tubelib_addons3") .. '/pushing_chest.lua')
|
||||
dofile(minetest.get_modpath("tubelib_addons3") .. '/chest.lua')
|
||||
dofile(minetest.get_modpath("tubelib_addons3") .. '/pusher.lua')
|
||||
dofile(minetest.get_modpath("tubelib_addons3") .. '/distributor.lua')
|
||||
dofile(minetest.get_modpath("tubelib_addons3") .. '/pushing_chest.lua')
|
||||
|
234
tubelib_addons3/pusher.lua
Normal file
@ -0,0 +1,234 @@
|
||||
--[[
|
||||
|
||||
Tubelib Addons 3
|
||||
================
|
||||
|
||||
Copyright (C) 2018 Joachim Stolberg
|
||||
|
||||
LGPLv2.1+
|
||||
See LICENSE.txt for more information
|
||||
|
||||
pusher.lua
|
||||
|
||||
A high performance pusher
|
||||
|
||||
]]--
|
||||
|
||||
local RUNNING_STATE = 10
|
||||
|
||||
local function switch_on(pos, node)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
meta:set_int("running", RUNNING_STATE)
|
||||
meta:set_string("infotext", "HighPerf Pusher "..number..": running")
|
||||
node.name = "tubelib_addons3:pusher_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):start(2)
|
||||
return false
|
||||
end
|
||||
|
||||
local function switch_off(pos, node)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
meta:set_int("running", tubelib.STATE_STOPPED)
|
||||
meta:set_string("infotext", "HighPerf Pusher "..number..": stopped")
|
||||
node.name = "tubelib_addons3:pusher"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):stop()
|
||||
return false
|
||||
end
|
||||
|
||||
local function goto_standby(pos, node)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
meta:set_int("running", tubelib.STATE_STANDBY)
|
||||
meta:set_string("infotext", "HighPerf Pusher "..number..": standby")
|
||||
node.name = "tubelib_addons3:pusher"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):start(20)
|
||||
return false
|
||||
end
|
||||
|
||||
local function goto_blocked(pos, node)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
meta:set_int("running", tubelib.STATE_BLOCKED)
|
||||
meta:set_string("infotext", "HighPerf Pusher "..number..": blocked")
|
||||
node.name = "tubelib_addons3:pusher"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.get_node_timer(pos):start(20)
|
||||
return false
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
local running = meta:get_int("running") - 1
|
||||
local player_name = meta:get_string("player_name")
|
||||
local items = tubelib.pull_stack(pos, "L", player_name)
|
||||
if items ~= nil then
|
||||
if tubelib.push_items(pos, "R", items, player_name) == false then
|
||||
-- place item back
|
||||
tubelib.unpull_items(pos, "L", items, player_name)
|
||||
local node = minetest.get_node(pos)
|
||||
return goto_blocked(pos, node)
|
||||
end
|
||||
meta:set_int("item_counter", meta:get_int("item_counter") + 1)
|
||||
if running <= 0 then
|
||||
local node = minetest.get_node(pos)
|
||||
return switch_on(pos, node)
|
||||
else
|
||||
-- reload running state
|
||||
running = RUNNING_STATE
|
||||
end
|
||||
else
|
||||
if running <= 0 then
|
||||
local node = minetest.get_node(pos)
|
||||
return goto_standby(pos, node)
|
||||
end
|
||||
end
|
||||
meta:set_int("running", running)
|
||||
return true
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib_addons3:pusher", {
|
||||
description = "HighPerf Pusher",
|
||||
tiles = {
|
||||
-- up, down, right, left, back, front
|
||||
'tubelib_pusher1.png^tubelib_addons3_node_frame4.png',
|
||||
'tubelib_pusher1.png^tubelib_addons3_node_frame4.png',
|
||||
'tubelib_outp.png^tubelib_addons3_node_frame4.png',
|
||||
'tubelib_inp.png^tubelib_addons3_node_frame4.png',
|
||||
"tubelib_pusher1.png^[transformR180]^tubelib_addons3_node_frame4.png^[transformR180]",
|
||||
"tubelib_pusher1.png^tubelib_addons3_node_frame4.png",
|
||||
},
|
||||
|
||||
after_place_node = function(pos, placer)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("player_name", placer:get_player_name())
|
||||
local number = tubelib.add_node(pos, "tubelib_addons3:pusher")
|
||||
meta:set_string("number", number)
|
||||
meta:set_string("infotext", "HighPerf Pusher "..number..": stopped")
|
||||
meta:set_int("item_counter", 0)
|
||||
end,
|
||||
|
||||
on_rightclick = function(pos, node, clicker)
|
||||
if not minetest.is_protected(pos, clicker:get_player_name()) then
|
||||
switch_on(pos, node)
|
||||
end
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
tubelib.remove_node(pos)
|
||||
end,
|
||||
|
||||
on_timer = keep_running,
|
||||
on_rotate = screwdriver.disallow,
|
||||
|
||||
paramtype = "light",
|
||||
sunlight_propagates = true,
|
||||
paramtype2 = "facedir",
|
||||
groups = {choppy=2, cracky=2, crumbly=2},
|
||||
is_ground_content = false,
|
||||
sounds = default.node_sound_wood_defaults(),
|
||||
})
|
||||
|
||||
|
||||
minetest.register_node("tubelib_addons3:pusher_active", {
|
||||
description = "HighPerf Pusher",
|
||||
tiles = {
|
||||
-- up, down, right, left, back, front
|
||||
{
|
||||
image = "tubelib_addons3_pusher_active.png",
|
||||
backface_culling = false,
|
||||
animation = {
|
||||
type = "vertical_frames",
|
||||
aspect_w = 32,
|
||||
aspect_h = 32,
|
||||
length = 2.0,
|
||||
},
|
||||
},
|
||||
{
|
||||
image = "tubelib_addons3_pusher_active.png",
|
||||
backface_culling = false,
|
||||
animation = {
|
||||
type = "vertical_frames",
|
||||
aspect_w = 32,
|
||||
aspect_h = 32,
|
||||
length = 2.0,
|
||||
},
|
||||
},
|
||||
'tubelib_outp.png^tubelib_addons3_node_frame4.png',
|
||||
'tubelib_inp.png^tubelib_addons3_node_frame4.png',
|
||||
{
|
||||
image = "tubelib_addons3_pusher_active.png^[transformR180]",
|
||||
backface_culling = false,
|
||||
animation = {
|
||||
type = "vertical_frames",
|
||||
aspect_w = 32,
|
||||
aspect_h = 32,
|
||||
length = 2.0,
|
||||
},
|
||||
},
|
||||
{
|
||||
image = "tubelib_addons3_pusher_active.png",
|
||||
backface_culling = false,
|
||||
animation = {
|
||||
type = "vertical_frames",
|
||||
aspect_w = 32,
|
||||
aspect_h = 32,
|
||||
length = 2.0,
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
on_rightclick = function(pos, node, clicker)
|
||||
if not minetest.is_protected(pos, clicker:get_player_name()) then
|
||||
switch_off(pos, node)
|
||||
end
|
||||
end,
|
||||
|
||||
on_timer = keep_running,
|
||||
on_rotate = screwdriver.disallow,
|
||||
|
||||
paramtype = "light",
|
||||
sunlight_propagates = true,
|
||||
paramtype2 = "facedir",
|
||||
groups = {crumbly=0, not_in_creative_inventory=1},
|
||||
is_ground_content = false,
|
||||
sounds = default.node_sound_wood_defaults(),
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
output = "tubelib_addons3:pusher",
|
||||
recipe = {
|
||||
{"default:tin_ingot", "tubelib:pusher", ""},
|
||||
{"tubelib:pusher", "default:gold_ingot", ""},
|
||||
{"", "", ""},
|
||||
},
|
||||
})
|
||||
|
||||
tubelib.register_node("tubelib_addons3:pusher", {"tubelib_addons3:pusher_active"}, {
|
||||
is_pusher = true, -- is a pulling/pushing node
|
||||
|
||||
on_recv_message = function(pos, topic, payload)
|
||||
local node = minetest.get_node(pos)
|
||||
if topic == "on" then
|
||||
return switch_on(pos, node)
|
||||
elseif topic == "off" then
|
||||
return switch_off(pos, node)
|
||||
elseif topic == "state" then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local running = meta:get_int("running") or tubelib.STATE_STOPPED
|
||||
return tubelib.statestring(running)
|
||||
elseif topic == "counter" then
|
||||
local meta = minetest.get_meta(pos)
|
||||
return meta:get_int("item_counter")
|
||||
elseif topic == "clear_counter" then
|
||||
local meta = minetest.get_meta(pos)
|
||||
return meta:set_int("item_counter", 0)
|
||||
else
|
||||
return "not supported"
|
||||
end
|
||||
end,
|
||||
})
|
@ -100,7 +100,7 @@ minetest.register_node("tubelib_addons3:pushing_chest", {
|
||||
tiles = {
|
||||
-- up, down, right, left, back, front
|
||||
{
|
||||
image = "tubelib_addons3_pushing_chest.png",
|
||||
image = "tubelib_addons3_pusher_active.png",
|
||||
backface_culling = false,
|
||||
animation = {
|
||||
type = "vertical_frames",
|
||||
@ -165,10 +165,10 @@ minetest.register_node("tubelib_addons3:pushing_chest", {
|
||||
minetest.register_craft({
|
||||
output = "tubelib_addons3:pushing_chest",
|
||||
recipe = {
|
||||
{ "", "default:tin_ingot", ""},
|
||||
{"default:chest", "default:gold_ingot", "tubelib:distributor"},
|
||||
{"", "default:steel_ingot", ""},
|
||||
}
|
||||
{"default:tin_ingot", "tubelib_addons3:pusher", ""},
|
||||
{"tubelib_addons1:chest", "default:gold_ingot", ""},
|
||||
{"", "", ""},
|
||||
},
|
||||
})
|
||||
|
||||
tubelib.register_node("tubelib_addons3:pushing_chest", {}, {
|
||||
|
Before Width: | Height: | Size: 16 KiB After Width: | Height: | Size: 2.8 KiB |
Before Width: | Height: | Size: 962 B After Width: | Height: | Size: 375 B |
BIN
tubelib_addons3/textures/tubelib_addons3_node_frame4.png
Normal file
After Width: | Height: | Size: 406 B |
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB |