Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
1afb8f77a0 | |||
|
69445d1eb4 | ||
|
7b9d711a91 | ||
|
cd3f250303 | ||
|
fcf6b7b6ff | ||
|
156b47f8b9 | ||
|
fed7295111 |
30
breaker.lua
30
breaker.lua
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -223,29 +223,6 @@ end
|
|||||||
|
|
||||||
|
|
||||||
local function eject_item (pos, stack, eject_pos)
|
local function eject_item (pos, stack, eject_pos)
|
||||||
if utils.pipeworks_supported then
|
|
||||||
local node = utils.get_far_node (eject_pos)
|
|
||||||
|
|
||||||
if node and minetest.get_item_group (node.name, "tube") > 0 then
|
|
||||||
local owner = nil
|
|
||||||
local meta = minetest.get_meta (pos)
|
|
||||||
|
|
||||||
if meta then
|
|
||||||
local o = meta:get_string ("owner")
|
|
||||||
|
|
||||||
if o ~= "" then
|
|
||||||
owner = o
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local vel = vector.subtract (eject_pos, pos)
|
|
||||||
|
|
||||||
pipeworks.tube_inject_item (pos, pos, vel, stack, owner)
|
|
||||||
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
utils.item_drop (stack, nil, eject_pos)
|
utils.item_drop (stack, nil, eject_pos)
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -739,7 +716,6 @@ minetest.register_node("lwcomponents:breaker", {
|
|||||||
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face.png"},
|
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (breaker_groups),
|
groups = table.copy (breaker_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -770,7 +746,6 @@ minetest.register_node("lwcomponents:breaker_locked", {
|
|||||||
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face.png"},
|
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (breaker_groups),
|
groups = table.copy (breaker_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -802,7 +777,6 @@ minetest.register_node("lwcomponents:breaker_on", {
|
|||||||
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face_on.png"},
|
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (breaker_on_groups),
|
groups = table.copy (breaker_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -834,7 +808,6 @@ minetest.register_node("lwcomponents:breaker_locked_on", {
|
|||||||
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face_on.png"},
|
"lwbreaker.png", "lwbreaker_rear.png", "lwbreaker_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (breaker_on_groups),
|
groups = table.copy (breaker_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -888,4 +861,3 @@ utils.hopper_add_container({
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
@@ -386,7 +386,6 @@ minetest.register_node("lwcomponents:camera", {
|
|||||||
"lwcamera.png", "lwcamera.png", "lwcamera_lens.png"},
|
"lwcamera.png", "lwcamera.png", "lwcamera_lens.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 },
|
groups = { cracky = 3 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -412,7 +411,6 @@ minetest.register_node("lwcomponents:camera_locked", {
|
|||||||
"lwcamera.png", "lwcamera.png", "lwcamera_lens.png"},
|
"lwcamera.png", "lwcamera.png", "lwcamera_lens.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 },
|
groups = { cracky = 3 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
|
@@ -1011,7 +1011,6 @@ minetest.register_node("lwcomponents:cannon", {
|
|||||||
inventory_image = "lwcannon_item.png",
|
inventory_image = "lwcannon_item.png",
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (cannon_groups),
|
groups = table.copy (cannon_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
param2 = 0,
|
param2 = 0,
|
||||||
@@ -1075,7 +1074,6 @@ minetest.register_node("lwcomponents:cannon_locked", {
|
|||||||
inventory_image = "lwcannon_item.png",
|
inventory_image = "lwcannon_item.png",
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (cannon_groups),
|
groups = table.copy (cannon_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
param2 = 0,
|
param2 = 0,
|
||||||
|
16
change.log
16
change.log
@@ -180,3 +180,19 @@ v0.1.29
|
|||||||
v0.1.30
|
v0.1.30
|
||||||
* Added quantity field to droppers.
|
* Added quantity field to droppers.
|
||||||
* Added 'Use player when placing' setting.
|
* Added 'Use player when placing' setting.
|
||||||
|
|
||||||
|
|
||||||
|
v0.1.31
|
||||||
|
* Added crafter.
|
||||||
|
|
||||||
|
|
||||||
|
v0.1.32
|
||||||
|
* Fixed crafter not return replacement items properly.
|
||||||
|
|
||||||
|
|
||||||
|
v0.1.33
|
||||||
|
* Added recipe list when crafting by item to UI in crafters.
|
||||||
|
* Added results message for crafters digilines messages "craft" and "craftitem".
|
||||||
|
* Added "can_craft" digilines message to crafters.
|
||||||
|
* Fixed crafter not outputing all items when output has full stack.
|
||||||
|
* Improved crafter crafting.
|
||||||
|
@@ -549,7 +549,6 @@ minetest.register_node("lwcomponents:collector", {
|
|||||||
"lwcollector.png", "lwcollector.png", "lwcollector.png"},
|
"lwcollector.png", "lwcollector.png", "lwcollector.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (collector_groups),
|
groups = table.copy (collector_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -577,7 +576,6 @@ minetest.register_node("lwcomponents:collector_locked", {
|
|||||||
"lwcollector.png", "lwcollector.png", "lwcollector.png"},
|
"lwcollector.png", "lwcollector.png", "lwcollector.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (collector_groups),
|
groups = table.copy (collector_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -605,7 +603,6 @@ minetest.register_node("lwcomponents:collector_on", {
|
|||||||
"lwcollector_on.png", "lwcollector_on.png", "lwcollector_on.png"},
|
"lwcollector_on.png", "lwcollector_on.png", "lwcollector_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (collector_on_groups),
|
groups = table.copy (collector_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -633,7 +630,6 @@ minetest.register_node("lwcomponents:collector_locked_on", {
|
|||||||
"lwcollector_on.png", "lwcollector_on.png", "lwcollector_on.png"},
|
"lwcollector_on.png", "lwcollector_on.png", "lwcollector_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (collector_on_groups),
|
groups = table.copy (collector_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
|
@@ -1075,7 +1075,6 @@ minetest.register_node("lwcomponents:conduit", {
|
|||||||
},
|
},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (conduit_groups),
|
groups = table.copy (conduit_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
@@ -1146,7 +1145,6 @@ minetest.register_node("lwcomponents:conduit_locked", {
|
|||||||
},
|
},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (conduit_groups),
|
groups = table.copy (conduit_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
|
1939
crafter.lua
Normal file
1939
crafter.lua
Normal file
File diff suppressed because it is too large
Load Diff
20
crafting.lua
20
crafting.lua
@@ -60,6 +60,26 @@ minetest.register_craft( {
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
minetest.register_craft( {
|
||||||
|
output = "lwcomponents:crafter",
|
||||||
|
recipe = {
|
||||||
|
{ "default:steel_ingot", "group:wood", "default:steel_ingot" },
|
||||||
|
{ "group:wood", "", "group:wood" },
|
||||||
|
{ "default:copper_ingot", "group:wood", "default:chest" },
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
minetest.register_craft( {
|
||||||
|
output = "lwcomponents:crafter_locked",
|
||||||
|
recipe = {
|
||||||
|
{ "default:steel_ingot", "group:wood", "default:steel_ingot" },
|
||||||
|
{ "group:wood", "", "group:wood" },
|
||||||
|
{ "default:copper_ingot", "group:wood", "default:chest_locked" },
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
minetest.register_craft( {
|
minetest.register_craft( {
|
||||||
output = "lwcomponents:force_field",
|
output = "lwcomponents:force_field",
|
||||||
recipe = {
|
recipe = {
|
||||||
|
5
crafting_mods.lua
Normal file
5
crafting_mods.lua
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
return
|
||||||
|
{
|
||||||
|
-- ["mod:crafted_item"] = { add = { "mod:name n", "mod:name n" }, remove = { "mod:name n", "mod:name n" } },
|
||||||
|
["farming:pineapple_ring"] = { add = { "farming:pineapple_top" } }
|
||||||
|
}
|
@@ -1,9 +0,0 @@
|
|||||||
default
|
|
||||||
mesecons?
|
|
||||||
digilines?
|
|
||||||
unifieddyes?
|
|
||||||
intllib?
|
|
||||||
hopper?
|
|
||||||
digistuff?
|
|
||||||
pipeworks?
|
|
||||||
lwwires?
|
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -663,7 +663,6 @@ minetest.register_node("lwcomponents:deployer", {
|
|||||||
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face.png"},
|
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (deployer_groups),
|
groups = table.copy (deployer_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -692,7 +691,6 @@ minetest.register_node("lwcomponents:deployer_locked", {
|
|||||||
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face.png"},
|
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (deployer_groups),
|
groups = table.copy (deployer_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -722,7 +720,6 @@ minetest.register_node("lwcomponents:deployer_on", {
|
|||||||
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face_on.png"},
|
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (deployer_on_groups),
|
groups = table.copy (deployer_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -753,7 +750,6 @@ minetest.register_node("lwcomponents:deployer_locked_on", {
|
|||||||
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face_on.png"},
|
"lwdeployer.png", "lwdeployer.png", "lwdeployer_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (deployer_on_groups),
|
groups = table.copy (deployer_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -809,7 +805,6 @@ utils.hopper_add_container({
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@@ -1 +0,0 @@
|
|||||||
Various components for mesecons and digilines.
|
|
@@ -137,7 +137,6 @@ minetest.register_node("lwcomponents:destroyer", {
|
|||||||
"lwcomponents_destroyer_side.png", "lwcomponents_destroyer_side.png" },
|
"lwcomponents_destroyer_side.png", "lwcomponents_destroyer_side.png" },
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (destroyer_groups),
|
groups = table.copy (destroyer_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -731,7 +731,6 @@ minetest.register_node("lwcomponents:detector", {
|
|||||||
"lwdetector.png", "lwdetector.png", "lwdetector_face.png"},
|
"lwdetector.png", "lwdetector.png", "lwdetector_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -760,7 +759,6 @@ minetest.register_node("lwcomponents:detector_locked", {
|
|||||||
"lwdetector.png", "lwdetector.png", "lwdetector_face.png"},
|
"lwdetector.png", "lwdetector.png", "lwdetector_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -789,7 +787,6 @@ minetest.register_node("lwcomponents:detector_on", {
|
|||||||
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -818,7 +815,6 @@ minetest.register_node("lwcomponents:detector_locked_on", {
|
|||||||
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -847,7 +843,6 @@ minetest.register_node("lwcomponents:detector_on_on", {
|
|||||||
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -876,7 +871,6 @@ minetest.register_node("lwcomponents:detector_locked_on_on", {
|
|||||||
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
"lwdetector.png", "lwdetector.png", "lwdetector_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -899,7 +893,6 @@ minetest.register_node("lwcomponents:detector_locked_on_on", {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@@ -335,7 +335,6 @@ minetest.register_node ("lwcomponents:digiswitch", {
|
|||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
groups = { cracky = 2, oddly_breakable_by_hand = 2, wires_connect = 1 },
|
groups = { cracky = 2, oddly_breakable_by_hand = 2, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
mesecons = mesecon_support (),
|
mesecons = mesecon_support (),
|
||||||
digiline = digilines_support (),
|
digiline = digilines_support (),
|
||||||
_digistuff_channelcopier_fieldname = "channel",
|
_digistuff_channelcopier_fieldname = "channel",
|
||||||
@@ -363,7 +362,6 @@ minetest.register_node ("lwcomponents:digiswitch_on", {
|
|||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
groups = { cracky = 2, oddly_breakable_by_hand = 2, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 2, oddly_breakable_by_hand = 2, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
mesecons = mesecon_support_on (),
|
mesecons = mesecon_support_on (),
|
||||||
digiline = digilines_support (),
|
digiline = digilines_support (),
|
||||||
_digistuff_channelcopier_fieldname = "channel",
|
_digistuff_channelcopier_fieldname = "channel",
|
||||||
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -527,7 +527,6 @@ minetest.register_node("lwcomponents:dispenser", {
|
|||||||
"lwdispenser.png", "lwdispenser.png", "lwdispenser_face.png"},
|
"lwdispenser.png", "lwdispenser.png", "lwdispenser_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (dispenser_groups),
|
groups = table.copy (dispenser_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -555,7 +554,6 @@ minetest.register_node("lwcomponents:dispenser_locked", {
|
|||||||
"lwdispenser.png", "lwdispenser.png", "lwdispenser_face.png"},
|
"lwdispenser.png", "lwdispenser.png", "lwdispenser_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (dispenser_groups),
|
groups = table.copy (dispenser_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -593,7 +591,6 @@ utils.hopper_add_container({
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
163
docs/crafter.txt
Normal file
163
docs/crafter.txt
Normal file
@@ -0,0 +1,163 @@
|
|||||||
|
Crafter
|
||||||
|
-------
|
||||||
|
|
||||||
|
Crafters can craft items by recipe or desired output item. Crafted items
|
||||||
|
are placed in the Output inventory, along with any replacement items (for
|
||||||
|
example if a bucket of milk is used in the craft the bucket is placed in
|
||||||
|
the Output inventory as well). Source items for the craft must be in the
|
||||||
|
Input inventory. If the crafter is adjoined to a storage unit the crafter
|
||||||
|
will also use source items from it as well.
|
||||||
|
|
||||||
|
Only the owner can dig or access the form of the locked version.
|
||||||
|
|
||||||
|
Unowned crafters can only access unowned units. Owned crafters can access
|
||||||
|
units of the same owner or unowned units.
|
||||||
|
|
||||||
|
UI
|
||||||
|
Input inventory - top left, source items for crafting.
|
||||||
|
Player inventory - lower left.
|
||||||
|
Channel - digilines channel of crafter, press enter or click Set to set.
|
||||||
|
Crafting grid - center top, enter a recipe to craft.
|
||||||
|
Automatic - if checked a craft of the recipe is performed every second (if possible).
|
||||||
|
Preview - this is a preview of the item crafted from the recipe.
|
||||||
|
Craft - perform 1 craft from the recipe (if possible).
|
||||||
|
Output inventory - center bottom, where crafted and replacement items are placed.
|
||||||
|
Search - top right.
|
||||||
|
Craftable list - right, list of all items that are possible to craft from
|
||||||
|
the input items. clicking an item crafts it (if possible).
|
||||||
|
|
||||||
|
The form does not update while open. A craft from source items no longer
|
||||||
|
available will not craft.
|
||||||
|
|
||||||
|
Terms can be entered into the search field, and when enter is pressed or
|
||||||
|
the Search button is pressed, only items whose name or description contains
|
||||||
|
these terms are shown in the list. That is if they match any of the space
|
||||||
|
separated terms.
|
||||||
|
|
||||||
|
When items are placed into the crafting grid a copy is used and the item
|
||||||
|
returns to where it was taken from. When items are removed from the crafting
|
||||||
|
grid they are disposed of.
|
||||||
|
|
||||||
|
The preview displays the craft preformed by the recipe. Items cannot be
|
||||||
|
pulled from here.
|
||||||
|
|
||||||
|
The automatic crafting is only operable when the crafter is in an active
|
||||||
|
block. Mesecons and digilines operations operate in unloaded blocks.
|
||||||
|
|
||||||
|
When crafting by item, if more than one recipe is satisfied by the input
|
||||||
|
items, the crafting grid is replaced with the available crafts for that
|
||||||
|
item. Clicking the < and > buttons walks through the recipes. Clicking
|
||||||
|
Craft performs one craft with the displayed recipe. Clicking Close displays
|
||||||
|
the crafting grid. If only one recipe is satisfied by the input items one
|
||||||
|
craft is immediately performed without displaying the recipe.
|
||||||
|
|
||||||
|
Hoppers placed to the top or sides of a crafter will feed items into the
|
||||||
|
input. Hoppers placed below a crafter will take items from the output.
|
||||||
|
|
||||||
|
Pipeworks tubes can push items into the input, and pull items from the
|
||||||
|
output.
|
||||||
|
|
||||||
|
Mesecons
|
||||||
|
Perform 1 craft from the recipe when power is turned on (if possible).
|
||||||
|
|
||||||
|
Digilines messages
|
||||||
|
"craft [qty]"
|
||||||
|
Craft from the recipe if possible. qty is optional, if given must be an
|
||||||
|
integer between 1 to 10. If not given defaults to 1. A return message
|
||||||
|
is sent with it's own channel in the following format:
|
||||||
|
{
|
||||||
|
action = "crafted",
|
||||||
|
qty = number, -- craft qty requested
|
||||||
|
crafted = number -- crafts successfully performed
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
"craftitem itemname [qty]"
|
||||||
|
Craft the given item if possible. itemname must be a valid item name
|
||||||
|
(eg. "default:wood"). qty is optional, if given must be an integer
|
||||||
|
between 1 to 10. If not given defaults to 1. A return message is sent
|
||||||
|
with it's own channel in the following format:
|
||||||
|
{
|
||||||
|
action = "crafted",
|
||||||
|
itemname = string, -- the name of the item requested to craft
|
||||||
|
qty = number, -- craft qty requested
|
||||||
|
crafted = number -- crafts successfully performed
|
||||||
|
}
|
||||||
|
|
||||||
|
"can_craft [itemname]"
|
||||||
|
Test whether a single craft can be performed for the item. itemname is
|
||||||
|
optional, if given will test craft by item. If not given will test if
|
||||||
|
the recipe in the crafting grid can be performed. A return message is
|
||||||
|
sent with it's own channel in the following format:
|
||||||
|
{
|
||||||
|
action = "can_craft",
|
||||||
|
itemname = string, -- the name of the item requested, nil for recipe
|
||||||
|
result = boolean -- true if craft can be performed, false if not
|
||||||
|
}
|
||||||
|
|
||||||
|
"automatic state"
|
||||||
|
Sets the automatic running state of the crafter. state must be true or
|
||||||
|
false.
|
||||||
|
|
||||||
|
"craftable"
|
||||||
|
Sends a digilines message with it's own channel of the possible craftable
|
||||||
|
items in the following form:
|
||||||
|
{
|
||||||
|
action = "craftable",
|
||||||
|
items = {
|
||||||
|
<items>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
The items key is an indexed list of items. Each item entry is
|
||||||
|
a table with the following keys:
|
||||||
|
{
|
||||||
|
name -- string, the name of the item, as <mod>:<name>
|
||||||
|
description -- string, short description of item
|
||||||
|
}
|
||||||
|
|
||||||
|
"inventory"
|
||||||
|
Sends a digilines message with it's own channel of the source items,
|
||||||
|
including any attached storage, in the following form:
|
||||||
|
{
|
||||||
|
action = "inventory",
|
||||||
|
inventory = {
|
||||||
|
<items>
|
||||||
|
}
|
||||||
|
}
|
||||||
|
The inventory key is an indexed list of items. Each item entry is
|
||||||
|
a table with the following keys:
|
||||||
|
{
|
||||||
|
name -- string, the name of the item, as <mod>:<name>
|
||||||
|
description -- string, short description of item
|
||||||
|
count -- number, the total number of this item in storage
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Set recipe grid:
|
||||||
|
{
|
||||||
|
action = "recipe",
|
||||||
|
items = { ... }
|
||||||
|
}
|
||||||
|
items must be a string list of item names as <mod>:<name>. The grid is
|
||||||
|
filled left to right, top to bottom. Up to the first 9 items are used.
|
||||||
|
|
||||||
|
* When crafting by item the output may not be as expected. For the digilines
|
||||||
|
"craftitem" message, the first found recipe for the craft which is
|
||||||
|
satisfied by the available items is used. So if you have saplings and
|
||||||
|
wood in the input and try to craft sticks, if the first recipe found
|
||||||
|
uses the saplings 1 stick will be output, if wood then 4 sticks.
|
||||||
|
Also, sometimes the same recipe is registered for more than 1 item.
|
||||||
|
In this case, what item will actually be crafted is ambiguous.
|
||||||
|
|
||||||
|
* The file 'crafting_mods.lua' in the mod folder contains a list of
|
||||||
|
crafting modifications. Modify this file as necessary. The field name
|
||||||
|
is the item being crafted. Each item in the add list is added to the
|
||||||
|
output inventory. Each item in the remove list is removed from the
|
||||||
|
replacements or source storage.
|
||||||
|
|
||||||
|
* Gaining the list of craftable items is an exponential process, based
|
||||||
|
on the number of unique source items and the total number of items
|
||||||
|
available. As a guide, 320 source items and 795 total items that resulted
|
||||||
|
623 craftable items took approx. 200ms (1st gen i5 processor). This list
|
||||||
|
is only gained: when the form is opened; when the Search button is clicked;
|
||||||
|
and when the digilines "craftable" message is sent.
|
@@ -19,7 +19,7 @@ Channel - digilines channel of indexer.
|
|||||||
Input - middle.
|
Input - middle.
|
||||||
Output - top right.
|
Output - top right.
|
||||||
Filter - center right.
|
Filter - center right.
|
||||||
Player inventor - lower right.
|
Player inventory - lower right.
|
||||||
|
|
||||||
When the UI is accessed the storage is scanned, and its contents are
|
When the UI is accessed the storage is scanned, and its contents are
|
||||||
displayed in the list. The list contains the following columns:
|
displayed in the list. The list contains the following columns:
|
||||||
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -536,7 +536,6 @@ minetest.register_node("lwcomponents:dropper", {
|
|||||||
"lwdropper.png", "lwdropper.png", "lwdropper_face.png"},
|
"lwdropper.png", "lwdropper.png", "lwdropper_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (dropper_groups),
|
groups = table.copy (dropper_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -564,7 +563,6 @@ minetest.register_node("lwcomponents:dropper_locked", {
|
|||||||
"lwdropper.png", "lwdropper.png", "lwdropper_face.png"},
|
"lwdropper.png", "lwdropper.png", "lwdropper_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (dropper_groups),
|
groups = table.copy (dropper_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -601,7 +599,6 @@ utils.hopper_add_container({
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@@ -485,7 +485,7 @@ minetest.register_node ("lwcomponents:boom", {
|
|||||||
tiles = { "lwcomponents_boom.png" },
|
tiles = { "lwcomponents_boom.png" },
|
||||||
inventory_image = "lwcomponents_boom.png",
|
inventory_image = "lwcomponents_boom.png",
|
||||||
wield_image = "lwcomponents_boom.png",
|
wield_image = "lwcomponents_boom.png",
|
||||||
light_source = default.LIGHT_MAX,
|
light_source = 14,
|
||||||
use_texture_alpha = "blend",
|
use_texture_alpha = "blend",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
18
extras.lua
18
extras.lua
@@ -31,15 +31,6 @@ if touchscreen then
|
|||||||
}
|
}
|
||||||
|
|
||||||
minetest.register_node ("lwcomponents:touchscreen", touchblock)
|
minetest.register_node ("lwcomponents:touchscreen", touchblock)
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = "lwcomponents:touchscreen",
|
|
||||||
recipe = {
|
|
||||||
{"mesecons_luacontroller:luacontroller0000","default:glass","default:glass"},
|
|
||||||
{"default:glass","digilines:lcd","default:glass"},
|
|
||||||
{"default:glass","default:glass","default:stone"}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
@@ -72,15 +63,6 @@ if panel then
|
|||||||
}
|
}
|
||||||
|
|
||||||
minetest.register_node ("lwcomponents:panel", panelblock)
|
minetest.register_node ("lwcomponents:panel", panelblock)
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = "lwcomponents:panel",
|
|
||||||
recipe = {
|
|
||||||
{"","digistuff:button",""},
|
|
||||||
{"digistuff:button","digilines:lcd","digistuff:button"},
|
|
||||||
{"","digistuff:button","default:stone"}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
7
fan.lua
7
fan.lua
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -342,7 +342,6 @@ minetest.register_node("lwcomponents:fan", {
|
|||||||
"lwfan.png", "lwfan.png", "lwfan_face.png"},
|
"lwfan.png", "lwfan.png", "lwfan_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -370,7 +369,6 @@ minetest.register_node("lwcomponents:fan_locked", {
|
|||||||
"lwfan.png", "lwfan.png", "lwfan_face.png"},
|
"lwfan.png", "lwfan.png", "lwfan_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -398,7 +396,6 @@ minetest.register_node("lwcomponents:fan_on", {
|
|||||||
"lwfan.png", "lwfan.png", "lwfan_face_on.png"},
|
"lwfan.png", "lwfan.png", "lwfan_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -427,7 +424,6 @@ minetest.register_node("lwcomponents:fan_locked_on", {
|
|||||||
"lwfan.png", "lwfan.png", "lwfan_face_on.png"},
|
"lwfan.png", "lwfan.png", "lwfan_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -450,4 +446,3 @@ minetest.register_node("lwcomponents:fan_locked_on", {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
@@ -842,7 +842,6 @@ minetest.register_node("lwcomponents:force_field", {
|
|||||||
"lwcomponents_force_field.png", "lwcomponents_force_field.png", "lwcomponents_force_field.png"},
|
"lwcomponents_force_field.png", "lwcomponents_force_field.png", "lwcomponents_force_field.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (force_field_groups),
|
groups = table.copy (force_field_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
@@ -872,7 +871,6 @@ minetest.register_node("lwcomponents:force_field_locked", {
|
|||||||
"lwcomponents_force_field.png", "lwcomponents_force_field.png", "lwcomponents_force_field.png"},
|
"lwcomponents_force_field.png", "lwcomponents_force_field.png", "lwcomponents_force_field.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (force_field_groups),
|
groups = table.copy (force_field_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
@@ -902,7 +900,6 @@ minetest.register_node("lwcomponents:force_field_on", {
|
|||||||
"lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png"},
|
"lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (force_field_on_groups),
|
groups = table.copy (force_field_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
@@ -933,7 +930,6 @@ minetest.register_node("lwcomponents:force_field_locked_on", {
|
|||||||
"lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png"},
|
"lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png", "lwcomponents_force_field_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (force_field_on_groups),
|
groups = table.copy (force_field_on_groups),
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
|
@@ -329,7 +329,6 @@ minetest.register_node("lwcomponents:hologram", {
|
|||||||
"lwhologram.png", "lwhologram.png", "lwhologram_face.png"},
|
"lwhologram.png", "lwhologram.png", "lwhologram_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 },
|
groups = { cracky = 3 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -355,7 +354,6 @@ minetest.register_node("lwcomponents:hologram_locked", {
|
|||||||
"lwhologram.png", "lwhologram.png", "lwhologram_face.png"},
|
"lwhologram.png", "lwhologram.png", "lwhologram_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 },
|
groups = { cracky = 3 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
|
@@ -382,7 +382,6 @@ minetest.register_node ("lwcomponents:hopper", {
|
|||||||
param2 = 0,
|
param2 = 0,
|
||||||
drop = "lwcomponents:hopper",
|
drop = "lwcomponents:hopper",
|
||||||
groups = { cracky = 3 },
|
groups = { cracky = 3 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
|
|
||||||
on_construct = on_construct,
|
on_construct = on_construct,
|
||||||
on_destruct = on_destruct,
|
on_destruct = on_destruct,
|
||||||
@@ -431,7 +430,6 @@ minetest.register_node ("lwcomponents:hopper_horz", {
|
|||||||
param2 = 0,
|
param2 = 0,
|
||||||
drop = "lwcomponents:hopper",
|
drop = "lwcomponents:hopper",
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
|
|
||||||
on_construct = on_construct,
|
on_construct = on_construct,
|
||||||
on_destruct = on_destruct,
|
on_destruct = on_destruct,
|
||||||
|
5
init.lua
5
init.lua
@@ -1,4 +1,4 @@
|
|||||||
local version = "0.1.30"
|
local version = "0.1.33"
|
||||||
local mod_storage = minetest.get_mod_storage ()
|
local mod_storage = minetest.get_mod_storage ()
|
||||||
|
|
||||||
|
|
||||||
@@ -40,13 +40,12 @@ loadfile (modpath.."/pistons.lua") (utils)
|
|||||||
loadfile (modpath.."/through_wire.lua") (utils)
|
loadfile (modpath.."/through_wire.lua") (utils)
|
||||||
loadfile (modpath.."/camera.lua") (utils)
|
loadfile (modpath.."/camera.lua") (utils)
|
||||||
loadfile (modpath.."/storage.lua") (utils)
|
loadfile (modpath.."/storage.lua") (utils)
|
||||||
|
loadfile (modpath.."/crafter.lua") (utils)
|
||||||
loadfile (modpath.."/force_field.lua") (utils)
|
loadfile (modpath.."/force_field.lua") (utils)
|
||||||
loadfile (modpath.."/destroyer.lua") (utils)
|
loadfile (modpath.."/destroyer.lua") (utils)
|
||||||
loadfile (modpath.."/extras.lua") (utils)
|
loadfile (modpath.."/extras.lua") (utils)
|
||||||
loadfile (modpath.."/digiswitch.lua") (utils)
|
loadfile (modpath.."/digiswitch.lua") (utils)
|
||||||
loadfile (modpath.."/movefloor.lua") (utils)
|
loadfile (modpath.."/movefloor.lua") (utils)
|
||||||
loadfile (modpath.."/solid_conductor.lua") (utils)
|
|
||||||
loadfile (modpath.."/crafting.lua") (utils)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
2
mod.conf
2
mod.conf
@@ -2,5 +2,3 @@ author = loosewheel
|
|||||||
description = Various components for mesecons and digilines.
|
description = Various components for mesecons and digilines.
|
||||||
title = LWComponents
|
title = LWComponents
|
||||||
name = lwcomponents
|
name = lwcomponents
|
||||||
depends = default
|
|
||||||
optional_depends = mesecons, digilines, unifieddyes, intllib, hopper, digistuff, pipeworks, lwwires
|
|
||||||
|
@@ -429,9 +429,7 @@ minetest.register_node("lwcomponents:movefloor", {
|
|||||||
{-0.5, -0.5, -0.5, 0.5, 0.5, 0.5},
|
{-0.5, -0.5, -0.5, 0.5, 0.5, 0.5},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
groups = { cracky = 2 },
|
groups = { cracky = 2 }, mesecons = mesecon_support (),
|
||||||
sounds = default.node_sound_wood_defaults (),
|
|
||||||
mesecons = mesecon_support (),
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1109,7 +1109,6 @@ minetest.register_node("lwcomponents:piston", {
|
|||||||
"lwcomponents_piston_base.png", "lwcomponents_piston_pusher.png" },
|
"lwcomponents_piston_base.png", "lwcomponents_piston_pusher.png" },
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -1156,7 +1155,6 @@ minetest.register_node("lwcomponents:piston_1", {
|
|||||||
},
|
},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -1203,7 +1201,6 @@ minetest.register_node("lwcomponents:piston_2", {
|
|||||||
},
|
},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -1233,7 +1230,6 @@ minetest.register_node("lwcomponents:piston_sticky", {
|
|||||||
"lwcomponents_piston_base.png", "lwcomponents_piston_pusher_sticky.png" },
|
"lwcomponents_piston_base.png", "lwcomponents_piston_pusher_sticky.png" },
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -1280,7 +1276,6 @@ minetest.register_node("lwcomponents:piston_sticky_1", {
|
|||||||
},
|
},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -1327,7 +1322,6 @@ minetest.register_node("lwcomponents:piston_sticky_2", {
|
|||||||
},
|
},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3 , not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -1350,4 +1344,3 @@ minetest.register_node("lwcomponents:piston_sticky_2", {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
@@ -114,8 +114,6 @@ minetest.register_node ("lwcomponents:player_button", {
|
|||||||
},
|
},
|
||||||
groups = { dig_immediate = 2, digiline_receiver = 1 },
|
groups = { dig_immediate = 2, digiline_receiver = 1 },
|
||||||
_digistuff_channelcopier_fieldname = "channel",
|
_digistuff_channelcopier_fieldname = "channel",
|
||||||
sounds = default and default.node_sound_stone_defaults(),
|
|
||||||
|
|
||||||
digiline =
|
digiline =
|
||||||
{
|
{
|
||||||
receptor = {},
|
receptor = {},
|
||||||
@@ -163,8 +161,6 @@ minetest.register_node ("lwcomponents:player_button_off", {
|
|||||||
},
|
},
|
||||||
groups = { dig_immediate = 2, digiline_receiver = 1, not_in_creative_inventory = 1 },
|
groups = { dig_immediate = 2, digiline_receiver = 1, not_in_creative_inventory = 1 },
|
||||||
_digistuff_channelcopier_fieldname = "channel",
|
_digistuff_channelcopier_fieldname = "channel",
|
||||||
sounds = default and default.node_sound_stone_defaults(),
|
|
||||||
|
|
||||||
digiline =
|
digiline =
|
||||||
{
|
{
|
||||||
receptor = {},
|
receptor = {},
|
||||||
@@ -214,8 +210,6 @@ minetest.register_node ("lwcomponents:player_button_on", {
|
|||||||
},
|
},
|
||||||
groups = { dig_immediate = 2, digiline_receiver = 1, not_in_creative_inventory = 1 },
|
groups = { dig_immediate = 2, digiline_receiver = 1, not_in_creative_inventory = 1 },
|
||||||
_digistuff_channelcopier_fieldname = "channel",
|
_digistuff_channelcopier_fieldname = "channel",
|
||||||
sounds = default and default.node_sound_stone_defaults(),
|
|
||||||
|
|
||||||
digiline =
|
digiline =
|
||||||
{
|
{
|
||||||
receptor = {},
|
receptor = {},
|
||||||
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -483,7 +483,6 @@ minetest.register_node("lwcomponents:puncher", {
|
|||||||
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face.png"},
|
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -510,7 +509,6 @@ minetest.register_node("lwcomponents:puncher_locked", {
|
|||||||
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face.png"},
|
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -537,7 +535,6 @@ minetest.register_node("lwcomponents:puncher_on", {
|
|||||||
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face_on.png"},
|
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -564,7 +561,6 @@ minetest.register_node("lwcomponents:puncher_locked_on", {
|
|||||||
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face_on.png"},
|
"lwpuncher.png", "lwpuncher.png", "lwpuncher_face_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
@@ -585,7 +581,6 @@ minetest.register_node("lwcomponents:puncher_locked_on", {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@@ -13,7 +13,7 @@ CC BY-SA 3.0
|
|||||||
|
|
||||||
Version
|
Version
|
||||||
=======
|
=======
|
||||||
0.1.30
|
0.1.33
|
||||||
|
|
||||||
|
|
||||||
Minetest Version
|
Minetest Version
|
||||||
@@ -71,6 +71,7 @@ Various components for mesecons and digilines.
|
|||||||
* Movefloor, similar to vertical mesecons movestone.
|
* Movefloor, similar to vertical mesecons movestone.
|
||||||
* Camera, takes a representative image.
|
* Camera, takes a representative image.
|
||||||
* Storage, indexed storage units.
|
* Storage, indexed storage units.
|
||||||
|
* Crafter, crafts by recipe or by item, and can pull from storage units.
|
||||||
* Hoppers, that are more compatible with this mod.
|
* Hoppers, that are more compatible with this mod.
|
||||||
* Force Field Generator, repels players and mobs within a radius.
|
* Force Field Generator, repels players and mobs within a radius.
|
||||||
* Mesecons Through Wire, transmits through 1 to 2 solid blocks.
|
* Mesecons Through Wire, transmits through 1 to 2 solid blocks.
|
||||||
|
@@ -3,7 +3,7 @@ local S = utils.S
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.digilines_supported or utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -492,7 +492,6 @@ minetest.register_node("lwcomponents:siren", {
|
|||||||
"lwsiren.png", "lwsiren.png", "lwsiren.png"},
|
"lwsiren.png", "lwsiren.png", "lwsiren.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -519,7 +518,6 @@ minetest.register_node("lwcomponents:siren_locked", {
|
|||||||
"lwsiren.png", "lwsiren.png", "lwsiren.png"},
|
"lwsiren.png", "lwsiren.png", "lwsiren.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, wires_connect = 1 },
|
groups = { cracky = 3, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -546,7 +544,6 @@ minetest.register_node("lwcomponents:siren_on", {
|
|||||||
"lwsiren_on.png", "lwsiren_on.png", "lwsiren_on.png"},
|
"lwsiren_on.png", "lwsiren_on.png", "lwsiren_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -573,7 +570,6 @@ minetest.register_node("lwcomponents:siren_locked_on", {
|
|||||||
"lwsiren_on.png", "lwsiren_on.png", "lwsiren_on.png"},
|
"lwsiren_on.png", "lwsiren_on.png", "lwsiren_on.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
floodable = false,
|
floodable = false,
|
||||||
@@ -600,7 +596,6 @@ minetest.register_node("lwcomponents:siren_alarm", {
|
|||||||
"lwsiren_alarm.png", "lwsiren_alarm.png", "lwsiren_alarm.png"},
|
"lwsiren_alarm.png", "lwsiren_alarm.png", "lwsiren_alarm.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
light_source = 3,
|
light_source = 3,
|
||||||
@@ -628,7 +623,6 @@ minetest.register_node("lwcomponents:siren_locked_alarm", {
|
|||||||
"lwsiren_alarm.png", "lwsiren_alarm.png", "lwsiren_alarm.png"},
|
"lwsiren_alarm.png", "lwsiren_alarm.png", "lwsiren_alarm.png"},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
groups = { cracky = 3, not_in_creative_inventory = 1, wires_connect = 1 },
|
||||||
sounds = default.node_sound_stone_defaults (),
|
|
||||||
paramtype = "none",
|
paramtype = "none",
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
light_source = 3,
|
light_source = 3,
|
||||||
@@ -650,7 +644,6 @@ minetest.register_node("lwcomponents:siren_locked_alarm", {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.digilines_supported or utils.mesecon_supported
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@@ -1,146 +0,0 @@
|
|||||||
local utils = ...
|
|
||||||
local S = utils.S
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if utils.unifieddyes_supported and utils.mesecon_supported then
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
mesecon.register_node (":lwcomponents:solid_conductor",
|
|
||||||
{
|
|
||||||
description = S("Solid Color Conductor"),
|
|
||||||
tiles = { "lwsolid_conductor.png" },
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = ( default and default.node_sound_wood_defaults() ),
|
|
||||||
paramtype2 = "color",
|
|
||||||
palette = "unifieddyes_palette_extended.png",
|
|
||||||
on_rotate = false,
|
|
||||||
drop = "lwcomponents:solid_conductor_off",
|
|
||||||
digiline = { wire = { rules = utils.digilines_default_rules } },
|
|
||||||
on_construct = unifieddyes.on_construct,
|
|
||||||
on_dig = unifieddyes.on_dig,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
tiles = { "lwsolid_conductor.png" },
|
|
||||||
mesecons =
|
|
||||||
{
|
|
||||||
conductor =
|
|
||||||
{
|
|
||||||
rules = utils.mesecon_default_rules,
|
|
||||||
state = utils.mesecon_state_off,
|
|
||||||
onstate = "lwcomponents:solid_conductor_on",
|
|
||||||
}
|
|
||||||
},
|
|
||||||
groups = {
|
|
||||||
dig_immediate = 2,
|
|
||||||
ud_param2_colorable = 1,
|
|
||||||
wires_connect = 1
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
tiles = { "lwsolid_conductor.png" },
|
|
||||||
mesecons =
|
|
||||||
{
|
|
||||||
conductor =
|
|
||||||
{
|
|
||||||
rules = utils.mesecon_default_rules,
|
|
||||||
state = utils.mesecon_state_on,
|
|
||||||
offstate = "lwcomponents:solid_conductor_off",
|
|
||||||
}
|
|
||||||
},
|
|
||||||
groups = {
|
|
||||||
dig_immediate = 2,
|
|
||||||
ud_param2_colorable = 1,
|
|
||||||
not_in_creative_inventory = 1,
|
|
||||||
wires_connect = 1
|
|
||||||
},
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
unifieddyes.register_color_craft ({
|
|
||||||
output = "lwcomponents:solid_conductor_off 3",
|
|
||||||
palette = "extended",
|
|
||||||
type = "shapeless",
|
|
||||||
neutral_node = "lwcomponents:solid_conductor_off",
|
|
||||||
recipe = {
|
|
||||||
"NEUTRAL_NODE",
|
|
||||||
"NEUTRAL_NODE",
|
|
||||||
"NEUTRAL_NODE",
|
|
||||||
"MAIN_DYE"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
mesecon.register_node (":lwcomponents:solid_horizontal_conductor",
|
|
||||||
{
|
|
||||||
description = S("Solid Color Horizontal Conductor"),
|
|
||||||
tiles = { "lwsolid_conductor.png" },
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = ( default and default.node_sound_wood_defaults() ),
|
|
||||||
paramtype2 = "color",
|
|
||||||
palette = "unifieddyes_palette_extended.png",
|
|
||||||
on_rotate = false,
|
|
||||||
drop = "lwcomponents:solid_horizontal_conductor_off",
|
|
||||||
digiline = { wire = { rules = utils.digilines_flat_rules } },
|
|
||||||
on_construct = unifieddyes.on_construct,
|
|
||||||
on_dig = unifieddyes.on_dig,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
tiles = { "lwsolid_conductor.png" },
|
|
||||||
mesecons =
|
|
||||||
{
|
|
||||||
conductor =
|
|
||||||
{
|
|
||||||
rules = utils.mesecon_flat_rules,
|
|
||||||
state = utils.mesecon_state_off,
|
|
||||||
onstate = "lwcomponents:solid_horizontal_conductor_on",
|
|
||||||
}
|
|
||||||
},
|
|
||||||
groups = {
|
|
||||||
dig_immediate = 2,
|
|
||||||
ud_param2_colorable = 1,
|
|
||||||
wires_connect = 1
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
tiles = { "lwsolid_conductor.png" },
|
|
||||||
mesecons =
|
|
||||||
{
|
|
||||||
conductor =
|
|
||||||
{
|
|
||||||
rules = utils.mesecon_flat_rules,
|
|
||||||
state = utils.mesecon_state_on,
|
|
||||||
offstate = "lwcomponents:solid_horizontal_conductor_off",
|
|
||||||
}
|
|
||||||
},
|
|
||||||
groups = {
|
|
||||||
dig_immediate = 2,
|
|
||||||
ud_param2_colorable = 1,
|
|
||||||
not_in_creative_inventory = 1,
|
|
||||||
wires_connect = 1
|
|
||||||
},
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
unifieddyes.register_color_craft ({
|
|
||||||
output = "lwcomponents:solid_horizontal_conductor_off 3",
|
|
||||||
palette = "extended",
|
|
||||||
type = "shapeless",
|
|
||||||
neutral_node = "lwcomponents:solid_horizontal_conductor_off",
|
|
||||||
recipe = {
|
|
||||||
"NEUTRAL_NODE",
|
|
||||||
"NEUTRAL_NODE",
|
|
||||||
"NEUTRAL_NODE",
|
|
||||||
"MAIN_DYE"
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
end -- utils.unifieddyes_supported and utils.mesecon_supported then
|
|
16
storage.lua
16
storage.lua
@@ -156,9 +156,7 @@ minetest.register_node("lwcomponents:storage_unit", {
|
|||||||
drawtype = "glasslike_framed",
|
drawtype = "glasslike_framed",
|
||||||
tiles = { "lwcomponents_storage_framed.png", "lwcomponents_storage.png" },
|
tiles = { "lwcomponents_storage_framed.png", "lwcomponents_storage.png" },
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { choppy = 2 },
|
groups = { choppy = 2 }, paramtype = "none",
|
||||||
sounds = default.node_sound_wood_defaults (),
|
|
||||||
paramtype = "none",
|
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
param2 = 0,
|
param2 = 0,
|
||||||
@@ -177,9 +175,7 @@ minetest.register_node("lwcomponents:storage_unit_locked", {
|
|||||||
drawtype = "glasslike_framed",
|
drawtype = "glasslike_framed",
|
||||||
tiles = { "lwcomponents_storage_framed.png", "lwcomponents_storage.png" },
|
tiles = { "lwcomponents_storage_framed.png", "lwcomponents_storage.png" },
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = { choppy = 2 },
|
groups = { choppy = 2 }, paramtype = "none",
|
||||||
sounds = default.node_sound_wood_defaults (),
|
|
||||||
paramtype = "none",
|
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
param2 = 0,
|
param2 = 0,
|
||||||
@@ -1352,9 +1348,7 @@ minetest.register_node("lwcomponents:storage_indexer", {
|
|||||||
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",
|
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",
|
||||||
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",},
|
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (indexer_groups),
|
groups = table.copy (indexer_groups), paramtype = "none",
|
||||||
sounds = default.node_sound_wood_defaults (),
|
|
||||||
paramtype = "none",
|
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
param2 = 0,
|
param2 = 0,
|
||||||
@@ -1386,9 +1380,7 @@ minetest.register_node("lwcomponents:storage_indexer_locked", {
|
|||||||
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",
|
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",
|
||||||
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",},
|
"lwcomponents_storage_indexer.png", "lwcomponents_storage_indexer.png",},
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = table.copy (indexer_groups),
|
groups = table.copy (indexer_groups), paramtype = "none",
|
||||||
sounds = default.node_sound_wood_defaults (),
|
|
||||||
paramtype = "none",
|
|
||||||
param1 = 0,
|
param1 = 0,
|
||||||
paramtype2 = "none",
|
paramtype2 = "none",
|
||||||
param2 = 0,
|
param2 = 0,
|
||||||
|
BIN
textures/lwcomponents_storage_crafter.png
Normal file
BIN
textures/lwcomponents_storage_crafter.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.5 KiB |
@@ -47,9 +47,7 @@ mesecon.register_node ("lwcomponents:through_wire", {
|
|||||||
{ -2/32, -1/2 , -16/32+0.001 , 2/32, -14/32, 7/16+0.002 } -- the horizontal wire
|
{ -2/32, -1/2 , -16/32+0.001 , 2/32, -14/32, 7/16+0.002 } -- the horizontal wire
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
drop = "lwcomponents:through_wire_off",
|
drop = "lwcomponents:through_wire_off",}, {
|
||||||
sounds = default.node_sound_defaults(),
|
|
||||||
}, {
|
|
||||||
tiles = { "mesecons_wire_off.png" },
|
tiles = { "mesecons_wire_off.png" },
|
||||||
groups = { dig_immediate = 3 },
|
groups = { dig_immediate = 3 },
|
||||||
mesecons = {
|
mesecons = {
|
||||||
|
Reference in New Issue
Block a user