mirror of
https://github.com/joe7575/techpack.git
synced 2025-01-26 16:01:29 +01:00
V2.03, Piston/WorldEdit/replacer detection added, farming and grinder recipes added
This commit is contained in:
parent
a5e18c3d79
commit
a7a6b50492
@ -150,6 +150,7 @@ tubelib_addons1 optional: unified_inventory
|
||||
- 2019-01-12 V2.00 * release
|
||||
- 2019-01-27 V2.01 * SaferLua Controller Terminal added
|
||||
- 2019-01-28 V2.02 * Logic Not added, output reduction on Harvester, Fermenter, and Gravel Sieve
|
||||
- 2019-04-23 V2.03 * Piston/WorldEdit/replacer detection added, farming and grinder recipes added
|
||||
|
||||
|
||||
## New in v2 (from players point of view)
|
||||
|
@ -1,5 +1,21 @@
|
||||
# Release Notes for ModPack TechPack [techpack]
|
||||
|
||||
2019-04-23 V2.03 * ,
|
||||
|
||||
## V2.03 (2019-04-23)
|
||||
|
||||
### Additions
|
||||
- Farming and Grinder recipes added (thanks to obl3pplifp)
|
||||
- Support for Signs Bot chest and Box added
|
||||
|
||||
### Removals
|
||||
|
||||
### Changes
|
||||
|
||||
### Fixes
|
||||
- Piston/WorldEdit/Replacer tool detection added. If node is replaced/removed/copied,
|
||||
it will switch to a "defect" dummy node.
|
||||
|
||||
|
||||
## V2.02.06 (2019-03-23)
|
||||
|
||||
|
@ -33,12 +33,15 @@ end
|
||||
|
||||
|
||||
local function on_time(pos, elasped)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("number")
|
||||
local mem = tubelib.get_data(number, "memory") or table.copy(DEFAULT_MEM)
|
||||
meta:set_string("infotext", "Server "..number..": ("..(mem.size or 0).."/"..SERVER_CAPA..")")
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("sl_controller:server", {
|
||||
description = "Central Server",
|
||||
|
@ -15,6 +15,7 @@
|
||||
|
||||
|
||||
local function switch_on(pos, node)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
node.name = "smartline:button_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.sound_play("button", {
|
||||
@ -36,8 +37,10 @@ local function switch_on(pos, node)
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "on", own_num)
|
||||
end
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "smartline:button"
|
||||
minetest.swap_node(pos, node)
|
||||
@ -57,6 +60,7 @@ local function switch_off(pos)
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "off", own_num)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
minetest.register_node("smartline:button", {
|
||||
|
@ -67,6 +67,7 @@ end
|
||||
|
||||
|
||||
local function on_timer(pos,elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local poll_numbers = meta:get_string("poll_numbers")
|
||||
local idx = meta:get_int("index") + 1
|
||||
@ -89,6 +90,8 @@ local function on_timer(pos,elapsed)
|
||||
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("smartline:collector", {
|
||||
description = "SmartLine State Collector",
|
||||
|
@ -578,6 +578,7 @@ local function execute(meta, number, debug)
|
||||
end
|
||||
|
||||
local function check_rules(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
--local t = minetest.get_us_time()
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("runtime", (meta:get_int("runtime") or 1) + 1)
|
||||
@ -589,6 +590,8 @@ local function check_rules(pos, elapsed)
|
||||
--print("time", minetest.get_us_time() - t)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function switch_state(pos, state, fs_data)
|
||||
local meta = minetest.get_meta(pos)
|
||||
|
@ -28,10 +28,13 @@ local function display_update(pos, objref)
|
||||
end
|
||||
|
||||
local function on_timer(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
lcdlib.update_entities(pos)
|
||||
return false
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local lcd_box = {
|
||||
type = "wallmounted",
|
||||
|
@ -139,12 +139,15 @@ minetest.register_node("smartline:playerdetector", {
|
||||
end,
|
||||
|
||||
on_timer = function (pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
if scan_for_player(pos) then
|
||||
switch_on(pos)
|
||||
minetest.get_node_timer(pos):start(1)
|
||||
return false
|
||||
end
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
paramtype = "light",
|
||||
|
@ -75,9 +75,12 @@ minetest.register_node("smartline:repeater", {
|
||||
end,
|
||||
|
||||
on_timer = function(pos,elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
|
@ -98,6 +98,7 @@ local function restart_timer(pos, time)
|
||||
end
|
||||
|
||||
local function check_rules(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if rules then
|
||||
@ -132,6 +133,8 @@ local function check_rules(pos, elapsed)
|
||||
end
|
||||
return false
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function start_the_sequencer(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
|
@ -86,6 +86,7 @@ local function formspec_help()
|
||||
end
|
||||
|
||||
local function check_rules(pos,elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local hour = math.floor(minetest.get_timeofday() * 24)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local events = minetest.deserialize(meta:get_string("events"))
|
||||
@ -122,6 +123,8 @@ local function check_rules(pos,elapsed)
|
||||
meta:set_string("infotext","SmartLine Timer ("..own_num..")"..hour..":00")
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
|
||||
minetest.register_node("smartline:timer", {
|
||||
|
@ -268,6 +268,7 @@ function techpack_warehouse.after_place_node(self, pos, placer, itemstack)
|
||||
end
|
||||
|
||||
function techpack_warehouse.on_timer(self, pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
if not inv:is_empty("shift") then
|
||||
@ -301,6 +302,8 @@ function techpack_warehouse.on_timer(self, pos, elapsed)
|
||||
|
||||
return self.State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
function techpack_warehouse.can_dig(self, pos)
|
||||
local inv = M(pos):get_inventory()
|
||||
|
@ -16,6 +16,7 @@
|
||||
|
||||
|
||||
local function switch_on(pos, node)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
node.name = "tubelib:button_active"
|
||||
minetest.swap_node(pos, node)
|
||||
minetest.sound_play("button", {
|
||||
@ -37,8 +38,10 @@ local function switch_on(pos, node)
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "on", own_num) -- <<=== tubelib
|
||||
end
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib:button"
|
||||
minetest.swap_node(pos, node)
|
||||
@ -58,6 +61,7 @@ local function switch_off(pos)
|
||||
end
|
||||
tubelib.send_message(numbers, placer_name, clicker_name, "off", own_num) -- <<=== tubelib
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
minetest.register_node("tubelib:button", {
|
||||
|
48
tubelib/defect.lua
Normal file
48
tubelib/defect.lua
Normal file
@ -0,0 +1,48 @@
|
||||
minetest.register_node("tubelib:defect_dummy", {
|
||||
description = "Corrupted Tubelib Node",
|
||||
tiles = {
|
||||
"tubelib_front.png",
|
||||
"tubelib_front.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
"tubelib_front.png^tubelib_defect.png",
|
||||
},
|
||||
drop = "",
|
||||
groups = {cracky=3, crumbly=3, choppy=3, not_in_creative_inventory=1},
|
||||
is_ground_content = false,
|
||||
})
|
||||
|
||||
|
||||
function tubelib.data_not_corrupted(pos)
|
||||
if minetest.pos_to_string(pos) ~= minetest.get_meta(pos):get_string("my_pos") then
|
||||
-- node number corrupt?
|
||||
local meta = minetest.get_meta(pos)
|
||||
local number = meta:get_string("tubelib_number")
|
||||
if number == "" then
|
||||
number = meta:get_string("number")
|
||||
end
|
||||
if number == "" then
|
||||
number = meta:get_string("own_num")
|
||||
end
|
||||
if number == "" then
|
||||
number = meta:get_string("own_number")
|
||||
end
|
||||
if number == "" then
|
||||
tubelib.remove_node(pos)
|
||||
minetest.set_node(pos, {name = "tubelib:defect_dummy"})
|
||||
meta:from_table(nil)
|
||||
return false
|
||||
end
|
||||
-- node moved?
|
||||
local info = tubelib.get_node_info(number)
|
||||
if not info or not vector.equals(info.pos, pos) then
|
||||
tubelib.remove_node(pos)
|
||||
minetest.set_node(pos, {name = "tubelib:defect_dummy"})
|
||||
meta:from_table(nil)
|
||||
return false
|
||||
end
|
||||
minetest.get_meta(pos):get_string("my_pos", minetest.pos_to_string(pos))
|
||||
end
|
||||
return true
|
||||
end
|
@ -270,10 +270,13 @@ end
|
||||
|
||||
-- move items to the output slots
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
distributing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -101,6 +101,7 @@ else
|
||||
-- conversion from v1.16 to v2.00
|
||||
dofile(minetest.get_modpath("tubelib") .. "/migrate.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/states.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/defect.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/node_states.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/pusher.lua")
|
||||
dofile(minetest.get_modpath("tubelib") .. "/blackhole.lua")
|
||||
|
@ -104,4 +104,32 @@ tubelib.register_node("shop:shop", {}, {
|
||||
end,
|
||||
})
|
||||
|
||||
tubelib.register_node("signs_bot:box", {}, {
|
||||
on_pull_item = function(pos, side)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.get_item(meta, "main")
|
||||
end,
|
||||
on_push_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
on_unpull_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
})
|
||||
|
||||
tubelib.register_node("signs_bot:chest", {}, {
|
||||
on_pull_item = function(pos, side)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.get_item(meta, "main")
|
||||
end,
|
||||
on_push_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
on_unpull_item = function(pos, side, item)
|
||||
local meta = minetest.get_meta(pos)
|
||||
return tubelib.put_item(meta, "main", item)
|
||||
end,
|
||||
})
|
||||
|
@ -376,17 +376,9 @@ function NodeStates:on_node_load(pos, not_start_timer)
|
||||
meta:set_int("counter", 0)
|
||||
end
|
||||
|
||||
-- node number corrupt?
|
||||
number = meta:get_string("tubelib_number")
|
||||
if number == "" then
|
||||
number = tubelib.get_new_number(pos, self.node_name_passive)
|
||||
meta:set_string("tubelib_number", number)
|
||||
else
|
||||
local info = tubelib.get_node_info(number)
|
||||
if not info or info.pos ~= pos then
|
||||
number = tubelib.get_new_number(pos, self.node_name_passive)
|
||||
meta:set_string("tubelib_number", number)
|
||||
end
|
||||
-- node corrupt?
|
||||
if not tubelib.data_not_corrupted(pos) then
|
||||
return
|
||||
end
|
||||
|
||||
-- state corrupt?
|
||||
|
@ -66,10 +66,13 @@ local function pushing(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib:pusher", {
|
||||
description = "Tubelib Pusher",
|
||||
|
@ -6,6 +6,12 @@ the automated mining, farming, and crafting.
|
||||
A Tutorial to this Mod is available as ![Wiki](https://github.com/joe7575/techpack/wiki)
|
||||
|
||||
|
||||
With contributions from:
|
||||
* obl3pplifp, https://github.com/obl3pplifp/techpack_compat and as pull requests
|
||||
* realmicu, as pull requests
|
||||
* theFox6, as pull request
|
||||
|
||||
|
||||
## Dependencies
|
||||
tubelib, default
|
||||
opt. unified_inventory
|
||||
|
@ -127,6 +127,7 @@ end
|
||||
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
local craft = get_craft(pos, inv)
|
||||
@ -134,6 +135,8 @@ local function keep_running(pos, elapsed)
|
||||
autocraft(pos, meta, inv, craft)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
-- note, that this function assumes allready being updated to virtual items
|
||||
-- and doesn't handle recipes with stacksizes > 1
|
||||
|
@ -14,6 +14,7 @@
|
||||
|
||||
|
||||
local function switch_on(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib_addons1:detector_active"
|
||||
minetest.swap_node(pos, node)
|
||||
@ -24,8 +25,10 @@ local function switch_on(pos)
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "on", own_num)
|
||||
end
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local node = minetest.get_node(pos)
|
||||
node.name = "tubelib_addons1:detector"
|
||||
minetest.swap_node(pos, node)
|
||||
@ -35,6 +38,7 @@ local function switch_off(pos)
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "off", own_num)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
minetest.register_node("tubelib_addons1:detector", {
|
||||
|
@ -144,10 +144,13 @@ local function convert_leaves_to_biogas(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
convert_leaves_to_biogas(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -103,11 +103,14 @@ local function grinding(pos, meta, inv)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local inv = meta:get_inventory()
|
||||
grinding(pos, meta, inv)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -243,6 +243,7 @@ end
|
||||
|
||||
-- move the "harvesting copter" to the next pos and harvest the field below
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
local this = minetest.deserialize(meta:get_string("this"))
|
||||
this.num_items = 0
|
||||
@ -268,6 +269,8 @@ local function keep_running(pos, elapsed)
|
||||
end
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
|
@ -112,10 +112,13 @@ local function allow_metadata_inventory_take(pos, listname, index, stack, player
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
sample_liquid(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -48,6 +48,7 @@ local tn = tubelib_addons1.register_tree_node
|
||||
local dn = tubelib_addons1.register_default_farming_node
|
||||
local fn = tubelib_addons1.register_farming_node
|
||||
local gn = tubelib_addons1.register_ground_node
|
||||
local gr = tubelib.add_grinder_recipe
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
-- Default Farming
|
||||
@ -103,6 +104,13 @@ if farming.mod == "redo" then
|
||||
fn("farming:oat_8", "farming:oat", "farming:oat_1")
|
||||
fn("farming:rye_8", "farming:rye", "farming:rye_1")
|
||||
fn("farming:rice_8", "farming:rice", "farming:rice_1")
|
||||
fn('farming:beetroot_5', 'farming:beetroot 2', 'farming:beetroot_1')
|
||||
fn('farming:cocoa_4', 'farming:cocoa_beans 2', 'farming:cocoa_1')
|
||||
fn('farming:garlic_5', 'farming:garlic 2', 'farming:garlic_1')
|
||||
fn('farming:onion_5', 'farming:onion 2', 'farming:onion_1')
|
||||
fn('farming:pea_5', 'farming:pea_pod 3', 'farming:pea_1')
|
||||
fn('farming:pepper_5', 'farming:pepper 2', 'farming:pepper_1')
|
||||
fn('farming:pineapple_8', 'farming:pineapple 1', 'farming:pineapple_1')
|
||||
end
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
@ -246,3 +254,55 @@ end
|
||||
|
||||
minetest.after(10, register_flowers)
|
||||
|
||||
-------------------------------------------------------------------------------
|
||||
-- moretrees
|
||||
-------------------------------------------------------------------------------
|
||||
|
||||
if minetest.global_exists("moretrees") then
|
||||
local function register_tree(treename)
|
||||
local trunk_name = 'moretrees:' .. treename .. '_trunk'
|
||||
local sappling_name = 'moretrees:' .. treename .. '_sapling'
|
||||
local leaves_name = 'moretrees:' .. treename .. '_leaves'
|
||||
|
||||
tn(trunk_name, trunk_name, sappling_name)
|
||||
fn(leaves_name)
|
||||
gr({input=trunk_name, output=leaves_name .. ' 8'})
|
||||
end
|
||||
|
||||
-- "ordinary" moretrees blocks
|
||||
for i in ipairs(moretrees.treelist) do
|
||||
local treename = moretrees.treelist[i][1]
|
||||
|
||||
if treename ~= 'jungletree' then
|
||||
register_tree(treename)
|
||||
end
|
||||
end
|
||||
|
||||
-- "weird" moretrees trunks
|
||||
tn('moretrees:date_palm_fruit_trunk', 'moretrees:date_palm_trunk', 'moretrees:date_palm_sapling')
|
||||
gr({input='moretrees:date_palm_fruit_trunk', output='moretrees:date_palm_leaves 8'})
|
||||
tn('moretrees:date_palm_ffruit_trunk', 'moretrees:date_palm_trunk', 'moretrees:date_palm_sapling')
|
||||
gr({input='moretrees:date_palm_ffruit_trunk', output='moretrees:date_palm_leaves 8'})
|
||||
tn('moretrees:date_palm_mfruit_trunk', 'moretrees:date_palm_trunk', 'moretrees:date_palm_sapling')
|
||||
gr({input='moretrees:date_palm_mfruit_trunk', output='moretrees:date_palm_leaves 8'})
|
||||
tn('moretrees:jungletree_trunk', 'default:jungletree', 'default:junglesapling')
|
||||
gr({input='moretrees:jungletree_trunk', output='default:jungleleaves 8'})
|
||||
tn('moretrees:palm_fruit_trunk', 'moretrees:palm_trunk', 'moretrees:palm_sapling')
|
||||
gr({input='moretrees:palm_fruit_trunk', output='moretrees:palm_leaves 8'})
|
||||
tn('moretrees:palm_fruit_trunk_gen', 'moretrees:palm_trunk', 'moretrees:palm_sapling')
|
||||
gr({input='moretrees:palm_fruit_trunk_gen', output='moretrees:palm_leaves 8'})
|
||||
tn('moretrees:rubber_tree_trunk_empty', 'moretrees:rubber_tree_trunk_empty', 'moretrees:rubber_tree_sapling')
|
||||
gr({input='moretrees:rubber_tree_trunk_empty', output='moretrees:rubber_tree_leaves 8'})
|
||||
|
||||
-- moretrees fruit and leaves
|
||||
fn('moretrees:acorn')
|
||||
fn('moretrees:cedar_cone')
|
||||
fn('moretrees:coconut_3', 'moretrees:coconut')
|
||||
fn('moretrees:dates_f4', 'moretrees:date 16')
|
||||
fn('moretrees:fir_cone')
|
||||
fn('moretrees:fir_leaves_bright')
|
||||
fn('moretrees:jungletree_leaves_red')
|
||||
fn('moretrees:jungletree_leaves_yellow')
|
||||
fn('moretrees:spruce_cone')
|
||||
end
|
||||
|
||||
|
@ -66,10 +66,13 @@ local function pushing(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib_addons1:pusher_fast", {
|
||||
description = "Fast Pusher",
|
||||
|
@ -238,10 +238,13 @@ local function quarry_next_node(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
quarry_next_node(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -139,10 +139,13 @@ end
|
||||
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
convert_biogas_to_biofuel(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -13,6 +13,7 @@
|
||||
]]--
|
||||
|
||||
local function switch_on(pos, meta)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
minetest.sound_play("tubelib_addons2_door", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
@ -24,8 +25,10 @@ local function switch_on(pos, meta)
|
||||
tubelib.send_message(numbers, placer_name, nil, "on", number)
|
||||
minetest.get_node_timer(pos):start(4)
|
||||
end
|
||||
end
|
||||
|
||||
local function switch_off(pos)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
minetest.sound_play("tubelib_addons2_door", {
|
||||
pos = pos,
|
||||
gain = 0.5,
|
||||
@ -37,6 +40,7 @@ local function switch_off(pos)
|
||||
local placer_name = meta:get_string("placer_name")
|
||||
tubelib.send_message(numbers, placer_name, nil, "off", number)
|
||||
end
|
||||
end
|
||||
|
||||
local function formspec1(numbers)
|
||||
return "size[6,5]"..
|
||||
|
@ -76,6 +76,7 @@ minetest.register_craft({
|
||||
|
||||
tubelib.register_node("tubelib_addons2:logic_not", {}, {
|
||||
on_recv_message = function(pos, topic, payload)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local owner = meta:get_string("owner")
|
||||
local numbers = meta:get_string("numbers")
|
||||
@ -90,5 +91,6 @@ tubelib.register_node("tubelib_addons2:logic_not", {}, {
|
||||
elseif topic == "off" then
|
||||
return tubelib.send_message(numbers, owner, nil, "on", payload)
|
||||
end
|
||||
end
|
||||
end,
|
||||
})
|
||||
|
@ -108,9 +108,12 @@ minetest.register_node("tubelib_addons2:mesecons_converter", {
|
||||
},
|
||||
|
||||
on_timer = function(pos,elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
|
@ -62,9 +62,12 @@ minetest.register_node("tubelib_addons2:repeater", {
|
||||
end,
|
||||
|
||||
on_timer = function(pos,elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("overload_cnt", 0)
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end,
|
||||
|
||||
after_dig_node = function(pos)
|
||||
|
@ -89,6 +89,7 @@ local function restart_timer(pos, time)
|
||||
end
|
||||
|
||||
local function check_rules(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local rules = minetest.deserialize(meta:get_string("rules"))
|
||||
if rules then
|
||||
@ -123,6 +124,8 @@ local function check_rules(pos, elapsed)
|
||||
end
|
||||
return false
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function start_the_sequencer(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
@ -139,6 +142,7 @@ local function start_the_sequencer(pos)
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local running = meta:get_int("running")
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
@ -189,6 +193,7 @@ local function on_receive_fields(pos, formname, fields, player)
|
||||
meta:set_string("formspec", formspec(tubelib.state(running), rules, endless))
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib_addons2:sequencer", {
|
||||
description = "Tubelib Sequencer",
|
||||
|
@ -67,6 +67,7 @@ end
|
||||
|
||||
|
||||
local function check_rules(pos,elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local hour = math.floor(minetest.get_timeofday() * 24)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local events = minetest.deserialize(meta:get_string("events"))
|
||||
@ -99,6 +100,8 @@ local function check_rules(pos,elapsed)
|
||||
meta:set_string("infotext","Tubelib Timer "..hour..":00")
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
|
||||
minetest.register_node("tubelib_addons2:timer", {
|
||||
|
@ -254,10 +254,13 @@ end
|
||||
|
||||
-- move items to the output slots
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
distributing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, player)
|
||||
if minetest.is_protected(pos, player:get_player_name()) then
|
||||
|
@ -51,10 +51,13 @@ local function pushing(pos, meta)
|
||||
end
|
||||
|
||||
local function keep_running(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = M(pos)
|
||||
pushing(pos, meta)
|
||||
return State:is_active(meta)
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
minetest.register_node("tubelib_addons3:pusher", {
|
||||
description = "HighPerf Pusher",
|
||||
|
@ -90,6 +90,7 @@ local function configured(pos, item)
|
||||
end
|
||||
|
||||
local function shift_items(pos, elapsed)
|
||||
if tubelib.data_not_corrupted(pos) then
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
if not inv:is_empty("shift") then
|
||||
@ -118,6 +119,8 @@ local function shift_items(pos, elapsed)
|
||||
end
|
||||
return true
|
||||
end
|
||||
return false
|
||||
end
|
||||
|
||||
local function formspec()
|
||||
return "size[9,9.2]"..
|
||||
|
Loading…
Reference in New Issue
Block a user