2019-03-08 02:07:41 +02:00
local S = minetest.get_translator ( " mesecons_delayer " )
2018-01-27 18:04:00 +02:00
local DELAYS = { 0.1 , 0.2 , 0.3 , 0.4 }
local DEFAULT_DELAY = DELAYS [ 1 ]
2015-06-29 20:55:56 +03:00
-- Function that get the input/output rules of the delayer
local delayer_get_output_rules = function ( node )
2018-01-13 04:37:41 +02:00
local rules = { { x = - 1 , y = 0 , z = 0 , spread = true } }
2015-06-29 20:55:56 +03:00
for i = 0 , node.param2 do
2017-07-31 01:12:21 +03:00
rules = mesecon.rotate_rules_left ( rules )
2015-06-29 20:55:56 +03:00
end
return rules
end
local delayer_get_input_rules = function ( node )
2017-03-12 01:09:55 +02:00
local rules = { { x = 1 , y = 0 , z = 0 } }
2015-06-29 20:55:56 +03:00
for i = 0 , node.param2 do
2017-07-31 01:12:21 +03:00
rules = mesecon.rotate_rules_left ( rules )
2015-06-29 20:55:56 +03:00
end
return rules
end
2018-01-27 15:32:21 +02:00
-- Return the sides of a delayer.
-- Those are used to toggle the lock state.
local delayer_get_sides = function ( node )
local rules = {
{ x = 0 , y = 0 , z = - 1 } ,
{ x = 0 , y = 0 , z = 1 } ,
}
for i = 0 , node.param2 do
rules = mesecon.rotate_rules_left ( rules )
end
return rules
2018-01-27 06:17:22 +02:00
end
2018-01-27 16:00:58 +02:00
-- Make the repeater at pos try to lock any repeater it faces.
-- Returns true if a repeater was locked.
2018-01-27 07:01:49 +02:00
local check_lock_repeater = function ( pos , node )
2018-01-27 16:00:58 +02:00
-- Check the repeater at pos and look if it faces
-- a repeater placed sideways.
2018-01-27 07:01:49 +02:00
-- If yes, lock the second repeater.
2018-01-27 06:17:22 +02:00
local r = delayer_get_output_rules ( node ) [ 1 ]
local lpos = vector.add ( pos , r )
local lnode = minetest.get_node ( lpos )
local ldef = minetest.registered_nodes [ lnode.name ]
local g = minetest.get_item_group ( lnode.name , " redstone_repeater " )
if g >= 1 and g <= 4 then
local lrs = delayer_get_input_rules ( lnode )
local fail = false
for _ , lr in pairs ( lrs ) do
if lr.x == r.x or lr.z == r.z then
fail = true
break
end
end
if not fail then
2018-01-27 17:10:29 +02:00
minetest.set_node ( lpos , { name = ldef.delayer_lockstate , param2 = lnode.param2 } )
2018-01-27 17:07:59 +02:00
local meta = minetest.get_meta ( lpos )
2018-01-27 18:04:00 +02:00
-- Metadata: delay. Used to remember the delay for locked repeaters.
-- The number is the torch position (1-4).
2018-01-27 17:07:59 +02:00
meta : set_int ( " delay " , g )
2018-01-27 07:01:49 +02:00
return true
2018-01-27 06:17:22 +02:00
end
end
2018-01-27 07:01:49 +02:00
return false
2015-06-29 20:55:56 +03:00
end
2018-01-27 16:00:58 +02:00
-- Make the repeater at pos try to unlock any repeater it faces.
-- Returns true if a repeater was unlocked.
2018-01-27 07:01:49 +02:00
local check_unlock_repeater = function ( pos , node )
2018-01-27 16:00:58 +02:00
-- Check the repeater at pos and look if it faces
-- a repeater placed sideways.
-- If yes, also check if the second repeater doesn't receive
-- a locking signal on the other side. If not, unlock the second repeater.
2018-01-27 06:17:22 +02:00
local r = delayer_get_output_rules ( node ) [ 1 ]
local lpos = vector.add ( pos , r )
local lnode = minetest.get_node ( lpos )
local ldef = minetest.registered_nodes [ lnode.name ]
local g = minetest.get_item_group ( lnode.name , " redstone_repeater " )
2018-01-27 16:00:58 +02:00
-- Are we facing a locked repeater?
2018-01-27 06:17:22 +02:00
if g == 5 then
2018-01-27 16:00:58 +02:00
-- First check the orientation of the faced repeater
2018-01-27 06:17:22 +02:00
local lrs = delayer_get_input_rules ( lnode )
for _ , lr in pairs ( lrs ) do
if lr.x == r.x or lr.z == r.z then
2018-01-27 16:00:58 +02:00
-- Invalid orientation. Do nothing
return false
2018-01-27 06:17:22 +02:00
end
end
2018-01-27 16:00:58 +02:00
-- Now we check if there's a powered repeater on the other side of the
-- locked repeater.
-- To get to the other side, we just take another step in the direction which we already face.
local other_side = vector.add ( lpos , r )
local other_node = minetest.get_node ( other_side )
if minetest.get_item_group ( other_node.name , " redstone_repeater " ) ~= 0 and mesecon.is_receptor_on ( other_node.name ) then
-- Final check: The other repeater must also face the right way
local other_face = delayer_get_output_rules ( other_node ) [ 1 ]
local other_facing_pos = vector.add ( other_side , other_face )
if vector.equals ( other_facing_pos , lpos ) then
-- Powered repeater found AND it's facing the locked repeater. Do NOT unlock!
return false
2018-01-27 06:43:05 +02:00
end
2018-01-27 06:17:22 +02:00
end
2018-01-27 17:07:59 +02:00
local lmeta = minetest.get_meta ( lpos )
local ldelay = lmeta : get_int ( " delay " )
if tonumber ( ldelay ) == nil or ldelay < 1 or ldelay > 4 then
ldelay = 1
end
2018-01-27 16:00:58 +02:00
if mesecon.is_powered ( lpos , delayer_get_input_rules ( lnode ) [ 1 ] ) then
2018-01-27 17:10:29 +02:00
minetest.set_node ( lpos , { name = " mesecons_delayer:delayer_on_ " .. ldelay , param2 = lnode.param2 } )
2018-01-27 16:00:58 +02:00
mesecon.queue : add_action ( lpos , " receptor_on " , { delayer_get_output_rules ( lnode ) } , ldef.delayer_time , nil )
else
2018-01-27 17:10:29 +02:00
minetest.set_node ( lpos , { name = " mesecons_delayer:delayer_off_ " .. ldelay , param2 = lnode.param2 } )
2018-01-27 16:00:58 +02:00
mesecon.queue : add_action ( lpos , " receptor_off " , { delayer_get_output_rules ( lnode ) } , ldef.delayer_time , nil )
end
return true
2018-01-27 06:17:22 +02:00
end
2018-01-27 07:01:49 +02:00
return false
end
-- Functions that are called after the delay time
local delayer_activate = function ( pos , node )
local def = minetest.registered_nodes [ node.name ]
local time = def.delayer_time
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = def.delayer_onstate , param2 = node.param2 } )
2018-01-27 07:01:49 +02:00
mesecon.queue : add_action ( pos , " receptor_on " , { delayer_get_output_rules ( node ) } , time , nil )
check_lock_repeater ( pos , node )
end
local delayer_deactivate = function ( pos , node )
local def = minetest.registered_nodes [ node.name ]
local time = def.delayer_time
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = def.delayer_offstate , param2 = node.param2 } )
2018-01-27 07:01:49 +02:00
mesecon.queue : add_action ( pos , " receptor_off " , { delayer_get_output_rules ( node ) } , time , nil )
check_unlock_repeater ( pos , node )
2015-06-29 20:55:56 +03:00
end
2018-02-02 04:46:27 +02:00
local on_rotate
if minetest.get_modpath ( " screwdriver " ) then
on_rotate = screwdriver.disallow
end
2015-06-29 20:55:56 +03:00
-- Register the 2 (states) x 4 (delay times) delayers
for i = 1 , 4 do
local groups = { }
if i == 1 then
2018-01-27 06:17:22 +02:00
groups = { dig_immediate = 3 , dig_by_water = 1 , destroy_by_lava_flow = 1 , dig_by_piston = 1 , attached_node = 1 , redstone_repeater = i }
2015-06-29 20:55:56 +03:00
else
2018-01-27 06:17:22 +02:00
groups = { dig_immediate = 3 , dig_by_water = 1 , destroy_by_lava_flow = 1 , dig_by_piston = 1 , attached_node = 1 , redstone_repeater = i , not_in_creative_inventory = 1 }
2015-06-29 20:55:56 +03:00
end
2018-01-27 18:04:00 +02:00
local delaytime = DELAYS [ i ]
2015-06-29 20:55:56 +03:00
local boxes
if i == 1 then
boxes = {
{ - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } , -- the main slab
2017-03-12 01:09:55 +02:00
{ - 1 / 16 , - 6 / 16 , 6 / 16 , 1 / 16 , - 1 / 16 , 4 / 16 } , -- still torch
{ - 1 / 16 , - 6 / 16 , 0 / 16 , 1 / 16 , - 1 / 16 , 2 / 16 } , -- moved torch
2015-06-29 20:55:56 +03:00
}
elseif i == 2 then
boxes = {
{ - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } , -- the main slab
2017-03-12 01:09:55 +02:00
{ - 1 / 16 , - 6 / 16 , 6 / 16 , 1 / 16 , - 1 / 16 , 4 / 16 } , -- still torch
{ - 1 / 16 , - 6 / 16 , - 2 / 16 , 1 / 16 , - 1 / 16 , 0 / 16 } , -- moved torch
2015-06-29 20:55:56 +03:00
}
elseif i == 3 then
boxes = {
{ - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } , -- the main slab
2017-03-12 01:09:55 +02:00
{ - 1 / 16 , - 6 / 16 , 6 / 16 , 1 / 16 , - 1 / 16 , 4 / 16 } , -- still torch
{ - 1 / 16 , - 6 / 16 , - 4 / 16 , 1 / 16 , - 1 / 16 , - 2 / 16 } , -- moved torch
2015-06-29 20:55:56 +03:00
}
elseif i == 4 then
boxes = {
{ - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } , -- the main slab
2017-03-12 01:09:55 +02:00
{ - 1 / 16 , - 6 / 16 , 6 / 16 , 1 / 16 , - 1 / 16 , 4 / 16 } , -- still torch
{ - 1 / 16 , - 6 / 16 , - 6 / 16 , 1 / 16 , - 1 / 16 , - 4 / 16 } , -- moved torch
2015-06-29 20:55:56 +03:00
}
end
2020-02-19 05:54:17 +02:00
local help , tt , longdesc , usagehelp , icon , on_construct
2017-03-12 01:17:10 +02:00
if i == 1 then
help = true
2020-03-12 02:35:11 +02:00
tt = S ( " Transmits redstone power only in one direction " ) .. " \n " ..
S ( " Delays signal " ) .. " \n " ..
S ( " Output locks when getting active redstone repeater signal from the side " )
2019-03-08 02:07:41 +02:00
longdesc = S ( " Redstone repeaters are versatile redstone components with multiple purposes: 1. They only allow signals to travel in one direction. 2. They delay the signal. 3. Optionally, they can lock their output in one state. " )
2019-03-16 03:00:48 +02:00
usagehelp = S ( " To power a redstone repeater, send a signal in “arrow” direction (the input). The signal goes out on the opposite side (the output) with a delay. To change the delay, use the redstone repeater. The delay is between 0.1 and 0.4 seconds long and can be changed in steps of 0.1 seconds. It is indicated by the position of the moving redstone torch. " ) .. " \n " ..
2019-03-08 02:07:41 +02:00
S ( " To lock a repeater, send a signal from an adjacent repeater into one of its sides. While locked, the moving redstone torch disappears, the output doesn't change and the input signal is ignored. " )
2017-03-12 01:17:10 +02:00
icon = " mesecons_delayer_item.png "
2018-01-27 17:35:56 +02:00
-- Check sides of constructed repeater and lock it, if required
2018-01-27 15:32:21 +02:00
on_construct = function ( pos )
local node = minetest.get_node ( pos )
local sides = delayer_get_sides ( node )
for s = 1 , # sides do
local spos = vector.add ( pos , sides [ s ] )
local snode = minetest.get_node ( spos )
2018-01-27 17:35:56 +02:00
-- Is there a powered repeater at one of our sides?
2018-01-27 15:32:21 +02:00
local g = minetest.get_item_group ( snode.name , " redstone_repeater " )
2018-01-27 17:25:38 +02:00
if g ~= 0 and mesecon.is_receptor_on ( snode.name ) then
2018-01-27 17:35:56 +02:00
-- The other repeater must also face towards the constructed node
local sface = delayer_get_output_rules ( snode ) [ 1 ]
local sface_pos = vector.add ( spos , sface )
if vector.equals ( sface_pos , pos ) then
-- Repeater is facing towards us! Now we just need to lock the costructed node
if mesecon.is_powered ( pos , delayer_get_input_rules ( node ) [ 1 ] ) ~= false then
2018-01-27 18:04:00 +02:00
local newnode = { name = " mesecons_delayer:delayer_on_locked " , param2 = node.param2 }
minetest.set_node ( pos , newnode )
mesecon.queue : add_action ( pos , " receptor_on " , { delayer_get_output_rules ( newnode ) } , DEFAULT_DELAY , nil )
2018-01-27 17:35:56 +02:00
else
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_off_locked " , param2 = node.param2 } )
end
break
2018-01-27 15:32:21 +02:00
end
end
end
end
2017-03-12 01:17:10 +02:00
else
help = false
2017-03-12 00:28:22 +02:00
end
2019-12-09 23:32:40 +02:00
local desc_off
if i == 1 then
desc_off = S ( " Redstone Repeater " )
else
desc_off = S ( " Redstone Repeater (Delay @1) " , i )
end
2015-06-29 20:55:56 +03:00
minetest.register_node ( " mesecons_delayer:delayer_off_ " .. tostring ( i ) , {
2019-12-09 23:32:40 +02:00
description = desc_off ,
2017-03-12 01:17:10 +02:00
inventory_image = icon ,
wield_image = icon ,
2020-02-19 05:54:17 +02:00
_tt_help = tt ,
2017-03-12 00:28:22 +02:00
_doc_items_create_entry = help ,
_doc_items_longdesc = longdesc ,
_doc_items_usagehelp = usagehelp ,
2015-06-29 20:55:56 +03:00
drawtype = " nodebox " ,
t iles = {
" mesecons_delayer_off.png " ,
2017-06-05 19:40:56 +03:00
" mcl_stairs_stone_slab_top.png " ,
2017-03-12 01:09:55 +02:00
" mesecons_delayer_sides_off.png " ,
" mesecons_delayer_sides_off.png " ,
2015-06-29 20:55:56 +03:00
" mesecons_delayer_ends_off.png " ,
" mesecons_delayer_ends_off.png " ,
2021-02-18 15:00:17 +02:00
} ,
use_texture_alpha = minetest.features . use_texture_alpha_string_modes and " opaque " or false ,
2015-06-29 20:55:56 +03:00
wield_image = " mesecons_delayer_off.png " ,
walkable = true ,
selection_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
2017-03-12 00:38:15 +02:00
collision_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
2015-06-29 20:55:56 +03:00
node_box = {
type = " fixed " ,
fixed = boxes
} ,
groups = groups ,
paramtype = " light " ,
paramtype2 = " facedir " ,
2017-03-12 01:54:16 +02:00
sunlight_propagates = false ,
2017-01-04 23:36:51 +02:00
is_ground_content = false ,
2015-06-29 20:55:56 +03:00
drop = ' mesecons_delayer:delayer_off_1 ' ,
2019-02-08 22:59:01 +02:00
on_rightclick = function ( pos , node , clicker )
local protname = clicker : get_player_name ( )
if minetest.is_protected ( pos , protname ) then
2019-02-08 23:17:51 +02:00
minetest.record_protection_violation ( pos , protname )
2019-02-08 22:59:01 +02:00
return
end
2015-06-29 20:55:56 +03:00
if node.name == " mesecons_delayer:delayer_off_1 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_off_2 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
elseif node.name == " mesecons_delayer:delayer_off_2 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_off_3 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
elseif node.name == " mesecons_delayer:delayer_off_3 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_off_4 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
elseif node.name == " mesecons_delayer:delayer_off_4 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_off_1 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
end
end ,
2018-01-27 15:32:21 +02:00
on_construct = on_construct ,
2015-06-29 20:55:56 +03:00
delayer_time = delaytime ,
delayer_onstate = " mesecons_delayer:delayer_on_ " .. tostring ( i ) ,
2018-01-27 06:17:22 +02:00
delayer_lockstate = " mesecons_delayer:delayer_off_locked " ,
2017-02-11 19:46:23 +02:00
sounds = mcl_sounds.node_sound_stone_defaults ( ) ,
2015-06-29 20:55:56 +03:00
mesecons = {
receptor =
{
state = mesecon.state . off ,
rules = delayer_get_output_rules
} ,
effector =
{
rules = delayer_get_input_rules ,
action_on = delayer_activate
}
2017-12-05 15:09:39 +02:00
} ,
on_rotate = on_rotate ,
2015-06-29 20:55:56 +03:00
} )
minetest.register_node ( " mesecons_delayer:delayer_on_ " .. tostring ( i ) , {
2019-12-09 23:32:40 +02:00
description = S ( " Redstone Repeater (Delay @1, Powered) " , i ) ,
2017-03-02 20:53:53 +02:00
_doc_items_create_entry = false ,
2015-06-29 20:55:56 +03:00
drawtype = " nodebox " ,
tiles = {
" mesecons_delayer_on.png " ,
2017-06-05 19:40:56 +03:00
" mcl_stairs_stone_slab_top.png " ,
2017-03-12 01:09:55 +02:00
" mesecons_delayer_sides_on.png " ,
" mesecons_delayer_sides_on.png " ,
2015-06-29 20:55:56 +03:00
" mesecons_delayer_ends_on.png " ,
" mesecons_delayer_ends_on.png " ,
2021-02-18 15:00:17 +02:00
} ,
use_texture_alpha = minetest.features . use_texture_alpha_string_modes and " opaque " or false ,
2015-06-29 20:55:56 +03:00
walkable = true ,
selection_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
2017-03-12 00:38:15 +02:00
collision_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
2015-06-29 20:55:56 +03:00
node_box = {
type = " fixed " ,
fixed = boxes
} ,
2018-01-27 06:17:22 +02:00
groups = { dig_immediate = 3 , dig_by_water = 1 , destroy_by_lava_flow = 1 , dig_by_piston = 1 , attached_node = 1 , redstone_repeater = i , not_in_creative_inventory = 1 } ,
2015-06-29 20:55:56 +03:00
paramtype = " light " ,
paramtype2 = " facedir " ,
2017-03-12 01:54:16 +02:00
sunlight_propagates = false ,
2017-01-04 23:36:51 +02:00
is_ground_content = false ,
2015-06-29 20:55:56 +03:00
drop = ' mesecons_delayer:delayer_off_1 ' ,
2019-02-08 22:59:01 +02:00
on_rightclick = function ( pos , node , clicker )
local protname = clicker : get_player_name ( )
if minetest.is_protected ( pos , protname ) then
2019-02-08 23:17:51 +02:00
minetest.record_protection_violation ( pos , protname )
2019-02-08 22:59:01 +02:00
return
end
2015-06-29 20:55:56 +03:00
if node.name == " mesecons_delayer:delayer_on_1 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_on_2 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
elseif node.name == " mesecons_delayer:delayer_on_2 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_on_3 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
elseif node.name == " mesecons_delayer:delayer_on_3 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_on_4 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
elseif node.name == " mesecons_delayer:delayer_on_4 " then
2018-01-27 17:10:29 +02:00
minetest.set_node ( pos , { name = " mesecons_delayer:delayer_on_1 " , param2 = node.param2 } )
2015-06-29 20:55:56 +03:00
end
end ,
2018-01-27 17:10:29 +02:00
after_dig_node = function ( pos , oldnode )
2018-01-27 07:01:49 +02:00
check_unlock_repeater ( pos , oldnode )
end ,
2015-06-29 20:55:56 +03:00
delayer_time = delaytime ,
delayer_offstate = " mesecons_delayer:delayer_off_ " .. tostring ( i ) ,
2018-01-27 06:17:22 +02:00
delayer_lockstate = " mesecons_delayer:delayer_on_locked " ,
2018-01-26 23:05:47 +02:00
sounds = mcl_sounds.node_sound_stone_defaults ( ) ,
2015-06-29 20:55:56 +03:00
mesecons = {
receptor =
{
state = mesecon.state . on ,
rules = delayer_get_output_rules
} ,
effector =
{
rules = delayer_get_input_rules ,
action_off = delayer_deactivate
}
2017-12-05 15:09:39 +02:00
} ,
on_rotate = on_rotate ,
2015-06-29 20:55:56 +03:00
} )
2018-01-27 05:36:17 +02:00
2015-06-29 20:55:56 +03:00
end
2018-01-27 06:17:22 +02:00
-- Locked repeater
2018-01-27 05:36:17 +02:00
minetest.register_node ( " mesecons_delayer:delayer_off_locked " , {
2019-03-08 02:07:41 +02:00
description = S ( " Redstone Repeater (Locked) " ) ,
2018-01-27 05:36:17 +02:00
_doc_items_create_entry = false ,
drawtype = " nodebox " ,
-- FIXME: Textures of torch and the lock bar overlap. Nodeboxes are (sadly) not suitable for this.
-- So this needs to be turned into a mesh.
tiles = {
" mesecons_delayer_locked_off.png " ,
" mcl_stairs_stone_slab_top.png " ,
" mesecons_delayer_sides_locked_off.png " ,
2018-01-27 06:23:40 +02:00
" mesecons_delayer_sides_locked_off.png " ,
2018-01-27 05:36:17 +02:00
" mesecons_delayer_front_locked_off.png " ,
" mesecons_delayer_end_locked_off.png " ,
2021-02-18 15:00:17 +02:00
} ,
use_texture_alpha = minetest.features . use_texture_alpha_string_modes and " opaque " or false ,
2018-01-27 05:36:17 +02:00
wield_image = " mesecons_delayer_locked_off.png " ,
walkable = true ,
selection_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
collision_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
node_box = {
type = " fixed " ,
fixed = {
{ - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } , -- the main slab
{ - 1 / 16 , - 6 / 16 , 6 / 16 , 1 / 16 , - 1 / 16 , 4 / 16 } , -- still torch
2018-01-27 17:22:59 +02:00
{ - 6 / 16 , - 6 / 16 , - 1 / 16 , 6 / 16 , - 4 / 16 , 1 / 16 } , -- lock
2018-01-27 05:36:17 +02:00
}
} ,
2018-01-27 06:17:22 +02:00
groups = { dig_immediate = 3 , dig_by_water = 1 , destroy_by_lava_flow = 1 , dig_by_piston = 1 , attached_node = 1 , redstone_repeater = 5 , not_in_creative_inventory = 1 } ,
2018-01-27 05:36:17 +02:00
paramtype = " light " ,
paramtype2 = " facedir " ,
sunlight_propagates = false ,
is_ground_content = false ,
drop = ' mesecons_delayer:delayer_off_1 ' ,
2018-01-27 18:04:00 +02:00
delayer_time = DEFAULT_DELAY ,
2018-01-27 05:36:17 +02:00
sounds = mcl_sounds.node_sound_stone_defaults ( ) ,
mesecons = {
receptor =
{
state = mesecon.state . off ,
rules = delayer_get_output_rules
} ,
effector =
{
rules = delayer_get_input_rules ,
}
} ,
on_rotate = on_rotate ,
} )
minetest.register_node ( " mesecons_delayer:delayer_on_locked " , {
2019-03-08 02:07:41 +02:00
description = S ( " Redstone Repeater (Locked, Powered) " ) ,
2018-01-27 05:36:17 +02:00
_doc_items_create_entry = false ,
drawtype = " nodebox " ,
tiles = {
" mesecons_delayer_locked_on.png " ,
" mcl_stairs_stone_slab_top.png " ,
" mesecons_delayer_sides_locked_on.png " ,
2018-01-27 06:23:40 +02:00
" mesecons_delayer_sides_locked_on.png " ,
2018-01-27 05:36:17 +02:00
" mesecons_delayer_front_locked_on.png " ,
" mesecons_delayer_end_locked_on.png " ,
2021-02-18 15:00:17 +02:00
} ,
use_texture_alpha = minetest.features . use_texture_alpha_string_modes and " opaque " or false ,
2018-01-27 05:36:17 +02:00
walkable = true ,
selection_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
collision_box = {
type = " fixed " ,
fixed = { - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } ,
} ,
node_box = {
type = " fixed " ,
fixed = {
{ - 8 / 16 , - 8 / 16 , - 8 / 16 , 8 / 16 , - 6 / 16 , 8 / 16 } , -- the main slab
{ - 1 / 16 , - 6 / 16 , 6 / 16 , 1 / 16 , - 1 / 16 , 4 / 16 } , -- still torch
2018-01-27 17:22:59 +02:00
{ - 6 / 16 , - 6 / 16 , - 1 / 16 , 6 / 16 , - 4 / 16 , 1 / 16 } , -- lock
2018-01-27 05:36:17 +02:00
}
} ,
2018-01-27 17:10:29 +02:00
after_dig_node = function ( pos , oldnode )
2018-01-27 07:01:49 +02:00
check_unlock_repeater ( pos , oldnode )
end ,
2018-01-27 06:17:22 +02:00
groups = { dig_immediate = 3 , dig_by_water = 1 , destroy_by_lava_flow = 1 , dig_by_piston = 1 , attached_node = 1 , redstone_repeater = 5 , not_in_creative_inventory = 1 } ,
2018-01-27 05:36:17 +02:00
paramtype = " light " ,
paramtype2 = " facedir " ,
sunlight_propagates = false ,
is_ground_content = false ,
drop = ' mesecons_delayer:delayer_off_1 ' ,
2018-01-27 18:04:00 +02:00
delayer_time = DEFAULT_DELAY ,
2018-01-27 05:36:17 +02:00
sounds = mcl_sounds.node_sound_stone_defaults ( ) ,
mesecons = {
receptor =
{
state = mesecon.state . on ,
rules = delayer_get_output_rules
} ,
effector =
{
rules = delayer_get_input_rules ,
}
} ,
on_rotate = on_rotate ,
} )
2015-06-29 20:55:56 +03:00
minetest.register_craft ( {
output = " mesecons_delayer:delayer_off_1 " ,
recipe = {
2017-02-08 02:44:07 +02:00
{ " mesecons_torch:mesecon_torch_on " , " mesecons:redstone " , " mesecons_torch:mesecon_torch_on " } ,
2017-02-01 00:32:56 +02:00
{ " mcl_core:stone " , " mcl_core:stone " , " mcl_core:stone " } ,
2015-06-29 20:55:56 +03:00
}
} )
2017-03-21 05:27:50 +02:00
-- Add entry aliases for the Help
if minetest.get_modpath ( " doc " ) then
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_off_2 " )
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_off_3 " )
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_off_4 " )
2018-01-27 05:36:17 +02:00
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_off_locked " )
2017-03-21 05:27:50 +02:00
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_on_1 " )
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_on_2 " )
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_on_3 " )
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_on_4 " )
2018-01-27 05:36:17 +02:00
doc.add_entry_alias ( " nodes " , " mesecons_delayer:delayer_off_1 " , " nodes " , " mesecons_delayer:delayer_on_locked " )
2017-03-21 05:27:50 +02:00
end