Compare commits
	
		
			32 Commits
		
	
	
		
			contributo
			...
			pkarcs-com
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 48a933fca8 | ||
|  | 4fc833bb00 | ||
|  | 5788062fac | ||
|  | 1c8024401f | ||
|  | 1273b627c2 | ||
|  | 3d7e7a82a5 | ||
|  | e40f9747b0 | ||
|  | 85aa74e98b | ||
|  | 5b9431ea18 | ||
|  | 53d9659051 | ||
|  | 79ba8cabc3 | ||
| 1d42e59ada | |||
|  | aecd323b93 | ||
|  | 317fdd6df6 | ||
|  | 2e035f37e9 | ||
|  | 178fd9c48b | ||
|  | d2dd770635 | ||
|  | eed0d601be | ||
|  | 16ff4dcdb8 | ||
|  | b54333d56b | ||
|  | 6492d311c8 | ||
|  | 03d097abf8 | ||
|  | 9ad9ba33c8 | ||
|  | 40bcb29c6d | ||
|  | 37aef1ce17 | ||
|  | 8a8e566d27 | ||
|  | a3b8ec1522 | ||
|  | ce0501bef3 | ||
|  | 6d6432940f | ||
|  | 242dbde0e6 | ||
|  | 973f14fbd2 | ||
|  | 0c19943f05 | 
							
								
								
									
										15
									
								
								.github/workflows/integration-test.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,15 @@ | |||||||
|  | name: integration-test | ||||||
|  |  | ||||||
|  | on: [push, pull_request] | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |  | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     timeout-minutes: 10 | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v1 | ||||||
|  |  | ||||||
|  |     - name: integration-test | ||||||
|  |       run: ./test/integration-test.sh | ||||||
| @@ -19,6 +19,8 @@ read_globals = { | |||||||
| 	"xpanes", | 	"xpanes", | ||||||
| 	"screwdriver", | 	"screwdriver", | ||||||
| 	"minetest", | 	"minetest", | ||||||
| 	"mesecon" | 	"mesecon", | ||||||
|  | 	"unifieddyes", | ||||||
|  | 	"pkarcs" | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -3,11 +3,14 @@ | |||||||
| # scifi_nodes | # scifi_nodes | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | [](https://content.minetest.net/packages/D00Med/scifi_nodes/) | ||||||
|  |  | ||||||
| Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets. | Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets. | ||||||
|  |  | ||||||
| # Changes log | # Changelog | ||||||
|  |  | ||||||
|  | * Added support for unifieddyes | ||||||
| * 14/08/2019 : retrocompatibility fixed (aliases in doors.lua) | * 14/08/2019 : retrocompatibility fixed (aliases in doors.lua) | ||||||
| * 13/08/2019 : | * 13/08/2019 : | ||||||
|   * added mod option doors_open_with_mesecon_only (default = false) |   * added mod option doors_open_with_mesecon_only (default = false) | ||||||
| @@ -42,9 +45,14 @@ CC0 | |||||||
|  |  | ||||||
| # Contributors: | # Contributors: | ||||||
|  |  | ||||||
|  | * D00Med https://github.com/D00Med (creator) | ||||||
| * tanmayameher https://github.com/tanmayameher | * tanmayameher https://github.com/tanmayameher | ||||||
| * naturefreshmilk https://github.com/naturefreshmilk | * BuckarooBanzay https://github.com/BuckarooBanzay | ||||||
| * acmgit https://github.com/acmgit | * acmgit https://github.com/acmgit | ||||||
| * catz85 https://github.com/catz85 | * catz85 https://github.com/catz85 | ||||||
| * coil0 https://github.com/coil0 | * coil0 https://github.com/coil0 | ||||||
| * Grossam https://github.com/Grossam | * Grossam https://github.com/Grossam | ||||||
|  | * OgelGames https://github.com/OgelGames | ||||||
|  | * leftshift https://github.com/leftshift | ||||||
|  | * fluxionary https://github.com/fluxionary | ||||||
|  | * Niles Corder https://github.com/ncorder | ||||||
|   | |||||||
| @@ -43,7 +43,7 @@ minetest.register_node("scifi_nodes:crate", { | |||||||
| 	groups = {cracky = 1, oddly_breakable_by_hand = 2, fuel = 8}, | 	groups = {cracky = 1, oddly_breakable_by_hand = 2, fuel = 8}, | ||||||
| 	legacy_facedir_simple = true, | 	legacy_facedir_simple = true, | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = scifi_nodes.node_sound_wood_defaults(), | ||||||
|  |  | ||||||
| 	after_dig_node = drop_chest_stuff(), | 	after_dig_node = drop_chest_stuff(), | ||||||
| 	on_construct = function(pos) | 	on_construct = function(pos) | ||||||
| @@ -82,7 +82,7 @@ minetest.register_node("scifi_nodes:box", { | |||||||
| 	groups = {cracky = 1}, | 	groups = {cracky = 1}, | ||||||
| 	legacy_facedir_simple = true, | 	legacy_facedir_simple = true, | ||||||
| 	is_ground_content = false, | 	is_ground_content = false, | ||||||
| 	sounds = default.node_sound_metal_defaults(), | 	sounds = scifi_nodes.node_sound_metal_defaults(), | ||||||
|  |  | ||||||
| 	after_dig_node = drop_chest_stuff(), | 	after_dig_node = drop_chest_stuff(), | ||||||
| 	on_construct = function(pos) | 	on_construct = function(pos) | ||||||
|   | |||||||
							
								
								
									
										66
									
								
								crafts.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,14 +1,38 @@ | |||||||
| -- CRAFTING RECIPES FOR SCIFI NODES | -- CRAFTING RECIPES FOR SCIFI NODES | ||||||
|  |  | ||||||
| -- 6 basic plastic from 9 homedecor plastic sheet | if minetest.get_modpath("basic_materials") then | ||||||
| minetest.register_craft({ |     -- 6 basic plastic from 9 homedecor plastic sheet | ||||||
|  |     minetest.register_craft({ | ||||||
|         output = "scifi_nodes:white2 6", |         output = "scifi_nodes:white2 6", | ||||||
|         recipe = { |         recipe = { | ||||||
|             {"homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting"}, |             {"homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting"}, | ||||||
|             {"homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting"}, |             {"homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting"}, | ||||||
|             {"homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting"} |             {"homedecor:plastic_sheeting", "homedecor:plastic_sheeting", "homedecor:plastic_sheeting"} | ||||||
|         } |         } | ||||||
| }) |     }) | ||||||
|  |  | ||||||
|  |     if minetest.settings:get_bool("scifi_nodes.teleporter_enable_crafting", false) then | ||||||
|  |         -- enable the teleporter pad crafting recipe only if the setting is enabled | ||||||
|  |         minetest.register_craft({ | ||||||
|  |             output = "scifi_nodes:pad", | ||||||
|  |             recipe = { | ||||||
|  |                 {"homedecor:plastic_sheeting", "quartz:block", "homedecor:plastic_sheeting"}, | ||||||
|  |                 {"default:mese_crystal", "quartz:block", "default:mese_crystal"}, | ||||||
|  |                 {"homedecor:plastic_sheeting", "quartz:block", "homedecor:plastic_sheeting"} | ||||||
|  |             } | ||||||
|  |         }) | ||||||
|  |     end | ||||||
|  |  | ||||||
|  | end | ||||||
|  |  | ||||||
|  |  | ||||||
|  | if not minetest.get_modpath("default") or not minetest.get_modpath("dye") then | ||||||
|  |     -- the default and dye mod are required for most of the recipes | ||||||
|  |     -- if either of them is missing (because we are not in the default game) | ||||||
|  |     -- then just skip the recipes entirely | ||||||
|  |     -- TODO: potentially switch recipes depending on current game | ||||||
|  |     return | ||||||
|  | end | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "scifi_nodes:super_white", | 	output = "scifi_nodes:super_white", | ||||||
| @@ -767,6 +791,16 @@ minetest.register_craft({ | |||||||
|     } |     } | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | -- 4 green light bar from 4 green metal, 2 green dye, 1 lightbar | ||||||
|  | minetest.register_craft({ | ||||||
|  |     output = "scifi_nodes:greenbar_animated 4", | ||||||
|  |     recipe = { | ||||||
|  |         {"scifi_nodes:greenbar", "", "scifi_nodes:greenbar"}, | ||||||
|  |         {"", "mesecons:wire_00000000_off", ""}, | ||||||
|  |         {"scifi_nodes:greenbar", "", "scifi_nodes:greenbar"} | ||||||
|  |     } | ||||||
|  | }) | ||||||
|  |  | ||||||
| -- 4 green metal block from 4 green metal | -- 4 green metal block from 4 green metal | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|     output = "scifi_nodes:green_square 4", |     output = "scifi_nodes:green_square 4", | ||||||
| @@ -1089,6 +1123,22 @@ minetest.register_craft({ | |||||||
|     } |     } | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | -- wet metal plant pot from dry metal plant pot | ||||||
|  | minetest.register_craft({ | ||||||
|  |     output = "scifi_nodes:pot2", | ||||||
|  |     recipe = { | ||||||
|  |         {"scifi_nodes:pot", "bucket:bucket_water"} | ||||||
|  |     }, | ||||||
|  |     replacements = {{"bucket:bucket_water", "bucket:bucket_empty"}} | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | -- dry metal plant pot from wet metal plant pot | ||||||
|  | minetest.register_craft({ | ||||||
|  | 	type = "cooking", | ||||||
|  | 	output = "scifi_nodes:pot", | ||||||
|  | 	recipe = "scifi_nodes:pot2", | ||||||
|  | }) | ||||||
|  |  | ||||||
| -- 6 itemholder from 2 dented metal block and 1 plastic | -- 6 itemholder from 2 dented metal block and 1 plastic | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|     output = "scifi_nodes:itemholder 6", |     output = "scifi_nodes:itemholder 6", | ||||||
| @@ -1282,10 +1332,13 @@ minetest.register_craft({ | |||||||
| }) | }) | ||||||
|  |  | ||||||
| -- https://forum.minetest.net/viewtopic.php?f=10&t=13125&p=261481#p261481 | -- https://forum.minetest.net/viewtopic.php?f=10&t=13125&p=261481#p261481 | ||||||
|  | -- with modified recipe | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|     output = 'scifi_nodes:windowpanel 4', |     output = 'scifi_nodes:windowpanel', | ||||||
|     recipe = { |     recipe = { | ||||||
|         {"scifi_nodes:glass","",""} |         {"scifi_nodes:glass_pane","scifi_nodes:glass_pane",""}, | ||||||
|  |         {"scifi_nodes:glass_pane","scifi_nodes:glass_pane",""}, | ||||||
|  |         {"","",""} | ||||||
|     } |     } | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -1680,7 +1733,7 @@ minetest.register_craft({ | |||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|     output = 'scifi_nodes:stripes2top 3', |     output = 'scifi_nodes:stripes2top 3', | ||||||
|     recipe = { |     recipe = { | ||||||
|         {"scifi_nodes:black","scifi_noedes:black","scifi_nodes:black"}, |         {"scifi_nodes:black","scifi_nodes:black","scifi_nodes:black"}, | ||||||
|         {"default:silver_sand","default:silver_sand","default:silver_sand"} |         {"default:silver_sand","default:silver_sand","default:silver_sand"} | ||||||
|     } |     } | ||||||
| }) | }) | ||||||
| @@ -1692,4 +1745,3 @@ minetest.register_craft({ | |||||||
|         {"scifi_nodes:stripes"} |         {"scifi_nodes:stripes"} | ||||||
|     } |     } | ||||||
| }) | }) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -122,14 +122,14 @@ minetest.register_node("scifi_nodes:digicode_on", { | |||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	light_source = 5, | 	light_source = 5, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1}, | ||||||
| 	drop = {items = {"scifi_nodes:digicode_off"}}, | 	drop = "scifi_nodes:digicode_off", | ||||||
| 	mesecons = { | 	mesecons = { | ||||||
| 		receptor = { | 		receptor = { | ||||||
| 			state = (has_mesecons and mesecon.state.on) | 			state = (has_mesecons and mesecon.state.on) | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	on_timer = toggle_digicode, | 	on_timer = toggle_digicode, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:digicode_off", { | minetest.register_node("scifi_nodes:digicode_off", { | ||||||
| @@ -152,7 +152,7 @@ minetest.register_node("scifi_nodes:digicode_off", { | |||||||
| 	}, | 	}, | ||||||
| 	after_place_node = set_owner, | 	after_place_node = set_owner, | ||||||
| 	on_rightclick = show_digicode_formspec, | 	on_rightclick = show_digicode_formspec, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						| @@ -4,19 +4,35 @@ scifi_nodes = {} | |||||||
|  |  | ||||||
| local MP = minetest.get_modpath("scifi_nodes") | local MP = minetest.get_modpath("scifi_nodes") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | dofile(MP.."/sounds.lua") | ||||||
|  |  | ||||||
| if minetest.get_modpath("xpanes") then | if minetest.get_modpath("xpanes") then | ||||||
| 	dofile(MP.."/panes.lua") | 	dofile(MP.."/panes.lua") | ||||||
| end | end | ||||||
|  |  | ||||||
| dofile(MP.."/common.lua") | dofile(MP.."/common.lua") | ||||||
| dofile(MP.."/builder.lua") |  | ||||||
| dofile(MP.."/chest.lua") | if minetest.get_modpath("default") then | ||||||
|  | 	-- only load builder and chest if the default mod is available | ||||||
|  | 	-- the formspecs depend on it | ||||||
|  | 	dofile(MP.."/builder.lua") | ||||||
|  | 	dofile(MP.."/chest.lua") | ||||||
|  | end | ||||||
|  |  | ||||||
| dofile(MP.."/plants.lua") | dofile(MP.."/plants.lua") | ||||||
| dofile(MP.."/nodes.lua") | dofile(MP.."/nodes.lua") | ||||||
| dofile(MP.."/doors.lua") | dofile(MP.."/doors.lua") | ||||||
| dofile(MP.."/switches.lua") | dofile(MP.."/switch.lua") | ||||||
|  | dofile(MP.."/protected_switch.lua") | ||||||
| dofile(MP.."/nodeboxes.lua") | dofile(MP.."/nodeboxes.lua") | ||||||
| dofile(MP.."/palm_scanner.lua") | dofile(MP.."/palm_scanner.lua") | ||||||
| dofile(MP.."/digicode.lua") | dofile(MP.."/digicode.lua") | ||||||
| dofile(MP.."/models.lua") | dofile(MP.."/models.lua") | ||||||
|  | dofile(MP.."/octagon_panes.lua") | ||||||
| dofile(MP.."/crafts.lua") | dofile(MP.."/crafts.lua") | ||||||
|  |  | ||||||
|  | if minetest.get_modpath("pkarcs") then | ||||||
|  | 	-- register some nodes in the pkarcs mod | ||||||
|  | 	dofile(MP.."/pkarcs.lua") | ||||||
|  | end | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								mod.conf
									
									
									
									
									
								
							
							
						
						| @@ -1,4 +1,16 @@ | |||||||
| name = scifi_nodes | name = scifi_nodes | ||||||
| description = Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets. | description = Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets. | ||||||
| depends = default,dye | optional_depends = """ | ||||||
| optional_depends = xpanes,mesecons,moreblocks,mesecons_microcontroller,mesecons_button,mesecons_torch,mesecons_receiver,basic_materials | default, | ||||||
|  | xpanes, | ||||||
|  | mesecons, | ||||||
|  | moreblocks, | ||||||
|  | mesecons_microcontroller, | ||||||
|  | mesecons_button, | ||||||
|  | mesecons_torch, | ||||||
|  | mesecons_receiver, | ||||||
|  | basic_materials, | ||||||
|  | dye, | ||||||
|  | unifieddyes, | ||||||
|  | pkarcs | ||||||
|  | """ | ||||||
|   | |||||||
							
								
								
									
										181
									
								
								models.lua
									
									
									
									
									
								
							
							
						
						| @@ -29,6 +29,7 @@ minetest.register_node("scifi_nodes:slope_"..name, { | |||||||
| 		}, | 		}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
|  | 	use_texture_alpha = "clip", | ||||||
| 	light_source = light, | 	light_source = light, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	on_place = minetest.rotate_node | 	on_place = minetest.rotate_node | ||||||
| @@ -38,7 +39,7 @@ end | |||||||
| -- register some blocks in stairsplus if available (part of moreblocks) | -- register some blocks in stairsplus if available (part of moreblocks) | ||||||
| scifi_nodes.register_slope("white2", "Plastic", {"scifi_nodes_white2.png",}, 0) | scifi_nodes.register_slope("white2", "Plastic", {"scifi_nodes_white2.png",}, 0) | ||||||
| scifi_nodes.register_slope("super_white", "Super Plastic", {"scifi_nodes_super_white.png",}, 11) | scifi_nodes.register_slope("super_white", "Super Plastic", {"scifi_nodes_super_white.png",}, 11) | ||||||
| scifi_nodes.register_slope("ultra_white", "Super Plastic", {"scifi_nodes_ultra_white.png",}, default.LIGHT_MAX) | scifi_nodes.register_slope("ultra_white", "Super Plastic", {"scifi_nodes_ultra_white.png",}, minetest.LIGHT_MAX) | ||||||
| scifi_nodes.register_slope("black", "Black", {"scifi_nodes_black.png",}, 0) | scifi_nodes.register_slope("black", "Black", {"scifi_nodes_black.png",}, 0) | ||||||
| scifi_nodes.register_slope("white", "White", {"scifi_nodes_white.png",}, 0) | scifi_nodes.register_slope("white", "White", {"scifi_nodes_white.png",}, 0) | ||||||
| scifi_nodes.register_slope("grey", "Grey", {"scifi_nodes_grey.png",}, 0) | scifi_nodes.register_slope("grey", "Grey", {"scifi_nodes_grey.png",}, 0) | ||||||
| @@ -53,8 +54,8 @@ scifi_nodes.register_slope("holes", "Holes", {"scifi_nodes_holes.png",}, 0) | |||||||
| scifi_nodes.register_slope("pipe", "Pipe", {"scifi_nodes_pipe.png",}, 0) | scifi_nodes.register_slope("pipe", "Pipe", {"scifi_nodes_pipe.png",}, 0) | ||||||
| scifi_nodes.register_slope("stripes", "Stripes", {"scifi_nodes_stripes.png",}, 0) | scifi_nodes.register_slope("stripes", "Stripes", {"scifi_nodes_stripes.png",}, 0) | ||||||
| scifi_nodes.register_slope("screen", "Screen", {"scifi_nodes_screen3.png",}, 5) | scifi_nodes.register_slope("screen", "Screen", {"scifi_nodes_screen3.png",}, 5) | ||||||
| scifi_nodes.register_slope("lightstripe", "Lightstripe", {"scifi_nodes_lightstripe.png",}, default.LIGHT_MAX) | scifi_nodes.register_slope("lightstripe", "Lightstripe", {"scifi_nodes_lightstripe.png",}, minetest.LIGHT_MAX) | ||||||
| scifi_nodes.register_slope("blight2", "Blue Light 2", {"scifi_nodes_capsule3.png",}, default.LIGHT_MAX) | scifi_nodes.register_slope("blight2", "Blue Light 2", {"scifi_nodes_capsule3.png",}, minetest.LIGHT_MAX) | ||||||
| scifi_nodes.register_slope("wallpipe", "Alien Pipe", {"scifi_nodes_wallpipe.png",}, 0) | scifi_nodes.register_slope("wallpipe", "Alien Pipe", {"scifi_nodes_wallpipe.png",}, 0) | ||||||
| scifi_nodes.register_slope("alien", "Alien Wall", {"scifi_nodes_alnslp.png",}, 0) | scifi_nodes.register_slope("alien", "Alien Wall", {"scifi_nodes_alnslp.png",}, 0) | ||||||
| scifi_nodes.register_slope("purple", "Purple", {"scifi_nodes_purple.png",}, 0) | scifi_nodes.register_slope("purple", "Purple", {"scifi_nodes_purple.png",}, 0) | ||||||
| @@ -69,106 +70,104 @@ scifi_nodes.register_slope("blklt2", "Black stripe light", {"scifi_nodes_black_l | |||||||
| local node = {} | local node = {} | ||||||
|  |  | ||||||
| node.types = { | node.types = { | ||||||
| 	{"blue",      "blue lines",        "blue"}, | 	{"blue",      "blue lines"}, | ||||||
| 	{"holes",       "metal with holes","holes"}, | 	{"holes",       "metal with holes"}, | ||||||
| 	{"white2",      "plastic",         "white2"}, | 	{"white2",      "plastic",}, | ||||||
|     {"super_white",      "Super Plastic",         "super_white", 11}, | 	{"super_white",      "Super Plastic", 11}, | ||||||
|     {"ultra_white",      "Ultra Plastic",         "ultra_white", default.LIGHT_MAX}, | 	{"ultra_white",      "Ultra Plastic", minetest.LIGHT_MAX}, | ||||||
| --	{"engine",      "engine",          "engine"}, | --	{"engine",      "engine",          "engine"}, | ||||||
| 	{"wall",      "metal wall",        "wall"}, | 	{"wall",      "metal wall"}, | ||||||
| 	{"white",      "plastic wall",     "white"}, | 	{"white",      "plastic wall"}, | ||||||
| 	{"stripes2top",     "dirty metal block","metal2"}, | 	{"stripes2top",     "dirty metal block"}, | ||||||
| 	{"rough",      "rough metal",      "rough"}, | 	{"rough",      "rough metal"}, | ||||||
| 	{"lighttop",      "metal block",      "metal"}, | 	{"lighttop",      "metal block"}, | ||||||
| 	{"red",      "red lines",          "red"}, | 	{"red",      "red lines"}, | ||||||
| 	{"green",      "green lines",      "green"}, | 	{"green",      "green lines"}, | ||||||
| 	{"vent2",      "vent",              "vent"}, | 	{"vent2",      "vent"}, | ||||||
| 	{"stripes",      "hazard stripes", "stripes"}, | 	{"stripes",      "hazard stripes"}, | ||||||
| 	{"rust",      "rusty metal",       "rust"}, | 	{"rust",      "rusty metal"}, | ||||||
| 	{"mesh",      "metal mesh",       "mesh"}, | 	{"mesh",      "metal mesh"}, | ||||||
| 	{"black",      "black wall",       "black"}, | 	{"black",      "black wall"}, | ||||||
| 	{"blackoct",      "black octagon",       "blackoct"}, | 	{"blackoct",      "black octagon"}, | ||||||
| 	{"blackpipe",      "black pipe",       "blackpipe"}, | 	{"blackpipe",      "black pipe"}, | ||||||
| 	{"blacktile",      "black tile",       "blktl"}, | 	{"blacktile",      "black tile"}, | ||||||
| 	{"blacktile2",      "black tile 2",       "blktl2"}, | 	{"blacktile2",      "black tile 2"}, | ||||||
| 	{"blackvent",      "black vent",       "blkvnt"}, | 	{"blackvent",      "black vent"}, | ||||||
| 	{"bluebars",      "blue bars",       "bluebars"}, | 	{"bluebars",      "blue bars"}, | ||||||
| 	{"bluemetal",      "blue metal",       "blumtl"}, | 	{"bluemetal",      "blue metal"}, | ||||||
| 	{"bluetile",      "blue tile",       "blutl"}, | 	{"bluetile",      "blue tile"}, | ||||||
| 	{"greytile",      "grey tile",       "grytl"}, | 	{"greytile",      "grey tile"}, | ||||||
| 	{"mesh2",      "metal floormesh",       "mesh2"}, | 	{"mesh2",      "metal floormesh"}, | ||||||
| 	{"white",      "plastic wall",       "white"}, | 	{"pipe",      "wall pipe"}, | ||||||
| 	{"pipe",      "wall pipe",       "pipe2"}, | 	{"pipeside",      "side pipe"}, | ||||||
| 	{"pipeside",      "side pipe",       "pipe3"}, | 	{"tile",      "white tile"}, | ||||||
| 	{"tile",      "white tile",       "tile"}, | 	{"whiteoct",      "white octagon"}, | ||||||
| 	{"whiteoct",      "white octagon",       "whiteoct"}, | 	{"whitetile",      "white tile2"}, | ||||||
| 	{"whitetile",      "white tile2",       "whttl"}, | 	{"black_detail",      "black detail"}, | ||||||
| 	{"black_detail",      "black detail",       "blckdtl"}, | 	{"green_square",      "green metal block"}, | ||||||
| 	{"green_square",      "green metal block",       "grnblck"}, | 	{"red_square",      "red metal block"}, | ||||||
| 	{"red_square",      "red metal block",       "redblck"}, | 	{"grey_square",      "grey metal block"}, | ||||||
| 	{"grey_square",      "grey metal block",       "greyblck"}, | 	{"blue_square",      "blue metal block"}, | ||||||
| 	{"blue_square",      "blue metal block",       "blublck"}, | 	{"black_mesh",      "black vent block"}, | ||||||
| 	{"black_mesh",      "black vent block",       "blckmsh"}, | 	{"dent",      "dented metal block"}, | ||||||
| 	{"dent",      "dented metal block",       "dent"}, | 	{"greenmetal",      "green metal wall"}, | ||||||
| 	{"greenmetal",      "green metal wall",       "grnmetl"}, | 	{"greenmetal2",      "green metal wall2"}, | ||||||
| 	{"greenmetal2",      "green metal wall2",       "grnmetl2"}, | 	{"greenlights",      "green wall lights",       10}, | ||||||
| 	{"greenlights",      "green wall lights",       "grnlt", 10}, | 	{"greenlights2",      "green wall lights2",     10}, | ||||||
| 	{"greenlights2",      "green wall lights2",       "grnlt2", 10}, | 	{"greenbar",      "green light bar",            10}, | ||||||
| 	{"greenbar",      "green light bar",       "grnlghtbr", 10}, | 	{"green2",      "green wall panel"}, | ||||||
| 	{"green2",      "green wall panel",       "grn2"}, | 	{"greentubes",      "green pipes"}, | ||||||
| 	{"greentubes",      "green pipes",       "grntubes"}, | 	{"grey",      "grey wall"}, | ||||||
| 	{"grey",      "grey wall",       "gry"}, | 	{"greybolts",      "grey wall bolts"}, | ||||||
| 	{"greybolts",      "grey wall bolts",       "gryblts"}, | 	{"greybars",      "grey bars"}, | ||||||
| 	{"greybars",      "grey bars",       "grybrs"}, | 	{"greydots",      "grey wall dots"}, | ||||||
| 	{"greydots",      "grey wall dots",       "grydts"}, | 	{"greygreenbar",      "gray power pipe",        10}, | ||||||
| 	{"greygreenbar",      "gray power pipe",       "grygrnbr", 10}, | 	{"octofloor",      "Doom floor"}, | ||||||
| 	{"octofloor",      "Doom floor",       "octofloor"}, | 	{"octofloor2",      "Brown Doom floor"}, | ||||||
| 	{"octofloor2",      "Brown Doom floor",       "octofloor2"}, | 	{"doomwall1",      "Doom wall 1"}, | ||||||
| 	{"doomwall1",      "Doom wall 1",       "doomwall1"}, | 	{"doomwall2",      "Doom wall 2"}, | ||||||
| 	{"doomwall2",      "Doom wall 2",       "doomwall2"}, | 	{"doomwall3",      "Doom wall 3"}, | ||||||
| 	{"doomwall3",      "Doom wall 3",       "doomwall3"}, | 	{"doomwall4",      "Doom wall 4"}, | ||||||
| 	{"doomwall4",      "Doom wall 4",       "doomwall4"}, | 	{"doomwall41",      "Doom wall 4.1"}, | ||||||
| 	{"doomwall41",      "Doom wall 4.1",       "doomwall4.1"}, | 	{"doomwall42",      "Doom wall 4.2"}, | ||||||
| 	{"doomwall42",      "Doom wall 4.2",       "doomwall4.2"}, | 	{"doomwall43",      "Doom wall 4.3"}, | ||||||
| 	{"doomwall43",      "Doom wall 4.3",       "doomwall4.3"}, | 	{"doomwall431",      "Doom wall 4.3.1"}, | ||||||
| 	{"doomwall431",      "Doom wall 4.3.1",       "doomwall4.3.1"}, | 	{"doomwall44",      "Doom wall 4.4"}, | ||||||
| 	{"doomwall44",      "Doom wall 4.4",       "doomwall4.4"}, | 	{"blackdmg",      "Damaged black wall"}, | ||||||
| 	{"blackdmg",      "Damaged black wall",       "blckdmg"}, | 	{"blackdmgstripe",      "Damaged black wall(stripes)"}, | ||||||
| 	{"blackdmgstripe",      "Damaged black wall(stripes)",       "blckdmgstripe"}, | 	{"doomengine",      "Doom engine wall"}, | ||||||
| 	{"doomengine",      "Doom engine wall",       "doomengine"}, |  | ||||||
| --	{"monitorwall",      "Wall monitors",       "monitorwall"}, | --	{"monitorwall",      "Wall monitors",       "monitorwall"}, | ||||||
| 	{"screen3",      "Wall monitor",       "screen3"}, | 	{"screen3",      "Wall monitor"}, | ||||||
| 	{"doomlight",      "Doom light",       "doomlight", 12}, | 	{"doomlight",      "Doom light",       12}, | ||||||
| 	{"bluwllight",      "Blue wall light", "capsule3", default.LIGHT_MAX}, | 	{"bluwllight",      "Blue wall light", minetest.LIGHT_MAX}, | ||||||
| 	{"bluegrid",      "Blue Grid", "bluegrid", 5}, | 	{"bluegrid",      "Blue Grid", 5}, | ||||||
| 	{"fan",      "Fan",       "fan"}, | 	{"fan",      "Fan"}, | ||||||
| 	{"ppllght",      "Purple wall light", "", default.LIGHT_MAX}, | 	{"ppllght",      "Purple wall light", minetest.LIGHT_MAX}, | ||||||
| 	{"pplwll",      "Purple wall", "", 0}, | 	{"pplwll",      "Purple wall"}, | ||||||
| 	{"pplwll2",      "Purple wall2", "", 0}, | 	{"pplwll2",      "Purple wall2"}, | ||||||
| 	{"pplwll3",      "Purple wall3", "", 0}, | 	{"pplwll3",      "Purple wall3"}, | ||||||
| 	{"pplwll4",      "Purple wall4", "", 0}, | 	{"pplwll4",      "Purple wall4"}, | ||||||
| 	{"pplblk",      "Purple tile", "", 0}, | 	{"pplblk",      "Purple tile"}, | ||||||
| 	{"purple",      "Purple node", "", 0}, | 	{"purple",      "Purple node"}, | ||||||
| 	{"rock",      "Moonstone", "", 0}, | 	{"rock",      "Moonstone"}, | ||||||
| 	{"rock2",      "Moonstone2", "", 0}, | 	{"rock2",      "Moonstone2"}, | ||||||
| 	{"blackvnt",      "Black vent", "", 0}, | 	{"blackvnt",      "Black vent"}, | ||||||
| 	{"blackplate",      "Black plate", "", 0}, | 	{"blackplate",      "Black plate"}, | ||||||
| } | } | ||||||
|  |  | ||||||
| if minetest.global_exists("stairsplus") then | if minetest.global_exists("stairsplus") then | ||||||
|  |  | ||||||
| 	for _, row in ipairs(node.types) do | 	for _, row in ipairs(node.types) do | ||||||
| 		local name = row[1] | 		local name = row[1] | ||||||
| 		local desc = row[2] |  | ||||||
| 		local light = row[4] |  | ||||||
| 		-- Node Definition | 		-- Node Definition | ||||||
| 		stairsplus:register_all("scifi_nodes", row[1], "scifi_nodes:"..name, { | 		stairsplus:register_all("scifi_nodes", name, "scifi_nodes:"..name, { | ||||||
| 			description = desc, | 			description = row[2], | ||||||
| 			tiles = {"scifi_nodes_"..name..".png"}, | 			tiles = {"scifi_nodes_"..name..".png"}, | ||||||
|  | 			use_texture_alpha = "clip", | ||||||
| 			groups = {cracky=1}, | 			groups = {cracky=1}, | ||||||
| 			paramtype = "light", | 			paramtype = "light", | ||||||
| 			paramtype2 = "facedir", | 			paramtype2 = "facedir", | ||||||
| 			light_source = light, | 			light_source = row[3], | ||||||
| 		}) | 		}) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|   | |||||||
							
								
								
									
										237
									
								
								nodeboxes.lua
									
									
									
									
									
								
							
							
						
						| @@ -32,7 +32,7 @@ minetest.register_node("scifi_nodes:alienslope", { | |||||||
| 			{-0.125, 0.375, -0.5, 0.5, 0.5, 0.5}, -- NodeBox17 | 			{-0.125, 0.375, -0.5, 0.5, 0.5, 0.5}, -- NodeBox17 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = scifi_nodes.node_sound_wood_defaults(), | ||||||
| 	on_place = minetest.rotate_node | 	on_place = minetest.rotate_node | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -62,7 +62,7 @@ minetest.register_node("scifi_nodes:wallpipe", { | |||||||
| 			{-0.5, -0.125, 0, 0.5, 0, 0.0625}, -- NodeBox24 | 			{-0.5, -0.125, 0, 0.5, 0, 0.0625}, -- NodeBox24 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_wood_defaults() | 	sounds = scifi_nodes.node_sound_wood_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:plant_trap", { | minetest.register_node("scifi_nodes:plant_trap", { | ||||||
| @@ -91,7 +91,7 @@ minetest.register_node("scifi_nodes:plant_trap", { | |||||||
| 			{-0.0625, -0.5, 0.3125, 0, 0.5, 0.375}, -- NodeBox28 | 			{-0.0625, -0.5, 0.3125, 0, 0.5, 0.375}, -- NodeBox28 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = scifi_nodes.node_sound_wood_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:egg", { | minetest.register_node("scifi_nodes:egg", { | ||||||
| @@ -122,7 +122,7 @@ minetest.register_node("scifi_nodes:egg", { | |||||||
| 			{-0.125, 0.75, -0.125, 0.125, 0.8125, 0.125}, -- NodeBox8 | 			{-0.125, 0.75, -0.125, 0.125, 0.8125, 0.125}, -- NodeBox8 | ||||||
| 			{-0.375, -0.3125, -0.4375, 0.375, 0.3125, 0.4375}, -- NodeBox9 | 			{-0.375, -0.3125, -0.4375, 0.375, 0.3125, 0.4375}, -- NodeBox9 | ||||||
| 		}, | 		}, | ||||||
| 	sounds = default.node_sound_wood_defaults() | 	sounds = scifi_nodes.node_sound_wood_defaults() | ||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -151,7 +151,8 @@ minetest.register_node("scifi_nodes:pad", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1}, | ||||||
| 	light_source = 5, | 	light_source = 5, | ||||||
| 	on_construct = function(pos, node, placer) |     after_place_node = function(pos, placer, itemstack, pointed_thing) | ||||||
|  |         local placer_name = placer:get_player_name() | ||||||
| 		local meta = minetest.get_meta(pos) | 		local meta = minetest.get_meta(pos) | ||||||
| 		if position1 == nil then | 		if position1 == nil then | ||||||
| 			position1 = pos | 			position1 = pos | ||||||
| @@ -160,10 +161,11 @@ minetest.register_node("scifi_nodes:pad", { | |||||||
| 			position2 = pos | 			position2 = pos | ||||||
| 			meta:set_int("type", 2) | 			meta:set_int("type", 2) | ||||||
| 		else | 		else | ||||||
| 			minetest.chat_send_all("There can only be two teleportation pads at a time!") | 			minetest.chat_send_player(placer_name, "There can only be two teleportation pads at a time!") | ||||||
| 		end | 		end | ||||||
| 	end, | 	end, | ||||||
|     on_rightclick = function(pos, node, clicker) |     on_rightclick = function(pos, node, clicker) | ||||||
|  |         local clicker_name = clicker:get_player_name() | ||||||
| 		local meta = minetest.get_meta(pos) | 		local meta = minetest.get_meta(pos) | ||||||
| 		if meta:get_int("type") == 1 and position2 ~= nil and position1 ~= nil then | 		if meta:get_int("type") == 1 and position2 ~= nil and position1 ~= nil then | ||||||
| 		minetest.add_particlespawner( | 		minetest.add_particlespawner( | ||||||
| @@ -236,12 +238,12 @@ minetest.register_node("scifi_nodes:pad", { | |||||||
| 		elseif position1 == nil and meta:get_int("type") ~= 2 then | 		elseif position1 == nil and meta:get_int("type") ~= 2 then | ||||||
| 		position1 = pos | 		position1 = pos | ||||||
|         meta:set_int("type", 1) |         meta:set_int("type", 1) | ||||||
| 		minetest.chat_send_all("Teleporter 1 connected at "..minetest.pos_to_string(pos)) | 		minetest.chat_send_player(clicker_name, "Teleporter 1 connected at "..minetest.pos_to_string(pos)) | ||||||
| 		elseif position2 == nil and meta:get_int("type") ~= 1 then | 		elseif position2 == nil and meta:get_int("type") ~= 1 then | ||||||
| 		position2 = pos | 		position2 = pos | ||||||
| 		meta:set_int("type", 2) | 		meta:set_int("type", 2) | ||||||
| 		minetest.chat_send_all("Teleporter 2 connected at "..minetest.pos_to_string(pos)) | 		minetest.chat_send_player(clicker_name, "Teleporter 2 connected at "..minetest.pos_to_string(pos)) | ||||||
| 		else minetest.chat_send_all("Teleporter error!") | 		else minetest.chat_send_player(clicker_name, "Teleporter error!") | ||||||
| 		end | 		end | ||||||
| 	end, | 	end, | ||||||
| 	on_destruct = function(pos, oldnode, placer) | 	on_destruct = function(pos, oldnode, placer) | ||||||
| @@ -262,7 +264,7 @@ minetest.register_node("scifi_nodes:pad", { | |||||||
| 			{-0.875, -0.5, -0.8125, 0.8125, -0.375, 0.8125}, -- NodeBox3 | 			{-0.875, -0.5, -0.8125, 0.8125, -0.375, 0.8125}, -- NodeBox3 | ||||||
| 			{-0.8125, -0.5, -0.75, 0.75, -0.3125, 0.75}, -- NodeBox4 | 			{-0.8125, -0.5, -0.75, 0.75, -0.3125, 0.75}, -- NodeBox4 | ||||||
| 		}, | 		}, | ||||||
| 	sounds = default.node_sound_wood_defaults() | 	sounds = scifi_nodes.node_sound_wood_defaults() | ||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -279,9 +281,9 @@ minetest.register_node("scifi_nodes:pplwndw", { | |||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	groups = {cracky=3}, | 	groups = {cracky=3}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = { | 		fixed = { | ||||||
| @@ -302,11 +304,11 @@ minetest.register_node("scifi_nodes:gloshroom", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	walkable = false, | 	walkable = false, | ||||||
| 	buildable_to = true, | 	buildable_to = true, | ||||||
| 	sunlight_propagates = false, | 	sunlight_propagates = false, | ||||||
| 	use_texture_alpha =  true, | 	use_texture_alpha = "blend", | ||||||
| 	groups = {fleshy=1, oddly_breakable_by_hand=1, dig_immediate=3}, | 	groups = {fleshy=1, oddly_breakable_by_hand=1, dig_immediate=3}, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| @@ -322,50 +324,64 @@ minetest.register_node("scifi_nodes:gloshroom", { | |||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:pot_lid", { | minetest.register_node("scifi_nodes:pot_lid", { | ||||||
| 	description = "plant pot lid(place above plant)", | 	description = "Plant Pot Lid", | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		"scifi_nodes_glass2.png", |  | ||||||
| 		"scifi_nodes_glass2.png", |  | ||||||
| 		"scifi_nodes_glass2.png", |  | ||||||
| 		"scifi_nodes_glass2.png", |  | ||||||
| 		"scifi_nodes_glass2.png", |  | ||||||
| 		"scifi_nodes_glass2.png" | 		"scifi_nodes_glass2.png" | ||||||
| 	}, | 	}, | ||||||
| 	inventory_image = "scifi_nodes_pod_inv.png", | 	inventory_image = "scifi_nodes_pod_inv.png", | ||||||
| 	wield_image = "scifi_nodes_pod_inv.png", | 	wield_image = "scifi_nodes_pod_inv.png", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1, not_in_creative_inventory=1}, | 	groups = {not_in_creative_inventory = 1}, | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
|  | 	diggable = false, | ||||||
|  | 	drop = "", | ||||||
| 	selection_box = { | 	selection_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = {0, 0, 0, 0, 0, 0} | 		fixed = {-0.5, -1.5, -0.5, 0.5, -0.25, 0.5} | ||||||
| 	}, |  | ||||||
| 	collision_box = { |  | ||||||
| 		type = "fixed", |  | ||||||
| 		fixed = {-0.5, -1.5, -0.5, 0.5, -0.5, 0.5} |  | ||||||
| 	}, | 	}, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = { | 		fixed = { | ||||||
| 			{-0.1875, -0.5625, -0.1875, 0.1875, -0.5, 0.1875}, -- NodeBox13 | 			{-0.4375, -1.5, -0.4375, 0.4375, -0.5, -0.375}, | ||||||
| 			{-0.25, -0.625, -0.25, 0.25, -0.5625, 0.25}, -- NodeBox14 | 			{-0.4375, -1.5, 0.375, 0.4375, -0.5, 0.4375}, | ||||||
| 			{-0.3125, -0.6875, -0.3125, 0.3125, -0.625, 0.3125}, -- NodeBox15 | 			{-0.4375, -1.5, -0.375, -0.375, -0.5, 0.375}, | ||||||
| 			{-0.375, -0.75, -0.375, 0.375, -0.6875, 0.375}, -- NodeBox16 | 			{0.375, -1.5, -0.375, 0.4375, -0.5, 0.375}, | ||||||
| 			{-0.4375, -0.75, 0.375, 0.4375, -1.5, 0.4375}, -- NodeBox17 | 			{-0.375, -0.5, -0.375, 0.375, -0.4375, 0.375}, | ||||||
| 			{-0.4375, -0.75, -0.4375, 0.4375, -1.5, -0.375}, -- NodeBox18 | 			{-0.3125, -0.4375, -0.3125, 0.3125, -0.375, 0.3125}, | ||||||
| 			{0.375, -0.75, -0.4375, 0.4375, -1.5, 0.4375}, -- NodeBox19 | 			{-0.25, -0.375, -0.25, 0.25, -0.3125, 0.25}, | ||||||
| 			{-0.4375, -0.75, -0.4375, -0.375, -1.5, 0.4375}, -- NodeBox20 | 			{-0.1875, -0.3125, -0.1875, 0.1875, -0.25, 0.1875} | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | local function toggle_lid(pos, node, player, itemstack) | ||||||
|  | 	if not player or minetest.is_protected(pos, player:get_player_name()) then | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  | 	local lid_pos = {x = pos.x, y = pos.y+2 , z = pos.z} | ||||||
|  | 	local lid_node = minetest.get_node(lid_pos) | ||||||
|  | 	if lid_node.name == "scifi_nodes:pot_lid" then | ||||||
|  | 		minetest.set_node(lid_pos, {name = "air"}) | ||||||
|  | 	elseif lid_node.name == "air" then | ||||||
|  | 		minetest.set_node(lid_pos, {name = "scifi_nodes:pot_lid"}) | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local function remove_lid(pos) | ||||||
|  | 	local lid_pos = {x = pos.x, y = pos.y+2 , z = pos.z} | ||||||
|  | 	local lid_node = minetest.get_node(lid_pos) | ||||||
|  | 	if lid_node.name == "scifi_nodes:pot_lid" then | ||||||
|  | 		minetest.set_node(lid_pos, {name = "air"}) | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:pot", { | minetest.register_node("scifi_nodes:pot", { | ||||||
| 	description = "metal plant pot (right click for lid, shift+rightclick to plant)", | 	description = "Metal Plant Pot (right-click for lid, sneak + right-click to plant)", | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		"scifi_nodes_pot.png", | 		"default_dirt.png^scifi_nodes_pot.png", | ||||||
| 		"scifi_nodes_greybolts.png", | 		"scifi_nodes_greybolts.png", | ||||||
| 		"scifi_nodes_greybolts.png", | 		"scifi_nodes_greybolts.png", | ||||||
| 		"scifi_nodes_greybolts.png", | 		"scifi_nodes_greybolts.png", | ||||||
| @@ -374,34 +390,30 @@ minetest.register_node("scifi_nodes:pot", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1, soil=1, sand=1}, | 	groups = {cracky = 1, soil = 1, sand = 1}, | ||||||
|  | 	selection_box = { | ||||||
|  | 		type = "fixed", | ||||||
|  | 		fixed = {-0.5, -0.5, -0.5, 0.5, 0.5, 0.5} | ||||||
|  | 	}, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = { | 		fixed = { | ||||||
| 			{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5}, -- NodeBox1 | 			{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5}, | ||||||
| 			{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5}, -- NodeBox2 | 			{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5}, | ||||||
| 			{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875}, -- NodeBox3 | 			{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875}, | ||||||
| 			{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5}, -- NodeBox4 | 			{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5}, | ||||||
| 			{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875}, -- NodeBox5 | 			{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875} | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = toggle_lid, | ||||||
| 		local lid_node = minetest.get_node({x=pos.x, y=pos.y+2, z=pos.z}) | 	on_destruct = remove_lid, | ||||||
| 		if lid_node.name == "scifi_nodes:pot_lid" then | 	sounds = scifi_nodes.node_sound_metal_defaults(), | ||||||
| 			minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="air", param2=lid_node.param2}) |  | ||||||
| 		elseif lid_node.name ~= "scifi_nodes:pot_lid" and node.name == "air" then |  | ||||||
| 			minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="scifi_nodes:pot_lid", param2=lid_node.param2}) |  | ||||||
| 		end |  | ||||||
| 	end, |  | ||||||
| 	on_destruct = function(pos, node, _) |  | ||||||
| 		minetest.remove_node({x=pos.x, y=pos.y+2, z=pos.z}) |  | ||||||
| 	end |  | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:pot2", { | minetest.register_node("scifi_nodes:pot2", { | ||||||
| 	description = "metal wet plant pot(right click for lid, shift+rightclick to plant)", | 	description = "Metal Plant Pot Wet (right-click for lid, sneak + right-click to plant)", | ||||||
| 	tiles = { | 	tiles = { | ||||||
| 		"scifi_nodes_pot.png^[colorize:black:100", | 		"default_dirt.png^scifi_nodes_pot2.png", | ||||||
| 		"scifi_nodes_greybolts.png", | 		"scifi_nodes_greybolts.png", | ||||||
| 		"scifi_nodes_greybolts.png", | 		"scifi_nodes_greybolts.png", | ||||||
| 		"scifi_nodes_greybolts.png", | 		"scifi_nodes_greybolts.png", | ||||||
| @@ -410,28 +422,24 @@ minetest.register_node("scifi_nodes:pot2", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1, soil=3, wet=1}, | 	groups = {cracky = 1, soil = 3, wet = 1}, | ||||||
|  | 	selection_box = { | ||||||
|  | 		type = "fixed", | ||||||
|  | 		fixed = {-0.5, -0.5, -0.5, 0.5, 0.5, 0.5} | ||||||
|  | 	}, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = { | 		fixed = { | ||||||
| 			{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5}, -- NodeBox1 | 			{-0.5, -0.25, -0.5, 0.5, 0.5, 0.5}, | ||||||
| 			{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5}, -- NodeBox2 | 			{0.1875, -0.5, 0.1875, 0.5, -0.25, 0.5}, | ||||||
| 			{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875}, -- NodeBox3 | 			{-0.5, -0.5, -0.5, -0.1875, -0.25, -0.1875}, | ||||||
| 			{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5}, -- NodeBox4 | 			{-0.5, -0.5, 0.1875, -0.1875, -0.25, 0.5}, | ||||||
| 			{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875}, -- NodeBox5 | 			{0.1875, -0.5, -0.5, 0.5, -0.25, -0.1875} | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = toggle_lid, | ||||||
| 		local lid_node = minetest.get_node({x=pos.x, y=pos.y+2, z=pos.z}) | 	on_destruct = remove_lid, | ||||||
| 		if lid_node.name == "scifi_nodes:pot_lid" then | 	sounds = scifi_nodes.node_sound_metal_defaults(), | ||||||
| 			minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="air", param2=lid_node.param2}) |  | ||||||
| 		elseif lid_node.name ~= "scifi_nodes:pot_lid" and node.name == "air" then |  | ||||||
| 			minetest.set_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="scifi_nodes:pot_lid", param2=lid_node.param2}) |  | ||||||
| 		end |  | ||||||
| 	end, |  | ||||||
| 	on_destruct = function(pos, node, _) |  | ||||||
| 		minetest.remove_node({x=pos.x, y=pos.y+2, z=pos.z}) |  | ||||||
| 	end |  | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:lightbar", { | minetest.register_node("scifi_nodes:lightbar", { | ||||||
| @@ -443,7 +451,7 @@ minetest.register_node("scifi_nodes:lightbar", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = { | 		fixed = { | ||||||
| @@ -457,7 +465,7 @@ minetest.register_node("scifi_nodes:lightbar", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:light_dynamic", { | minetest.register_node("scifi_nodes:light_dynamic", { | ||||||
| @@ -473,10 +481,16 @@ minetest.register_node("scifi_nodes:light_dynamic", { | |||||||
| 		type = "wallmounted", | 		type = "wallmounted", | ||||||
| 		fixed = {-0.5, -0.5, -0.5, -0.45, 0.5, 0.5} | 		fixed = {-0.5, -0.5, -0.5, -0.45, 0.5, 0.5} | ||||||
| 	}, | 	}, | ||||||
|  | 	node_box = { | ||||||
|  | 		type = "fixed", | ||||||
|  | 		fixed = { | ||||||
|  | 			fixed = {-0.5, -0.5, -0.5, -0.45, 0.5, 0.5} | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:ladder", { | minetest.register_node("scifi_nodes:ladder", { | ||||||
| @@ -506,7 +520,7 @@ minetest.register_node("scifi_nodes:ladder", { | |||||||
| 			{0.3125, -0.5, 0.0625, 0.4375, -0.375, 0.1875}, -- NodeBox25 | 			{0.3125, -0.5, 0.0625, 0.4375, -0.375, 0.1875}, -- NodeBox25 | ||||||
| 			{0.3125, -0.5, -0.1875, 0.4375, -0.375, -0.0625}, -- NodeBox26 | 			{0.3125, -0.5, -0.1875, 0.4375, -0.375, -0.0625}, -- NodeBox26 | ||||||
| 		}, | 		}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| 	}, | 	}, | ||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	walkable = false, | 	walkable = false, | ||||||
| @@ -521,8 +535,8 @@ minetest.register_node("scifi_nodes:lightbars", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| 		fixed = { | 		fixed = { | ||||||
| @@ -533,7 +547,7 @@ minetest.register_node("scifi_nodes:lightbars", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:liquid_pipe", { | minetest.register_node("scifi_nodes:liquid_pipe", { | ||||||
| @@ -542,8 +556,8 @@ tiles = {{ | |||||||
| 		name = "scifi_nodes_liquid.png", | 		name = "scifi_nodes_liquid.png", | ||||||
| 		animation = {type = "vertical_frames", aspect_w = 16, aspect_h = 16, length = 1.00}, | 		animation = {type = "vertical_frames", aspect_w = 16, aspect_h = 16, length = 1.00}, | ||||||
| 	}}, | 	}}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| @@ -554,7 +568,7 @@ tiles = {{ | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:liquid_pipe2", { | minetest.register_node("scifi_nodes:liquid_pipe2", { | ||||||
| @@ -562,8 +576,8 @@ minetest.register_node("scifi_nodes:liquid_pipe2", { | |||||||
| tiles = { | tiles = { | ||||||
| 		"scifi_nodes_orange.png", | 		"scifi_nodes_orange.png", | ||||||
| 	}, | 	}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| @@ -574,7 +588,7 @@ tiles = { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:powered_stand", { | minetest.register_node("scifi_nodes:powered_stand", { | ||||||
| @@ -641,7 +655,7 @@ minetest.register_node("scifi_nodes:cover", { | |||||||
| 			{-0.3125, -0.375, -0.3125, 0.3125, -0.3125, 0.3125}, -- NodeBox6 | 			{-0.3125, -0.375, -0.3125, 0.3125, -0.3125, 0.3125}, -- NodeBox6 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_wood_defaults(), | 	sounds = scifi_nodes.node_sound_wood_defaults(), | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1} | 	groups = {cracky=1, oddly_breakable_by_hand=1} | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -746,7 +760,7 @@ minetest.register_node("scifi_nodes:table", { | |||||||
| 			{-0.0625, 0.25, -0.125, 0.0625, 0.4375, -0.0625}, -- NodeBox7 | 			{-0.0625, 0.25, -0.125, 0.0625, 0.4375, -0.0625}, -- NodeBox7 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_metal_defaults(), | 	sounds = scifi_nodes.node_sound_metal_defaults(), | ||||||
| 	groups = {cracky=1} | 	groups = {cracky=1} | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -846,7 +860,7 @@ minetest.register_node("scifi_nodes:windowcorner", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	node_box = { | 	node_box = { | ||||||
| @@ -862,7 +876,7 @@ minetest.register_node("scifi_nodes:windowcorner", { | |||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	on_place = minetest.rotate_node, | 	on_place = minetest.rotate_node, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:windowstraight", { | minetest.register_node("scifi_nodes:windowstraight", { | ||||||
| @@ -877,7 +891,7 @@ minetest.register_node("scifi_nodes:windowstraight", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	node_box = { | 	node_box = { | ||||||
| @@ -889,7 +903,7 @@ minetest.register_node("scifi_nodes:windowstraight", { | |||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	on_place = minetest.rotate_node, | 	on_place = minetest.rotate_node, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:windowcorner2", { | minetest.register_node("scifi_nodes:windowcorner2", { | ||||||
| @@ -904,7 +918,7 @@ minetest.register_node("scifi_nodes:windowcorner2", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	node_box = { | 	node_box = { | ||||||
| @@ -920,7 +934,7 @@ minetest.register_node("scifi_nodes:windowcorner2", { | |||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	on_place = minetest.rotate_node, | 	on_place = minetest.rotate_node, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:windowstraight2", { | minetest.register_node("scifi_nodes:windowstraight2", { | ||||||
| @@ -935,7 +949,7 @@ minetest.register_node("scifi_nodes:windowstraight2", { | |||||||
| 	}, | 	}, | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	node_box = { | 	node_box = { | ||||||
| @@ -947,7 +961,7 @@ minetest.register_node("scifi_nodes:windowstraight2", { | |||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	on_place = minetest.rotate_node, | 	on_place = minetest.rotate_node, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -962,7 +976,7 @@ minetest.register_node("scifi_nodes:capsule", { | |||||||
| 		"scifi_nodes_capsule.png", | 		"scifi_nodes_capsule.png", | ||||||
| 		"scifi_nodes_capsule.png" | 		"scifi_nodes_capsule.png" | ||||||
| 	}, | 	}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| @@ -976,7 +990,7 @@ minetest.register_node("scifi_nodes:capsule", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = function(pos, node, clicker, item, _) | ||||||
| 			minetest.set_node(pos, {name="scifi_nodes:capsule2", param2=node.param2}) | 			minetest.set_node(pos, {name="scifi_nodes:capsule2", param2=node.param2}) | ||||||
| 	end, | 	end, | ||||||
| @@ -992,7 +1006,7 @@ minetest.register_node("scifi_nodes:capsule3", { | |||||||
| 		"scifi_nodes_capsule3.png", | 		"scifi_nodes_capsule3.png", | ||||||
| 		"scifi_nodes_capsule3.png" | 		"scifi_nodes_capsule3.png" | ||||||
| 	}, | 	}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| @@ -1006,7 +1020,7 @@ minetest.register_node("scifi_nodes:capsule3", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = function(pos, node, clicker, item, _) | ||||||
| 			minetest.set_node(pos, {name="scifi_nodes:capsule", param2=node.param2}) | 			minetest.set_node(pos, {name="scifi_nodes:capsule", param2=node.param2}) | ||||||
| 	end, | 	end, | ||||||
| @@ -1022,7 +1036,7 @@ minetest.register_node("scifi_nodes:capsule2", { | |||||||
| 		"scifi_nodes_capsule2.png", | 		"scifi_nodes_capsule2.png", | ||||||
| 		"scifi_nodes_capsule2.png" | 		"scifi_nodes_capsule2.png" | ||||||
| 	}, | 	}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| @@ -1036,7 +1050,7 @@ minetest.register_node("scifi_nodes:capsule2", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = function(pos, node, clicker, item, _) | ||||||
| 			minetest.set_node(pos, {name="scifi_nodes:capsule3", param2=node.param2}) | 			minetest.set_node(pos, {name="scifi_nodes:capsule3", param2=node.param2}) | ||||||
| 	end, | 	end, | ||||||
| @@ -1066,7 +1080,7 @@ minetest.register_node("scifi_nodes:itemholder", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	on_rotate = screwdriver.disallow, | 	on_rotate = minetest.get_modpath("screwdriver") and screwdriver.disallow, | ||||||
| 	after_place_node = function(pos, placer, itemstack) | 	after_place_node = function(pos, placer, itemstack) | ||||||
| 		local meta = minetest.get_meta(pos) | 		local meta = minetest.get_meta(pos) | ||||||
| 		meta:set_string("owner",placer:get_player_name()) | 		meta:set_string("owner",placer:get_player_name()) | ||||||
| @@ -1078,10 +1092,9 @@ minetest.register_node("scifi_nodes:itemholder", { | |||||||
| 		local meta = minetest.get_meta(pos) | 		local meta = minetest.get_meta(pos) | ||||||
| 		if name == meta:get_string("owner") or | 		if name == meta:get_string("owner") or | ||||||
| 				minetest.check_player_privs(name, "protection_bypass") then | 				minetest.check_player_privs(name, "protection_bypass") then | ||||||
| 			local wield_item = clicker:get_wielded_item():get_name() |  | ||||||
| 			local taken = item:take_item() | 			local taken = item:take_item() | ||||||
| 			if taken and not taken:is_empty() then | 			if taken and not taken:is_empty() then | ||||||
| 				minetest.add_item(pos, wield_item) | 				minetest.add_item(pos, taken:to_string()) | ||||||
| 				return item | 				return item | ||||||
| 			end | 			end | ||||||
| 		end | 		end | ||||||
| @@ -1111,11 +1124,11 @@ minetest.register_node("scifi_nodes:glassscreen", { | |||||||
| 		"scifi_nodes_glscrn.png", | 		"scifi_nodes_glscrn.png", | ||||||
| 		"scifi_nodes_glscrn.png" | 		"scifi_nodes_glscrn.png" | ||||||
| 	}, | 	}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	drawtype = "nodebox", | 	drawtype = "nodebox", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	sunlight_propagates = true, | 	sunlight_propagates = true, | ||||||
| 	node_box = { | 	node_box = { | ||||||
| 		type = "fixed", | 		type = "fixed", | ||||||
| @@ -1125,7 +1138,7 @@ minetest.register_node("scifi_nodes:glassscreen", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1197,7 +1210,7 @@ minetest.register_node("scifi_nodes:windowpanel", { | |||||||
|     }, |     }, | ||||||
|     drawtype = "nodebox", |     drawtype = "nodebox", | ||||||
|     paramtype = "light", |     paramtype = "light", | ||||||
|     use_texture_alpha = true, |     use_texture_alpha = "blend", | ||||||
|     sunlight_propagates = true, |     sunlight_propagates = true, | ||||||
|     paramtype2 = "facedir", |     paramtype2 = "facedir", | ||||||
|     node_box = { |     node_box = { | ||||||
| @@ -1208,5 +1221,5 @@ minetest.register_node("scifi_nodes:windowpanel", { | |||||||
|     }, |     }, | ||||||
|     groups = {cracky=1}, |     groups = {cracky=1}, | ||||||
|     on_place = minetest.rotate_node, |     on_place = minetest.rotate_node, | ||||||
|     sounds = default.node_sound_glass_defaults(), |     sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|   | |||||||
							
								
								
									
										141
									
								
								nodes.lua
									
									
									
									
									
								
							
							
						
						| @@ -35,7 +35,7 @@ minetest.register_node("scifi_nodes:rfloor", { | |||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:bfloor", { | minetest.register_node("scifi_nodes:bfloor", { | ||||||
| @@ -47,7 +47,7 @@ minetest.register_node("scifi_nodes:bfloor", { | |||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -64,7 +64,7 @@ minetest.register_node("scifi_nodes:stripes2", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:gblock", { | minetest.register_node("scifi_nodes:gblock", { | ||||||
| @@ -80,7 +80,7 @@ minetest.register_node("scifi_nodes:gblock", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}; | 	groups = {cracky=1}; | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:gblock2", { | minetest.register_node("scifi_nodes:gblock2", { | ||||||
| @@ -97,7 +97,7 @@ minetest.register_node("scifi_nodes:gblock2", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:gblock3", { | minetest.register_node("scifi_nodes:gblock3", { | ||||||
| @@ -114,7 +114,7 @@ minetest.register_node("scifi_nodes:gblock3", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -133,7 +133,7 @@ minetest.register_node("scifi_nodes:green_light", { | |||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:red_light", { | minetest.register_node("scifi_nodes:red_light", { | ||||||
| @@ -150,7 +150,7 @@ minetest.register_node("scifi_nodes:red_light", { | |||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:discs", { | minetest.register_node("scifi_nodes:discs", { | ||||||
| @@ -166,7 +166,7 @@ minetest.register_node("scifi_nodes:discs", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:disc", { | minetest.register_node("scifi_nodes:disc", { | ||||||
| @@ -182,6 +182,23 @@ minetest.register_node("scifi_nodes:disc", { | |||||||
| 	groups = {cracky=1} | 	groups = {cracky=1} | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | minetest.register_node("scifi_nodes:greenbar_animated", { | ||||||
|  | 	description = "animated green light bar", | ||||||
|  | 	sunlight_propagates = false, | ||||||
|  | 	tiles = { | ||||||
|  | 		"scifi_nodes_greenbar.png", | ||||||
|  | 		"scifi_nodes_greenbar.png", { | ||||||
|  | 			name="scifi_nodes_greenbar_animated.png", | ||||||
|  | 			animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.00}, | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	paramtype = "light", | ||||||
|  | 	paramtype2 = "facedir", | ||||||
|  | 	groups = {cracky=1}, | ||||||
|  | 	light_source = 10, | ||||||
|  | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
|  | 	on_place = minetest.rotate_node | ||||||
|  | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:blink", { | minetest.register_node("scifi_nodes:blink", { | ||||||
| 	description = "blinking light", | 	description = "blinking light", | ||||||
| @@ -193,7 +210,7 @@ minetest.register_node("scifi_nodes:blink", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	light_source = 5, | 	light_source = 5, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:black_lights", { | minetest.register_node("scifi_nodes:black_lights", { | ||||||
| @@ -205,7 +222,7 @@ minetest.register_node("scifi_nodes:black_lights", { | |||||||
| 	}}, | 	}}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:black_screen", { | minetest.register_node("scifi_nodes:black_screen", { | ||||||
| @@ -218,7 +235,7 @@ minetest.register_node("scifi_nodes:black_screen", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	light_source = 1, | 	light_source = 1, | ||||||
| 	sounds = default.node_sound_stone_defaults() | 	sounds = scifi_nodes.node_sound_stone_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:screen", { | minetest.register_node("scifi_nodes:screen", { | ||||||
| @@ -231,7 +248,7 @@ minetest.register_node("scifi_nodes:screen", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	light_source = 5, | 	light_source = 5, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:screen2", { | minetest.register_node("scifi_nodes:screen2", { | ||||||
| @@ -244,7 +261,7 @@ minetest.register_node("scifi_nodes:screen2", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	light_source = 5, | 	light_source = 5, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -263,7 +280,7 @@ minetest.register_node("scifi_nodes:white_pad", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:white_base", { | minetest.register_node("scifi_nodes:white_base", { | ||||||
| @@ -280,7 +297,7 @@ minetest.register_node("scifi_nodes:white_base", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:grnpipe", { | minetest.register_node("scifi_nodes:grnpipe", { | ||||||
| @@ -297,7 +314,7 @@ minetest.register_node("scifi_nodes:grnpipe", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults(), | 	sounds = scifi_nodes.node_sound_metal_defaults(), | ||||||
| 	on_place = minetest.rotate_node | 	on_place = minetest.rotate_node | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -316,7 +333,7 @@ minetest.register_node("scifi_nodes:grnpipe2", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_metal_defaults(), | 	sounds = scifi_nodes.node_sound_metal_defaults(), | ||||||
| 	on_place = minetest.rotate_node | 	on_place = minetest.rotate_node | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -329,10 +346,10 @@ minetest.register_node("scifi_nodes:octrng", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	groups = {cracky=2}, | 	groups = {cracky=2}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:octgrn", { | minetest.register_node("scifi_nodes:octgrn", { | ||||||
| @@ -344,10 +361,10 @@ minetest.register_node("scifi_nodes:octgrn", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	groups = {cracky=2}, | 	groups = {cracky=2}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:octbl", { | minetest.register_node("scifi_nodes:octbl", { | ||||||
| @@ -359,10 +376,10 @@ minetest.register_node("scifi_nodes:octbl", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	groups = {cracky=2}, | 	groups = {cracky=2}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:octppl", { | minetest.register_node("scifi_nodes:octppl", { | ||||||
| @@ -374,10 +391,10 @@ minetest.register_node("scifi_nodes:octppl", { | |||||||
| 	}, | 	}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	groups = {cracky=2}, | 	groups = {cracky=2}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:tower", { | minetest.register_node("scifi_nodes:tower", { | ||||||
| @@ -392,7 +409,7 @@ minetest.register_node("scifi_nodes:tower", { | |||||||
| 	inventory_image = "scifi_nodes_tower.png", | 	inventory_image = "scifi_nodes_tower.png", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=2}, | 	groups = {cracky=2}, | ||||||
| 	sounds = default.node_sound_metal_defaults() | 	sounds = scifi_nodes.node_sound_metal_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:junk", { | minetest.register_node("scifi_nodes:junk", { | ||||||
| @@ -427,7 +444,7 @@ minetest.register_node("scifi_nodes:blumetlight", { | |||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -437,10 +454,10 @@ minetest.register_node("scifi_nodes:lightstp", { | |||||||
| 	tiles = { | 	tiles = { | ||||||
| 		"scifi_nodes_lightstripe.png" | 		"scifi_nodes_lightstripe.png" | ||||||
| 	}, | 	}, | ||||||
| 	light_source = default.LIGHT_MAX, | 	light_source = minetest.LIGHT_MAX, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:blklt2", { | minetest.register_node("scifi_nodes:blklt2", { | ||||||
| @@ -452,7 +469,7 @@ minetest.register_node("scifi_nodes:blklt2", { | |||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:blumetstr", { | minetest.register_node("scifi_nodes:blumetstr", { | ||||||
| @@ -464,7 +481,7 @@ minetest.register_node("scifi_nodes:blumetstr", { | |||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:glass", { | minetest.register_node("scifi_nodes:glass", { | ||||||
| @@ -474,10 +491,10 @@ minetest.register_node("scifi_nodes:glass", { | |||||||
| 	tiles = { | 	tiles = { | ||||||
| 		"scifi_nodes_glass.png" | 		"scifi_nodes_glass.png" | ||||||
| 	}, | 	}, | ||||||
| 	use_texture_alpha = true, | 	use_texture_alpha = "blend", | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:whtlightbnd", { | minetest.register_node("scifi_nodes:whtlightbnd", { | ||||||
| @@ -489,7 +506,7 @@ minetest.register_node("scifi_nodes:whtlightbnd", { | |||||||
| 	light_source = 10, | 	light_source = 10, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	groups = {cracky=1}, | 	groups = {cracky=1}, | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| --edited wool code (Copyright (C) 2012 celeron55, Perttu Ahola <celeron55@gmail.com>) | --edited wool code (Copyright (C) 2012 celeron55, Perttu Ahola <celeron55@gmail.com>) | ||||||
| @@ -500,14 +517,15 @@ minetest.register_node("scifi_nodes:whtlightbnd", { | |||||||
| -- colors available. When crafting, the last recipes will be checked first. | -- colors available. When crafting, the last recipes will be checked first. | ||||||
| --add new block using texture name(without "scifi_nodes_" prefix) then the description, and then the name of the block | --add new block using texture name(without "scifi_nodes_" prefix) then the description, and then the name of the block | ||||||
| local nodetypes = { | local nodetypes = { | ||||||
|  | 	-- { name, description, shortname?, light, colorable } | ||||||
| 	{"blue",      "blue lines",        "blue"}, | 	{"blue",      "blue lines",        "blue"}, | ||||||
| 	{"holes",       "metal with holes","holes"}, | 	{"holes",       "metal with holes","holes"}, | ||||||
| 	{"white2",      "plastic",         "white2"}, | 	{"white2",      "plastic",         "white2", 0, true}, | ||||||
|     {"super_white",      "Super Plastic",         "super_white", 11}, |     {"super_white",      "Super Plastic",         "super_white", 11}, | ||||||
|     {"ultra_white",      "Ultra Plastic",         "ultra_white", default.LIGHT_MAX}, |     {"ultra_white",      "Ultra Plastic",         "ultra_white", minetest.LIGHT_MAX}, | ||||||
| 	{"engine",      "engine",          "engine"}, | 	{"engine",      "engine",          "engine"}, | ||||||
| 	{"wall",      "metal wall",        "wall"}, | 	{"wall",      "metal wall",        "wall"}, | ||||||
| 	{"white",      "plastic wall",     "white"}, | 	{"white",      "plastic wall",     "white", 0, true}, | ||||||
| 	{"stripes2top",     "dirty metal block","metal2"}, | 	{"stripes2top",     "dirty metal block","metal2"}, | ||||||
| 	{"rough",      "rough metal",      "rough"}, | 	{"rough",      "rough metal",      "rough"}, | ||||||
| 	{"lighttop",      "metal block",      "metal"}, | 	{"lighttop",      "metal block",      "metal"}, | ||||||
| @@ -528,12 +546,11 @@ local nodetypes = { | |||||||
| 	{"bluetile",      "blue tile",       "blutl"}, | 	{"bluetile",      "blue tile",       "blutl"}, | ||||||
| 	{"greytile",      "grey tile",       "grytl"}, | 	{"greytile",      "grey tile",       "grytl"}, | ||||||
| 	{"mesh2",      "metal floormesh",       "mesh2"}, | 	{"mesh2",      "metal floormesh",       "mesh2"}, | ||||||
| 	{"white",      "plastic wall",       "white"}, |  | ||||||
| 	{"pipe",      "wall pipe",       "pipe2"}, | 	{"pipe",      "wall pipe",       "pipe2"}, | ||||||
| 	{"pipeside",      "side pipe",       "pipe3"}, | 	{"pipeside",      "side pipe",       "pipe3"}, | ||||||
| 	{"tile",      "white tile",       "tile"}, | 	{"tile",      "white tile",       "tile"}, | ||||||
| 	{"whiteoct",      "white octagon",       "whiteoct"}, | 	{"whiteoct",      "white octagon",       "whiteoct", 0, true}, | ||||||
| 	{"whitetile",      "white tile2",       "whttl"}, | 	{"whitetile",      "white tile2",       "whttl", 0, true}, | ||||||
| 	{"black_detail",      "black detail",       "blckdtl"}, | 	{"black_detail",      "black detail",       "blckdtl"}, | ||||||
| 	{"green_square",      "green metal block",       "grnblck"}, | 	{"green_square",      "green metal block",       "grnblck"}, | ||||||
| 	{"red_square",      "red metal block",       "redblck"}, | 	{"red_square",      "red metal block",       "redblck"}, | ||||||
| @@ -570,10 +587,10 @@ local nodetypes = { | |||||||
| 	{"monitorwall",      "Wall monitors",       "monitorwall"}, | 	{"monitorwall",      "Wall monitors",       "monitorwall"}, | ||||||
| 	{"screen3",      "Wall monitor",       "screen3"}, | 	{"screen3",      "Wall monitor",       "screen3"}, | ||||||
| 	{"doomlight",      "Doom light",       "doomlight", 12}, | 	{"doomlight",      "Doom light",       "doomlight", 12}, | ||||||
| 	{"bluwllight",      "Blue wall light", "capsule3", default.LIGHT_MAX}, | 	{"bluwllight",      "Blue wall light", "capsule3", minetest.LIGHT_MAX}, | ||||||
| 	{"bluegrid",      "Blue Grid", "bluegrid", 5}, | 	{"bluegrid",      "Blue Grid", "bluegrid", 5}, | ||||||
| 	{"fan",      "Fan",       "fan"}, | 	{"fan",      "Fan",       "fan"}, | ||||||
| 	{"ppllght",      "Purple wall light", "", default.LIGHT_MAX}, | 	{"ppllght",      "Purple wall light", "", minetest.LIGHT_MAX}, | ||||||
| 	{"pplwll",      "Purple wall", "", 0}, | 	{"pplwll",      "Purple wall", "", 0}, | ||||||
| 	{"pplwll2",      "Purple wall2", "", 0}, | 	{"pplwll2",      "Purple wall2", "", 0}, | ||||||
| 	{"pplwll3",      "Purple wall3", "", 0}, | 	{"pplwll3",      "Purple wall3", "", 0}, | ||||||
| @@ -586,18 +603,52 @@ local nodetypes = { | |||||||
| 	{"blackplate",      "Black plate", "", 0}, | 	{"blackplate",      "Black plate", "", 0}, | ||||||
| } | } | ||||||
|  |  | ||||||
|  | local has_unifieddyes_mod = minetest.get_modpath("unifieddyes") | ||||||
|  |  | ||||||
| for _, row in ipairs(nodetypes) do | for _, row in ipairs(nodetypes) do | ||||||
| 	local name = row[1] | 	local name = row[1] | ||||||
| 	local desc = row[2] | 	local desc = row[2] | ||||||
| 	local light = row[4] | 	local light = row[4] | ||||||
|  | 	local is_colorable = row[5] | ||||||
|  |  | ||||||
| 	-- Node Definition | 	-- Node Definition | ||||||
| 	minetest.register_node("scifi_nodes:"..name, { | 	local node_def = { | ||||||
| 		description = desc, | 		description = desc, | ||||||
| 		tiles = {"scifi_nodes_"..name..".png"}, | 		tiles = {"scifi_nodes_"..name..".png"}, | ||||||
| 		groups = {cracky=1}, | 		groups = {cracky=1}, | ||||||
| 		paramtype = "light", | 		paramtype = "light", | ||||||
| 		paramtype2 = "facedir", | 		paramtype2 = "facedir", | ||||||
| 		light_source = light, | 		light_source = light, | ||||||
| 		sounds = default.node_sound_glass_defaults() | 		sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if is_colorable and has_unifieddyes_mod then | ||||||
|  | 		-- overwrite attributes on the "uncolored" node | ||||||
|  | 		node_def.palette = "unifieddyes_palette_extended.png" | ||||||
|  | 		node_def.groups.ud_param2_colorable = 1 | ||||||
|  | 		node_def.airbrush_replacement_node = "scifi_nodes:"..name.."_colored" | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	-- register node | ||||||
|  | 	minetest.register_node("scifi_nodes:"..name, node_def) | ||||||
|  |  | ||||||
|  | 	if is_colorable and has_unifieddyes_mod then | ||||||
|  | 		-- register colored node | ||||||
|  | 		minetest.register_node("scifi_nodes:"..name.."_colored", { | ||||||
|  | 			description = desc, | ||||||
|  | 			tiles = {"scifi_nodes_"..name..".png"}, | ||||||
|  | 			groups = { | ||||||
|  | 				cracky = 1, | ||||||
|  | 				ud_param2_colorable = 1, | ||||||
|  | 				not_in_creative_inventory = 1 | ||||||
|  | 			}, | ||||||
|  | 			palette = "unifieddyes_palette_extended.png", | ||||||
|  | 			paramtype = "light", | ||||||
|  | 			paramtype2 = "color", | ||||||
|  | 			light_source = light, | ||||||
|  | 			sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
|  | 			on_construct = unifieddyes.on_construct, | ||||||
|  | 			on_dig = unifieddyes.on_dig | ||||||
| 		}) | 		}) | ||||||
|  | 	end | ||||||
| end | end | ||||||
							
								
								
									
										111
									
								
								octagon_panes.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,111 @@ | |||||||
|  |  | ||||||
|  | local function register(basename, description, texture) | ||||||
|  |   local nodename_single = "scifi_nodes:" .. basename .. "_pane" | ||||||
|  |   local nodename_double = "scifi_nodes:" .. basename .. "_pane_double" | ||||||
|  |   local nodename_offset = "scifi_nodes:" .. basename .. "_pane_offset" | ||||||
|  |   local recipe_ingredient = "scifi_nodes:" .. basename | ||||||
|  |  | ||||||
|  |   -- single height | ||||||
|  |   minetest.register_node(nodename_single, { | ||||||
|  |     description = description, | ||||||
|  |     drawtype = "nodebox", | ||||||
|  |     tiles = { | ||||||
|  |       texture | ||||||
|  |     }, | ||||||
|  |     wield_image = texture, | ||||||
|  |     paramtype = "light", | ||||||
|  |     paramtype2 = "facedir", | ||||||
|  |     sunlight_propagates = true, | ||||||
|  |     is_ground_content = false, | ||||||
|  |     node_box = { | ||||||
|  |       type = "fixed", | ||||||
|  |       fixed = {{-0.5, -0.5, -0.03125, 0.5, 0.5, 0.03125}}, | ||||||
|  |     }, | ||||||
|  |     selection_box = { | ||||||
|  |       type = "fixed", | ||||||
|  |       fixed = {{-0.5, -0.5, -0.25, 0.5, 0.5, 0.25}}, | ||||||
|  |     }, | ||||||
|  |     groups = {cracky = 3, oddly_breakable_by_hand = 3}, | ||||||
|  |     use_texture_alpha = "blend", | ||||||
|  |     sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   -- double height | ||||||
|  |   minetest.register_node(nodename_double, { | ||||||
|  |     description = description, | ||||||
|  |     drawtype = "nodebox", | ||||||
|  |     tiles = { | ||||||
|  |       texture | ||||||
|  |     }, | ||||||
|  |     wield_image = texture, | ||||||
|  |     paramtype = "light", | ||||||
|  |     paramtype2 = "facedir", | ||||||
|  |     sunlight_propagates = true, | ||||||
|  |     is_ground_content = false, | ||||||
|  |     node_box = { | ||||||
|  |       type = "fixed", | ||||||
|  |       fixed = {{-0.5, -0.5, -0.03125, 0.5, 1.5, 0.03125}}, | ||||||
|  |     }, | ||||||
|  |     selection_box = { | ||||||
|  |       type = "fixed", | ||||||
|  |       fixed = {{-0.5, -0.5, -0.25, 0.5, 1.5, 0.25}}, | ||||||
|  |     }, | ||||||
|  |     groups = {cracky = 3, oddly_breakable_by_hand = 3}, | ||||||
|  |     use_texture_alpha = "blend", | ||||||
|  |     sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   -- single height with offset | ||||||
|  |   minetest.register_node(nodename_offset, { | ||||||
|  |     description = description, | ||||||
|  |     drawtype = "nodebox", | ||||||
|  |     tiles = { | ||||||
|  |       texture | ||||||
|  |     }, | ||||||
|  |     wield_image = texture, | ||||||
|  |     paramtype = "light", | ||||||
|  |     paramtype2 = "facedir", | ||||||
|  |     sunlight_propagates = true, | ||||||
|  |     is_ground_content = false, | ||||||
|  |     node_box = { | ||||||
|  |       type = "fixed", | ||||||
|  |       fixed = {{-0.5, -0.5, 0.96875, 0.5, 0.5, 1.03125}}, | ||||||
|  |     }, | ||||||
|  |     selection_box = { | ||||||
|  |       type = "fixed", | ||||||
|  |       fixed = {{-0.5, -0.5, 0.75, 0.5, 0.5, 1.25}}, | ||||||
|  |     }, | ||||||
|  |     groups = {cracky = 3, oddly_breakable_by_hand = 3}, | ||||||
|  |     use_texture_alpha = "blend", | ||||||
|  |     sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   -- register recipes | ||||||
|  |  | ||||||
|  |   minetest.register_craft({ | ||||||
|  |     output = nodename_single .. " 16", | ||||||
|  |     recipe = { | ||||||
|  |       {recipe_ingredient} | ||||||
|  |     }, | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   minetest.register_craft({ | ||||||
|  |     output = nodename_double .. " 16", | ||||||
|  |     recipe = { | ||||||
|  |       {recipe_ingredient}, | ||||||
|  |       {recipe_ingredient} | ||||||
|  |     }, | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   minetest.register_craft({ | ||||||
|  |     output = nodename_offset, | ||||||
|  |     type = "shapeless", | ||||||
|  |     recipe = {nodename_single}, | ||||||
|  |   }) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | register("octrng", "Orange Octagon Glass pane", "scifi_nodes_octrng.png") | ||||||
|  | register("octgrn", "Green Octagon Glass pane", "scifi_nodes_octgrn.png") | ||||||
|  | register("octbl", "Blue Octagon Glass pane", "scifi_nodes_octbl.png") | ||||||
|  | register("octppl", "Purple Octagon Glass pane", "scifi_nodes_octppl.png") | ||||||
|  | register("glass", "Dark Glass pane", "scifi_nodes_glass.png") | ||||||
| @@ -22,6 +22,8 @@ local function activate_palm_scanner(pos, node, player) | |||||||
|  |  | ||||||
| 	-- check protection | 	-- check protection | ||||||
| 	minetest.after(2, function() | 	minetest.after(2, function() | ||||||
|  | 		if minetest.get_node(pos).name ~= node.name then return end | ||||||
|  |  | ||||||
| 		if minetest.is_protected(pos, name or "") then | 		if minetest.is_protected(pos, name or "") then | ||||||
| 			-- clicker has no access to area | 			-- clicker has no access to area | ||||||
| 			minetest.chat_send_player(name, "Access denied !") | 			minetest.chat_send_player(name, "Access denied !") | ||||||
| @@ -36,6 +38,7 @@ local function activate_palm_scanner(pos, node, player) | |||||||
|  |  | ||||||
| 		-- reset state | 		-- reset state | ||||||
| 		minetest.after(1, function() | 		minetest.after(1, function() | ||||||
|  | 			if minetest.get_node(pos).name ~= node.name then return end | ||||||
| 			node.name = "scifi_nodes:palm_scanner_off" | 			node.name = "scifi_nodes:palm_scanner_off" | ||||||
| 			minetest.swap_node(pos, node) | 			minetest.swap_node(pos, node) | ||||||
| 			mesecon.receptor_off(pos, scifi_nodes.get_switch_rules(node.param2)) | 			mesecon.receptor_off(pos, scifi_nodes.get_switch_rules(node.param2)) | ||||||
| @@ -62,7 +65,7 @@ minetest.register_node("scifi_nodes:palm_scanner_off", { | |||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	on_rightclick = (has_mesecons and activate_palm_scanner), | 	on_rightclick = (has_mesecons and activate_palm_scanner), | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:palm_scanner_checking", { | minetest.register_node("scifi_nodes:palm_scanner_checking", { | ||||||
| @@ -80,7 +83,7 @@ minetest.register_node("scifi_nodes:palm_scanner_checking", { | |||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1}, | 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1}, | ||||||
| 	drop = "scifi_nodes:palm_scanner_off", | 	drop = "scifi_nodes:palm_scanner_off", | ||||||
| 	sounds = default.node_sound_glass_defaults() | 	sounds = scifi_nodes.node_sound_glass_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_node("scifi_nodes:palm_scanner_on", { | minetest.register_node("scifi_nodes:palm_scanner_on", { | ||||||
| @@ -103,7 +106,7 @@ minetest.register_node("scifi_nodes:palm_scanner_on", { | |||||||
| 			state = (has_mesecons and mesecon.state.on) | 			state = (has_mesecons and mesecon.state.on) | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								pkarcs.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,4 @@ | |||||||
|  | pkarcs.register_node("scifi_nodes:whitetile") | ||||||
|  | pkarcs.register_node("scifi_nodes:whiteoct") | ||||||
|  | pkarcs.register_node("scifi_nodes:white") | ||||||
|  | pkarcs.register_node("scifi_nodes:lighttop") | ||||||
| @@ -1,11 +1,11 @@ | |||||||
|  |  | ||||||
| local plants = { | local plants = { | ||||||
| 	{"flower1", "Glow Flower", 1,0, default.LIGHT_MAX}, | 	{"flower1", "Glow Flower", 1,0, minetest.LIGHT_MAX}, | ||||||
| 	{"flower2", "Pink Flower", 1.5,0, 10}, | 	{"flower2", "Pink Flower", 1.5,0, 10}, | ||||||
| 	{"flower3", "Triffid", 2,5, 0}, | 	{"flower3", "Triffid", 2,5, 0}, | ||||||
| 	{"flower4", "Weeping flower", 1.5,0, 0}, | 	{"flower4", "Weeping flower", 1.5,0, 0}, | ||||||
| 	{"plant1", "Bulb Plant", 1,0, 0}, | 	{"plant1", "Bulb Plant", 1,0, 0}, | ||||||
| 	{"plant2", "Trap Plant", 1.5,0, default.LIGHT_MAX}, | 	{"plant2", "Trap Plant", 1.5,0, minetest.LIGHT_MAX}, | ||||||
| 	{"plant3", "Blue Jelly Plant", 1.2,0, 10}, | 	{"plant3", "Blue Jelly Plant", 1.2,0, 10}, | ||||||
| 	{"plant4", "Green Jelly Plant", 1.2,0, 10}, | 	{"plant4", "Green Jelly Plant", 1.2,0, 10}, | ||||||
| 	{"plant5", "Fern Plant", 1.7,0, 0}, | 	{"plant5", "Fern Plant", 1.7,0, 0}, | ||||||
|   | |||||||
							
								
								
									
										89
									
								
								protected_switch.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,89 @@ | |||||||
|  |  | ||||||
|  | -------------- | ||||||
|  | -- Switches -- | ||||||
|  | -------------- | ||||||
|  |  | ||||||
|  | local has_mesecons = minetest.get_modpath("mesecons") | ||||||
|  |  | ||||||
|  | local function toggle_switch(pos, _, player) | ||||||
|  | 	local node = minetest.get_node(pos) | ||||||
|  | 	local name = node.name | ||||||
|  | 	if name == "scifi_nodes:protected_switch_on" then | ||||||
|  | 		-- toggle off | ||||||
|  | 		minetest.sound_play("scifi_nodes_switch", {max_hear_distance = 8, pos = pos}) | ||||||
|  | 		minetest.set_node(pos, {name = "scifi_nodes:protected_switch_off", param2 = node.param2}) | ||||||
|  | 		mesecon.receptor_off(pos, scifi_nodes.get_switch_rules(node.param2)) | ||||||
|  | 	elseif name == "scifi_nodes:protected_switch_off" then | ||||||
|  | 		-- toggle on, check protection first | ||||||
|  | 		if player and minetest.is_protected(pos, player:get_player_name()) then | ||||||
|  | 			-- position is protected, abort | ||||||
|  | 			minetest.sound_play("scifi_nodes_scanner_refused", {max_hear_distance = 8, pos = pos}) | ||||||
|  | 			return | ||||||
|  | 		end | ||||||
|  | 		minetest.sound_play("scifi_nodes_switch", {max_hear_distance = 8, pos = pos}) | ||||||
|  | 		minetest.set_node(pos, {name = "scifi_nodes:protected_switch_on", param2 = node.param2}) | ||||||
|  | 		mesecon.receptor_on(pos, scifi_nodes.get_switch_rules(node.param2)) | ||||||
|  | 		minetest.get_node_timer(pos):start(2) | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | minetest.register_node("scifi_nodes:protected_switch_on", { | ||||||
|  | 	description = "Protected wall switch", | ||||||
|  | 	sunlight_propagates = true, | ||||||
|  | 	buildable_to = false, | ||||||
|  | 	tiles = {"scifi_nodes_switch_on.png",}, | ||||||
|  | 	inventory_image = "scifi_nodes_switch_on.png", | ||||||
|  | 	wield_image = "scifi_nodes_switch_on.png", | ||||||
|  | 	drawtype = "signlike", | ||||||
|  | 	node_box = {type = "wallmounted",}, | ||||||
|  | 	selection_box = {type = "wallmounted",}, | ||||||
|  | 	paramtype = "light", | ||||||
|  | 	paramtype2 = "wallmounted", | ||||||
|  | 	light_source = 5, | ||||||
|  | 	groups = { | ||||||
|  | 		cracky=1, | ||||||
|  | 		oddly_breakable_by_hand = 1, | ||||||
|  | 		not_in_creative_inventory = 1, | ||||||
|  | 		mesecon_needs_receiver = 1 | ||||||
|  | 	}, | ||||||
|  | 	mesecons = { | ||||||
|  | 		receptor = { | ||||||
|  | 			state = (has_mesecons and mesecon.state.on) | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
|  | 	on_rightclick = (has_mesecons and toggle_switch), | ||||||
|  | 	on_timer = (has_mesecons and toggle_switch) | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | minetest.register_node("scifi_nodes:protected_switch_off", { | ||||||
|  | 	description = "Protected wall switch", | ||||||
|  | 	tiles = {"scifi_nodes_switch_off.png",}, | ||||||
|  | 	inventory_image = "scifi_nodes_switch_on.png", | ||||||
|  | 	wield_image = "scifi_nodes_switch_on.png", | ||||||
|  | 	drawtype = "signlike", | ||||||
|  | 	sunlight_propagates = true, | ||||||
|  | 	buildable_to = false, | ||||||
|  | 	node_box = {type = "wallmounted",}, | ||||||
|  | 	selection_box = {type = "wallmounted",}, | ||||||
|  | 	paramtype = "light", | ||||||
|  | 	paramtype2 = "wallmounted", | ||||||
|  | 	groups = { | ||||||
|  | 		cracky = 1, | ||||||
|  | 		oddly_breakable_by_hand = 1, | ||||||
|  | 		mesecon_needs_receiver = 1 | ||||||
|  | 	}, | ||||||
|  | 	mesecons = { | ||||||
|  | 		receptor = { | ||||||
|  | 			state = (has_mesecons and mesecon.state.off) | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
|  | 	on_rightclick = (has_mesecons and toggle_switch) | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | minetest.register_craft({ | ||||||
|  | 	output = "scifi_nodes:protected_switch_off 2", | ||||||
|  | 	type = "shapeless", | ||||||
|  | 	recipe = {"scifi_nodes:switch_off", "default:steel_ingot"} | ||||||
|  | }) | ||||||
| @@ -1,2 +1,5 @@ | |||||||
| # Doors can only be opened by mesecon signal | # Doors can only be opened by mesecon signal | ||||||
| scifi_nodes.doors_open_with_mesecon_only (disables right click on doors) bool true | scifi_nodes.doors_open_with_mesecon_only (disables right click on doors) bool false | ||||||
|  |  | ||||||
|  | # Teleporter recipe flag | ||||||
|  | scifi_nodes.teleporter_enable_crafting (enables the teleporter recipe) bool false | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								sounds.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,29 @@ | |||||||
|  | -- sound definitions | ||||||
|  |  | ||||||
|  | function scifi_nodes.node_sound_wood_defaults() | ||||||
|  |     if minetest.get_modpath("default") then | ||||||
|  |         -- default game | ||||||
|  |         return default.node_sound_wood_defaults() | ||||||
|  |     end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function scifi_nodes.node_sound_glass_defaults() | ||||||
|  |     if minetest.get_modpath("default") then | ||||||
|  |         -- default game | ||||||
|  |         return default.node_sound_glass_defaults() | ||||||
|  |     end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function scifi_nodes.node_sound_metal_defaults() | ||||||
|  |     if minetest.get_modpath("default") then | ||||||
|  |         -- default game | ||||||
|  |         return default.node_sound_metal_defaults() | ||||||
|  |     end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function scifi_nodes.node_sound_stone_defaults() | ||||||
|  |     if minetest.get_modpath("default") then | ||||||
|  |         -- default game | ||||||
|  |         return default.node_sound_stone_defaults() | ||||||
|  |     end | ||||||
|  | end | ||||||
| @@ -33,13 +33,18 @@ minetest.register_node("scifi_nodes:switch_on", { | |||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	light_source = 5, | 	light_source = 5, | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1}, | 	groups = { | ||||||
|  | 		cracky=1, | ||||||
|  | 		oddly_breakable_by_hand = 1, | ||||||
|  | 		not_in_creative_inventory = 1, | ||||||
|  | 		mesecon_needs_receiver = 1 | ||||||
|  | 	}, | ||||||
| 	mesecons = { | 	mesecons = { | ||||||
| 		receptor = { | 		receptor = { | ||||||
| 			state = (has_mesecons and mesecon.state.on) | 			state = (has_mesecons and mesecon.state.on) | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| 	on_rightclick = (has_mesecons and toggle_switch), | 	on_rightclick = (has_mesecons and toggle_switch), | ||||||
| 	on_timer = (has_mesecons and toggle_switch) | 	on_timer = (has_mesecons and toggle_switch) | ||||||
| }) | }) | ||||||
| @@ -56,13 +61,17 @@ minetest.register_node("scifi_nodes:switch_off", { | |||||||
| 	selection_box = {type = "wallmounted",}, | 	selection_box = {type = "wallmounted",}, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	paramtype2 = "wallmounted", | 	paramtype2 = "wallmounted", | ||||||
| 	groups = {cracky=1, oddly_breakable_by_hand=1, mesecon_needs_receiver = 1}, | 	groups = { | ||||||
|  | 		cracky = 1, | ||||||
|  | 		oddly_breakable_by_hand = 1, | ||||||
|  | 		mesecon_needs_receiver = 1 | ||||||
|  | 	}, | ||||||
| 	mesecons = { | 	mesecons = { | ||||||
| 		receptor = { | 		receptor = { | ||||||
| 			state = (has_mesecons and mesecon.state.off) | 			state = (has_mesecons and mesecon.state.off) | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = default.node_sound_glass_defaults(), | 	sounds = scifi_nodes.node_sound_glass_defaults(), | ||||||
| 	on_rightclick = (has_mesecons and toggle_switch) | 	on_rightclick = (has_mesecons and toggle_switch) | ||||||
| }) | }) | ||||||
| 
 | 
 | ||||||
							
								
								
									
										25
									
								
								test/integration-test.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,25 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | # Spins up a test world to ensure proper working recipes and registrations | ||||||
|  |  | ||||||
|  | CWD=$(dirname $0) | ||||||
|  | cd ${CWD}/../ | ||||||
|  |  | ||||||
|  | CFG=/tmp/minetest.conf | ||||||
|  | MTDIR=/tmp/mt | ||||||
|  | WORLDDIR=${MTDIR}/worlds/world | ||||||
|  |  | ||||||
|  | cat <<EOF > ${CFG} | ||||||
|  |  # empty | ||||||
|  | EOF | ||||||
|  |  | ||||||
|  | mkdir -p ${WORLDDIR} | ||||||
|  | chmod 777 ${MTDIR} -R | ||||||
|  | docker run --rm -i \ | ||||||
|  | 	-v ${CFG}:/etc/minetest/minetest.conf:ro \ | ||||||
|  | 	-v ${MTDIR}:/var/lib/minetest/.minetest \ | ||||||
|  | 	-v $(pwd)/:/var/lib/minetest/.minetest/worlds/world/worldmods/scifi_nodes \ | ||||||
|  |   -v $(pwd)/test/test_mod/:/var/lib/minetest/.minetest/worlds/world/worldmods/scifi_nodes_test \ | ||||||
|  |   --network host \ | ||||||
|  | 	registry.gitlab.com/minetest/minetest/server:5.2.0 | ||||||
|  |  | ||||||
|  | test -f ${WORLDDIR}/integration_test.json && exit 0 || exit 1 | ||||||
							
								
								
									
										40
									
								
								test/test_mod/init.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,40 @@ | |||||||
|  |  | ||||||
|  | minetest.log("warning", "[TEST] integration-test enabled!") | ||||||
|  |  | ||||||
|  | -- those mods have to be present | ||||||
|  | local assert_mods = { | ||||||
|  | 	"scifi_nodes" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | -- those nodes have to be present | ||||||
|  | local assert_nodes = { | ||||||
|  | 	"scifi_nodes:crate", | ||||||
|  | 	"scifi_nodes:door1a" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | minetest.register_on_mods_loaded(function() | ||||||
|  | 	minetest.after(0, function() | ||||||
|  | 		-- check mods | ||||||
|  | 		for _, modname in ipairs(assert_mods) do | ||||||
|  | 			if not minetest.get_modpath(modname) then | ||||||
|  | 				error("Mod not present: " .. modname) | ||||||
|  | 			end | ||||||
|  | 		end | ||||||
|  |  | ||||||
|  | 		-- check nodes | ||||||
|  | 		for _, nodename in ipairs(assert_nodes) do | ||||||
|  | 			if not minetest.registered_nodes[nodename] then | ||||||
|  | 				error("Node not present: " .. nodename) | ||||||
|  | 			end | ||||||
|  | 		end | ||||||
|  |  | ||||||
|  | 		local data = minetest.write_json({ success = true }, true); | ||||||
|  | 		local file = io.open(minetest.get_worldpath().."/integration_test.json", "w" ); | ||||||
|  | 		if file then | ||||||
|  | 			file:write(data) | ||||||
|  | 			file:close() | ||||||
|  | 		end | ||||||
|  | 		minetest.request_shutdown("success") | ||||||
|  |  | ||||||
|  | 	end) | ||||||
|  | end) | ||||||
							
								
								
									
										2
									
								
								test/test_mod/mod.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,2 @@ | |||||||
|  | name = scifi_nodes_test | ||||||
|  | depends = scifi_nodes | ||||||
| Before Width: | Height: | Size: 373 B After Width: | Height: | Size: 254 B | 
| Before Width: | Height: | Size: 155 B After Width: | Height: | Size: 133 B | 
| Before Width: | Height: | Size: 323 B After Width: | Height: | Size: 270 B | 
| Before Width: | Height: | Size: 86 B After Width: | Height: | Size: 83 B | 
| Before Width: | Height: | Size: 205 B After Width: | Height: | Size: 146 B | 
| Before Width: | Height: | Size: 836 B After Width: | Height: | Size: 461 B | 
| Before Width: | Height: | Size: 200 B After Width: | Height: | Size: 159 B | 
| Before Width: | Height: | Size: 373 B After Width: | Height: | Size: 218 B | 
| Before Width: | Height: | Size: 170 B After Width: | Height: | Size: 146 B | 
| Before Width: | Height: | Size: 420 B After Width: | Height: | Size: 276 B | 
| Before Width: | Height: | Size: 491 B After Width: | Height: | Size: 261 B | 
| Before Width: | Height: | Size: 575 B After Width: | Height: | Size: 435 B | 
| Before Width: | Height: | Size: 320 B After Width: | Height: | Size: 165 B | 
| Before Width: | Height: | Size: 108 B After Width: | Height: | Size: 100 B | 
| Before Width: | Height: | Size: 157 B After Width: | Height: | Size: 135 B | 
| Before Width: | Height: | Size: 257 B After Width: | Height: | Size: 186 B | 
| Before Width: | Height: | Size: 132 B After Width: | Height: | Size: 109 B | 
| Before Width: | Height: | Size: 131 B After Width: | Height: | Size: 111 B | 
| Before Width: | Height: | Size: 145 B After Width: | Height: | Size: 124 B | 
| Before Width: | Height: | Size: 483 B After Width: | Height: | Size: 243 B | 
| Before Width: | Height: | Size: 791 B After Width: | Height: | Size: 724 B | 
| Before Width: | Height: | Size: 605 B After Width: | Height: | Size: 537 B | 
| Before Width: | Height: | Size: 168 B After Width: | Height: | Size: 147 B | 
| Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 153 B | 
| Before Width: | Height: | Size: 268 B After Width: | Height: | Size: 230 B | 
| Before Width: | Height: | Size: 265 B After Width: | Height: | Size: 208 B | 
| Before Width: | Height: | Size: 310 B After Width: | Height: | Size: 228 B | 
| Before Width: | Height: | Size: 107 B After Width: | Height: | Size: 104 B | 
| Before Width: | Height: | Size: 154 B After Width: | Height: | Size: 137 B | 
| Before Width: | Height: | Size: 222 B After Width: | Height: | Size: 184 B | 
| Before Width: | Height: | Size: 364 B After Width: | Height: | Size: 238 B | 
| Before Width: | Height: | Size: 240 B After Width: | Height: | Size: 179 B | 
| Before Width: | Height: | Size: 574 B After Width: | Height: | Size: 268 B | 
| Before Width: | Height: | Size: 567 B After Width: | Height: | Size: 230 B | 
| Before Width: | Height: | Size: 608 B After Width: | Height: | Size: 304 B | 
| Before Width: | Height: | Size: 243 B After Width: | Height: | Size: 205 B | 
| Before Width: | Height: | Size: 219 B After Width: | Height: | Size: 184 B | 
| Before Width: | Height: | Size: 222 B After Width: | Height: | Size: 184 B | 
| Before Width: | Height: | Size: 214 B After Width: | Height: | Size: 167 B | 
| Before Width: | Height: | Size: 225 B After Width: | Height: | Size: 170 B | 
| Before Width: | Height: | Size: 289 B After Width: | Height: | Size: 166 B | 
| Before Width: | Height: | Size: 450 B After Width: | Height: | Size: 360 B | 
| Before Width: | Height: | Size: 457 B After Width: | Height: | Size: 360 B | 
| Before Width: | Height: | Size: 469 B After Width: | Height: | Size: 285 B | 
| Before Width: | Height: | Size: 437 B After Width: | Height: | Size: 342 B | 
| Before Width: | Height: | Size: 603 B After Width: | Height: | Size: 325 B | 
| Before Width: | Height: | Size: 177 B After Width: | Height: | Size: 129 B | 
| Before Width: | Height: | Size: 733 B After Width: | Height: | Size: 560 B | 
| Before Width: | Height: | Size: 419 B After Width: | Height: | Size: 237 B | 
| Before Width: | Height: | Size: 431 B After Width: | Height: | Size: 248 B | 
| Before Width: | Height: | Size: 347 B After Width: | Height: | Size: 215 B | 
| Before Width: | Height: | Size: 716 B After Width: | Height: | Size: 636 B | 
| Before Width: | Height: | Size: 791 B After Width: | Height: | Size: 713 B | 
| Before Width: | Height: | Size: 730 B After Width: | Height: | Size: 564 B | 
| Before Width: | Height: | Size: 768 B After Width: | Height: | Size: 674 B | 
| Before Width: | Height: | Size: 787 B After Width: | Height: | Size: 674 B | 
| Before Width: | Height: | Size: 731 B After Width: | Height: | Size: 664 B | 
| Before Width: | Height: | Size: 754 B After Width: | Height: | Size: 511 B | 
| Before Width: | Height: | Size: 314 B After Width: | Height: | Size: 248 B | 
| Before Width: | Height: | Size: 91 B After Width: | Height: | Size: 67 B | 
| Before Width: | Height: | Size: 502 B After Width: | Height: | Size: 368 B | 
| Before Width: | Height: | Size: 780 B After Width: | Height: | Size: 517 B | 
| Before Width: | Height: | Size: 308 B After Width: | Height: | Size: 156 B | 
| Before Width: | Height: | Size: 637 B After Width: | Height: | Size: 460 B | 
| Before Width: | Height: | Size: 270 B After Width: | Height: | Size: 156 B | 
| Before Width: | Height: | Size: 691 B After Width: | Height: | Size: 521 B | 
| Before Width: | Height: | Size: 275 B After Width: | Height: | Size: 252 B | 
| Before Width: | Height: | Size: 324 B After Width: | Height: | Size: 204 B | 
| Before Width: | Height: | Size: 188 B After Width: | Height: | Size: 126 B | 
| Before Width: | Height: | Size: 70 B After Width: | Height: | Size: 67 B | 
| Before Width: | Height: | Size: 347 B After Width: | Height: | Size: 262 B | 
| Before Width: | Height: | Size: 351 B After Width: | Height: | Size: 203 B | 
| Before Width: | Height: | Size: 212 B After Width: | Height: | Size: 126 B | 
| Before Width: | Height: | Size: 401 B After Width: | Height: | Size: 223 B | 
| Before Width: | Height: | Size: 269 B After Width: | Height: | Size: 149 B | 
| Before Width: | Height: | Size: 385 B After Width: | Height: | Size: 222 B | 
| Before Width: | Height: | Size: 250 B After Width: | Height: | Size: 149 B | 
| Before Width: | Height: | Size: 238 B After Width: | Height: | Size: 134 B |