mirror of
				https://github.com/mt-mods/homedecor_modpack.git
				synced 2025-11-04 13:05:31 +01:00 
			
		
		
		
	Compare commits
	
		
			24 Commits
		
	
	
		
			2019-06-07
			...
			2019-09-22
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					c118b43711 | ||
| 
						 | 
					f6da0f7329 | ||
| 
						 | 
					e84a184946 | ||
| 
						 | 
					0c9d883f28 | ||
| 
						 | 
					97e7a31830 | ||
| 
						 | 
					d897e6d97c | ||
| 
						 | 
					8532dee8ed | ||
| 
						 | 
					356f872327 | ||
| 
						 | 
					6c07a31857 | ||
| 
						 | 
					daef49a255 | ||
| 
						 | 
					1072598701 | ||
| 
						 | 
					60be4a6320 | ||
| 
						 | 
					67f2065408 | ||
| 
						 | 
					f90834ff06 | ||
| 
						 | 
					c871e0d388 | ||
| 
						 | 
					d17ec1d978 | ||
| 
						 | 
					9dcc6c2b4d | ||
| 
						 | 
					80352d69e1 | ||
| 
						 | 
					1d59c2258d | ||
| 
						 | 
					11e6b5d92a | ||
| 
						 | 
					7e7b2bcabb | ||
| 
						 | 
					b28f1314da | ||
| 
						 | 
					17ea2040e2 | ||
| 
						 | 
					ed9fb6a34d | 
@@ -258,33 +258,6 @@ minetest.register_node("computer:tower", {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
minetest.register_alias("computer:tower_on", "computer:tower")
 | 
					minetest.register_alias("computer:tower_on", "computer:tower")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- Printer/scaner combo
 | 
					 | 
				
			||||||
minetest.register_node("computer:printer", {
 | 
					 | 
				
			||||||
	description = S("Printer-Scanner Combo"),
 | 
					 | 
				
			||||||
	inventory_image = "computer_printer_inv.png",
 | 
					 | 
				
			||||||
	tiles = {"computer_printer_t.png","computer_printer_bt.png","computer_printer_l.png",
 | 
					 | 
				
			||||||
			"computer_printer_r.png","computer_printer_b.png","computer_printer_f.png"},
 | 
					 | 
				
			||||||
	paramtype = "light",
 | 
					 | 
				
			||||||
	paramtype2 = "facedir",
 | 
					 | 
				
			||||||
	walkable = true,
 | 
					 | 
				
			||||||
	groups = {snappy=3},
 | 
					 | 
				
			||||||
	sound = default.node_sound_wood_defaults(),
 | 
					 | 
				
			||||||
	drawtype = "nodebox",
 | 
					 | 
				
			||||||
	node_box = {
 | 
					 | 
				
			||||||
		type = "fixed",
 | 
					 | 
				
			||||||
		fixed = {
 | 
					 | 
				
			||||||
			{-0.4375, -0.3125, -0.125, 0.4375, -0.0625, 0.375},
 | 
					 | 
				
			||||||
			{-0.4375, -0.5, -0.125, 0.4375, -0.4375, 0.375},
 | 
					 | 
				
			||||||
			{-0.4375, -0.5, -0.125, -0.25, -0.0625, 0.375},
 | 
					 | 
				
			||||||
			{0.25, -0.5, -0.125, 0.4375, -0.0625, 0.375},
 | 
					 | 
				
			||||||
			{-0.4375, -0.5, -0.0625, 0.4375, -0.0625, 0.375},
 | 
					 | 
				
			||||||
			{-0.375, -0.4375, 0.25, 0.375, -0.0625, 0.4375},
 | 
					 | 
				
			||||||
			{-0.25, -0.25, 0.4375, 0.25, 0.0625, 0.5},
 | 
					 | 
				
			||||||
			{-0.25, -0.481132, -0.3125, 0.25, -0.4375, 0}
 | 
					 | 
				
			||||||
		},
 | 
					 | 
				
			||||||
	},
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
--Rack Server
 | 
					--Rack Server
 | 
				
			||||||
minetest.register_node("computer:server", {
 | 
					minetest.register_node("computer:server", {
 | 
				
			||||||
	drawtype = "nodebox",
 | 
						drawtype = "nodebox",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
default
 | 
					default
 | 
				
			||||||
homedecor_common
 | 
					homedecor_common
 | 
				
			||||||
 | 
					basic_materials
 | 
				
			||||||
 | 
					unifieddyes
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -94,6 +94,6 @@ end
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
local MODPATH = minetest.get_modpath("computer")
 | 
					local MODPATH = minetest.get_modpath("computer")
 | 
				
			||||||
dofile(MODPATH.."/computers.lua")
 | 
					dofile(MODPATH.."/computers.lua")
 | 
				
			||||||
dofile(MODPATH.."/miscitems.lua")
 | 
					dofile(MODPATH.."/printers.lua")
 | 
				
			||||||
dofile(MODPATH.."/recipes.lua")
 | 
					dofile(MODPATH.."/recipes.lua")
 | 
				
			||||||
dofile(MODPATH.."/tetris.lua")
 | 
					dofile(MODPATH.."/tetris.lua")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,68 +0,0 @@
 | 
				
			|||||||
-- Copyright (C) 2012-2013 Diego Martínez <kaeza@users.sf.net>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- This file defines some items in order to not have to depend on other mods.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
local S = homedecor.gettext
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if (not minetest.get_modpath("homedecor")) then
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craftitem(":basic_materials:plastic_sheet", {
 | 
					 | 
				
			||||||
		description = S("Plastic sheet"),
 | 
					 | 
				
			||||||
		inventory_image = "homedecor_plastic_sheeting.png",
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craftitem(":homedecor:plastic_base", {
 | 
					 | 
				
			||||||
		description = S("Unprocessed Plastic base"),
 | 
					 | 
				
			||||||
		wield_image = "homedecor_plastic_base.png",
 | 
					 | 
				
			||||||
		inventory_image = "homedecor_plastic_base_inv.png",
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craft({
 | 
					 | 
				
			||||||
		type = "shapeless",
 | 
					 | 
				
			||||||
		output = 'homedecor:plastic_base 6',
 | 
					 | 
				
			||||||
		recipe = { "default:junglegrass",
 | 
					 | 
				
			||||||
		   "default:junglegrass",
 | 
					 | 
				
			||||||
		   "default:junglegrass"
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craft({
 | 
					 | 
				
			||||||
		type = "shapeless",
 | 
					 | 
				
			||||||
		output = 'homedecor:plastic_base 3',
 | 
					 | 
				
			||||||
		recipe = { "default:dry_shrub",
 | 
					 | 
				
			||||||
		   "default:dry_shrub",
 | 
					 | 
				
			||||||
		   "default:dry_shrub"
 | 
					 | 
				
			||||||
		},
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craft({
 | 
					 | 
				
			||||||
		type = "shapeless",
 | 
					 | 
				
			||||||
		output = 'homedecor:plastic_base 4',
 | 
					 | 
				
			||||||
		recipe = { "default:leaves",
 | 
					 | 
				
			||||||
			   "default:leaves",
 | 
					 | 
				
			||||||
			   "default:leaves",
 | 
					 | 
				
			||||||
			   "default:leaves",
 | 
					 | 
				
			||||||
			   "default:leaves",
 | 
					 | 
				
			||||||
			   "default:leaves"
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craft({
 | 
					 | 
				
			||||||
		type = "cooking",
 | 
					 | 
				
			||||||
		output = "basic_materials:plastic_sheet",
 | 
					 | 
				
			||||||
		recipe = "homedecor:plastic_base",
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craft({
 | 
					 | 
				
			||||||
		type = 'fuel',
 | 
					 | 
				
			||||||
		recipe = 'homedecor:plastic_base',
 | 
					 | 
				
			||||||
		burntime = 30,
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	minetest.register_craft({
 | 
					 | 
				
			||||||
		type = 'fuel',
 | 
					 | 
				
			||||||
		recipe = 'basic_materials:plastic_sheet',
 | 
					 | 
				
			||||||
		burntime = 30,
 | 
					 | 
				
			||||||
	})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
end -- not homedecor
 | 
					 | 
				
			||||||
							
								
								
									
										9835
									
								
								computer/models/computer_3dprinter_bedflinger.obj
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9835
									
								
								computer/models/computer_3dprinter_bedflinger.obj
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										61
									
								
								computer/printers.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								computer/printers.lua
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,61 @@
 | 
				
			|||||||
 | 
					-- Printers of some kind or another
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					local S = homedecor.gettext
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					minetest.register_node("computer:printer", {
 | 
				
			||||||
 | 
						description = S("Printer-Scanner Combo"),
 | 
				
			||||||
 | 
						inventory_image = "computer_printer_inv.png",
 | 
				
			||||||
 | 
						tiles = {"computer_printer_t.png","computer_printer_bt.png","computer_printer_l.png",
 | 
				
			||||||
 | 
								"computer_printer_r.png","computer_printer_b.png","computer_printer_f.png"},
 | 
				
			||||||
 | 
						paramtype = "light",
 | 
				
			||||||
 | 
						paramtype2 = "facedir",
 | 
				
			||||||
 | 
						walkable = true,
 | 
				
			||||||
 | 
						groups = {snappy=3},
 | 
				
			||||||
 | 
						sound = default.node_sound_wood_defaults(),
 | 
				
			||||||
 | 
						drawtype = "nodebox",
 | 
				
			||||||
 | 
						node_box = {
 | 
				
			||||||
 | 
							type = "fixed",
 | 
				
			||||||
 | 
							fixed = {
 | 
				
			||||||
 | 
								{-0.4375, -0.3125, -0.125, 0.4375, -0.0625, 0.375},
 | 
				
			||||||
 | 
								{-0.4375, -0.5, -0.125, 0.4375, -0.4375, 0.375},
 | 
				
			||||||
 | 
								{-0.4375, -0.5, -0.125, -0.25, -0.0625, 0.375},
 | 
				
			||||||
 | 
								{0.25, -0.5, -0.125, 0.4375, -0.0625, 0.375},
 | 
				
			||||||
 | 
								{-0.4375, -0.5, -0.0625, 0.4375, -0.0625, 0.375},
 | 
				
			||||||
 | 
								{-0.375, -0.4375, 0.25, 0.375, -0.0625, 0.4375},
 | 
				
			||||||
 | 
								{-0.25, -0.25, 0.4375, 0.25, 0.0625, 0.5},
 | 
				
			||||||
 | 
								{-0.25, -0.481132, -0.3125, 0.25, -0.4375, 0}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- "bedflinger" style 3D Printer (Prusa i3 or equivalent)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					local cbox = {
 | 
				
			||||||
 | 
						type = "fixed",
 | 
				
			||||||
 | 
						fixed = {-0.25, -0.25, -0.5, 0.3, 0.3, 0.25 }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					minetest.register_node("computer:3dprinter_bedflinger", {
 | 
				
			||||||
 | 
						description = S('3D Printer ("bedflinger")'),
 | 
				
			||||||
 | 
						inventory_image = "computer_3dprinter_bedflinger_inv.png",
 | 
				
			||||||
 | 
						tiles = {
 | 
				
			||||||
 | 
							{ name = "computer_3dprinter_bedflinger.png", color = 0xffffffff },
 | 
				
			||||||
 | 
							"computer_3dprinter_filament.png"
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						paramtype = "light",
 | 
				
			||||||
 | 
						walkable = true,
 | 
				
			||||||
 | 
						groups = {snappy=3, ud_param2_colorable = 1},
 | 
				
			||||||
 | 
						sound = default.node_sound_wood_defaults(),
 | 
				
			||||||
 | 
						drawtype = "mesh",
 | 
				
			||||||
 | 
						mesh = "computer_3dprinter_bedflinger.obj",
 | 
				
			||||||
 | 
						paramtype2 = "colorwallmounted",
 | 
				
			||||||
 | 
						palette = "unifieddyes_palette_colorwallmounted.png",
 | 
				
			||||||
 | 
						selection_box = cbox,
 | 
				
			||||||
 | 
						collision_box = cbox,
 | 
				
			||||||
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
 | 
							unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
 | 
						on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										
											BIN
										
									
								
								computer/textures/computer_3dprinter_bedflinger.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								computer/textures/computer_3dprinter_bedflinger.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 3.5 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								computer/textures/computer_3dprinter_bedflinger_inv.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								computer/textures/computer_3dprinter_bedflinger_inv.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 3.8 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								computer/textures/computer_3dprinter_filament.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								computer/textures/computer_3dprinter_filament.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 216 B  | 
@@ -89,28 +89,19 @@ end
 | 
				
			|||||||
-- 3d-ify default mtg wood and steel doors and trap doors
 | 
					-- 3d-ify default mtg wood and steel doors and trap doors
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if minetest.get_modpath("doors") then
 | 
					if minetest.get_modpath("doors") then
 | 
				
			||||||
	local function clone_node(name)
 | 
					 | 
				
			||||||
		local node2 = {}
 | 
					 | 
				
			||||||
		local node = minetest.registered_nodes[name]
 | 
					 | 
				
			||||||
		for k,v in pairs(node) do
 | 
					 | 
				
			||||||
			node2[k]=v
 | 
					 | 
				
			||||||
		end
 | 
					 | 
				
			||||||
		return node2
 | 
					 | 
				
			||||||
	end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	local def
 | 
						local def
 | 
				
			||||||
	for _,mat in ipairs({"wood", "steel"}) do
 | 
						for _,mat in ipairs({"wood", "steel"}) do
 | 
				
			||||||
		def = clone_node("doors:door_"..mat.."_a")
 | 
							def = table.copy(minetest.registered_nodes["doors:door_"..mat.."_a"])
 | 
				
			||||||
			def.mesh = "homedecor_3d_door_"..mat.."_a.obj"
 | 
								def.mesh = "homedecor_3d_door_"..mat.."_a.obj"
 | 
				
			||||||
			minetest.register_node(":doors:door_"..mat.."_a", def)
 | 
								minetest.register_node(":doors:door_"..mat.."_a", def)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		def = clone_node("doors:door_"..mat.."_b")
 | 
							def = table.copy(minetest.registered_nodes["doors:door_"..mat.."_b"])
 | 
				
			||||||
			def.mesh = "homedecor_3d_door_"..mat.."_b.obj"
 | 
								def.mesh = "homedecor_3d_door_"..mat.."_b.obj"
 | 
				
			||||||
			minetest.register_node(":doors:door_"..mat.."_b", def)
 | 
								minetest.register_node(":doors:door_"..mat.."_b", def)
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for _,mat in ipairs({"", "_steel"}) do
 | 
						for _,mat in ipairs({"", "_steel"}) do
 | 
				
			||||||
		def = clone_node("doors:trapdoor"..mat)
 | 
							def = table.copy(minetest.registered_nodes["doors:trapdoor"..mat])
 | 
				
			||||||
			def.drawtype = "mesh"
 | 
								def.drawtype = "mesh"
 | 
				
			||||||
			def.mesh = "homedecor_3d_trapdoor"..mat..".obj"
 | 
								def.mesh = "homedecor_3d_trapdoor"..mat..".obj"
 | 
				
			||||||
			def.tiles = {
 | 
								def.tiles = {
 | 
				
			||||||
@@ -119,7 +110,7 @@ if minetest.get_modpath("doors") then
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
			minetest.register_node(":doors:trapdoor"..mat, def)
 | 
								minetest.register_node(":doors:trapdoor"..mat, def)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		def = clone_node("doors:trapdoor"..mat.."_open")
 | 
							def = table.copy(minetest.registered_nodes["doors:trapdoor"..mat.."_open"])
 | 
				
			||||||
			def.mesh = "homedecor_3d_trapdoor"..mat.."_open.obj"
 | 
								def.mesh = "homedecor_3d_trapdoor"..mat.."_open.obj"
 | 
				
			||||||
			def.drawtype = "mesh"
 | 
								def.drawtype = "mesh"
 | 
				
			||||||
			def.tiles = {
 | 
								def.tiles = {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -15,6 +15,7 @@ minetest.register_node(":homedecor:bathroom_tiles_dark", {
 | 
				
			|||||||
	groups = {cracky=3, ud_param2_colorable = 1},
 | 
						groups = {cracky=3, ud_param2_colorable = 1},
 | 
				
			||||||
	sounds = default.node_sound_stone_defaults(),
 | 
						sounds = default.node_sound_stone_defaults(),
 | 
				
			||||||
	on_construct = unifieddyes.on_construct,
 | 
						on_construct = unifieddyes.on_construct,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_node(":homedecor:bathroom_tiles_medium", {
 | 
					minetest.register_node(":homedecor:bathroom_tiles_medium", {
 | 
				
			||||||
@@ -31,6 +32,7 @@ minetest.register_node(":homedecor:bathroom_tiles_medium", {
 | 
				
			|||||||
	groups = {cracky=3, ud_param2_colorable = 1},
 | 
						groups = {cracky=3, ud_param2_colorable = 1},
 | 
				
			||||||
	sounds = default.node_sound_stone_defaults(),
 | 
						sounds = default.node_sound_stone_defaults(),
 | 
				
			||||||
	on_construct = unifieddyes.on_construct,
 | 
						on_construct = unifieddyes.on_construct,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_node(":homedecor:bathroom_tiles_light", {
 | 
					minetest.register_node(":homedecor:bathroom_tiles_light", {
 | 
				
			||||||
@@ -47,6 +49,7 @@ minetest.register_node(":homedecor:bathroom_tiles_light", {
 | 
				
			|||||||
	groups = {cracky=3, ud_param2_colorable = 1},
 | 
						groups = {cracky=3, ud_param2_colorable = 1},
 | 
				
			||||||
	sounds = default.node_sound_stone_defaults(),
 | 
						sounds = default.node_sound_stone_defaults(),
 | 
				
			||||||
	on_construct = unifieddyes.on_construct,
 | 
						on_construct = unifieddyes.on_construct,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local tr_cbox = {
 | 
					local tr_cbox = {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -59,6 +59,7 @@ homedecor.register("bed_regular", {
 | 
				
			|||||||
	after_dig_node = function(pos, oldnode, oldmetadata, digger)
 | 
						after_dig_node = function(pos, oldnode, oldmetadata, digger)
 | 
				
			||||||
		homedecor.unextend_bed(pos)
 | 
							homedecor.unextend_bed(pos)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		local itemname = itemstack:get_name()
 | 
							local itemname = itemstack:get_name()
 | 
				
			||||||
		if itemname == "homedecor:bed_regular" then
 | 
							if itemname == "homedecor:bed_regular" then
 | 
				
			||||||
@@ -92,6 +93,7 @@ homedecor.register("bed_extended", {
 | 
				
			|||||||
	after_dig_node = function(pos, oldnode, oldmetadata, digger)
 | 
						after_dig_node = function(pos, oldnode, oldmetadata, digger)
 | 
				
			||||||
		homedecor.unextend_bed(pos)
 | 
							homedecor.unextend_bed(pos)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
--	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
					--	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
--		homedecor.beds_on_rightclick(pos, node, clicker)
 | 
					--		homedecor.beds_on_rightclick(pos, node, clicker)
 | 
				
			||||||
--		return itemstack
 | 
					--		return itemstack
 | 
				
			||||||
@@ -128,6 +130,7 @@ homedecor.register("bed_kingsize", {
 | 
				
			|||||||
			inv:add_item("main", "homedecor:bed_regular 2")
 | 
								inv:add_item("main", "homedecor:bed_regular 2")
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
--	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
					--	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
--		homedecor.beds_on_rightclick(pos, node, clicker)
 | 
					--		homedecor.beds_on_rightclick(pos, node, clicker)
 | 
				
			||||||
--		return itemstack
 | 
					--		return itemstack
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -25,7 +25,7 @@ minetest.register_node(":homedecor:cobweb_corner", {
 | 
				
			|||||||
	end
 | 
						end
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_node(":Lhomedecor:cobweb_centered", {
 | 
					minetest.register_node(":homedecor:cobweb_centered", {
 | 
				
			||||||
	description = S("Cobweb"),
 | 
						description = S("Cobweb"),
 | 
				
			||||||
	drawtype = "nodebox",
 | 
						drawtype = "nodebox",
 | 
				
			||||||
	tiles = { "homedecor_cobweb.png" },
 | 
						tiles = { "homedecor_cobweb.png" },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -80,7 +80,7 @@ local furnace_can_dig = function(pos,player)
 | 
				
			|||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function homedecor.register_furnace(name, furnacedef)
 | 
					function homedecor.register_furnace(name, furnacedef)
 | 
				
			||||||
	furnacedef.fire_fg = furnacedef.fire_bg or "default_furnace_fire_fg.png"
 | 
						furnacedef.fire_fg = furnacedef.fire_fg or "default_furnace_fire_fg.png"
 | 
				
			||||||
	furnacedef.fire_bg = furnacedef.fire_bg or "default_furnace_fire_bg.png"
 | 
						furnacedef.fire_bg = furnacedef.fire_bg or "default_furnace_fire_bg.png"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	furnacedef.output_slots = furnacedef.output_slots or 4
 | 
						furnacedef.output_slots = furnacedef.output_slots or 4
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,17 +3,6 @@
 | 
				
			|||||||
local S = homedecor.gettext
 | 
					local S = homedecor.gettext
 | 
				
			||||||
local mesecons_mp = minetest.get_modpath("mesecons")
 | 
					local mesecons_mp = minetest.get_modpath("mesecons")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- clone node
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
function hd_doors_clone_node(name)
 | 
					 | 
				
			||||||
	local node2 = {}
 | 
					 | 
				
			||||||
	local node = minetest.registered_nodes[name]
 | 
					 | 
				
			||||||
	for k,v in pairs(node) do
 | 
					 | 
				
			||||||
		node2[k]=v
 | 
					 | 
				
			||||||
	end
 | 
					 | 
				
			||||||
	return node2
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- new doors using minetest_game doors API
 | 
					-- new doors using minetest_game doors API
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local door_list = {
 | 
					local door_list = {
 | 
				
			||||||
@@ -181,22 +170,22 @@ for _, door in ipairs(door_list) do
 | 
				
			|||||||
	local nn_b = "doors:homedecor_"..door.name.."_b"
 | 
						local nn_b = "doors:homedecor_"..door.name.."_b"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if door.alpha then
 | 
						if door.alpha then
 | 
				
			||||||
		local def = hd_doors_clone_node(nn_a)
 | 
							local def = table.copy(minetest.registered_nodes[nn_a])
 | 
				
			||||||
			def.use_texture_alpha = true
 | 
								def.use_texture_alpha = true
 | 
				
			||||||
			def.mesh = "door_a.obj"                -- leaving this out will break the _a model
 | 
								def.mesh = "door_a.obj"                -- leaving this out will break the _a model
 | 
				
			||||||
			minetest.register_node(":"..nn_a, def) -- assignment when the override takes place
 | 
								minetest.register_node(":"..nn_a, def) -- assignment when the override takes place
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		def = hd_doors_clone_node(nn_b)
 | 
							def = table.copy(minetest.registered_nodes[nn_b])
 | 
				
			||||||
			def.use_texture_alpha = true
 | 
								def.use_texture_alpha = true
 | 
				
			||||||
			minetest.register_node(":"..nn_b, def)
 | 
								minetest.register_node(":"..nn_b, def)
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if door.custom_model and hd_3d then
 | 
						if door.custom_model and hd_3d then
 | 
				
			||||||
		def = hd_doors_clone_node(nn_a)
 | 
							def = table.copy(minetest.registered_nodes[nn_a])
 | 
				
			||||||
			def.mesh = door.custom_model.."_a.obj"
 | 
								def.mesh = door.custom_model.."_a.obj"
 | 
				
			||||||
			minetest.register_node(":"..nn_a, def)
 | 
								minetest.register_node(":"..nn_a, def)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		def = hd_doors_clone_node(nn_b)
 | 
							def = table.copy(minetest.registered_nodes[nn_b])
 | 
				
			||||||
			def.mesh = door.custom_model.."_b.obj"
 | 
								def.mesh = door.custom_model.."_b.obj"
 | 
				
			||||||
			minetest.register_node(":"..nn_b, def)
 | 
								minetest.register_node(":"..nn_b, def)
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
@@ -468,8 +457,8 @@ minetest.register_craft( {
 | 
				
			|||||||
	type = "shapeless",
 | 
						type = "shapeless",
 | 
				
			||||||
	output = "homedecor:gate_half_door_closed 4",
 | 
						output = "homedecor:gate_half_door_closed 4",
 | 
				
			||||||
	recipe = {
 | 
						recipe = {
 | 
				
			||||||
		"homedecor:door_wood_plain_a",
 | 
							"doors:homedecor_wood_plain_a",
 | 
				
			||||||
		"homedecor:door_wood_plain_a"
 | 
							"doors:homedecor_wood_plain_a"
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -477,8 +466,8 @@ minetest.register_craft( {
 | 
				
			|||||||
	type = "shapeless",
 | 
						type = "shapeless",
 | 
				
			||||||
	output = "homedecor:gate_half_door_white_closed 4",
 | 
						output = "homedecor:gate_half_door_white_closed 4",
 | 
				
			||||||
	recipe = {
 | 
						recipe = {
 | 
				
			||||||
		"homedecor:door_bedroom_a",
 | 
							"doors:homedecor_bedroom_a",
 | 
				
			||||||
		"homedecor:door_bedroom_a"
 | 
							"doors:homedecor_bedroom_a"
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -553,7 +542,7 @@ minetest.register_craft( {
 | 
				
			|||||||
-- plain wood, non-windowed
 | 
					-- plain wood, non-windowed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
        output = "homedecor:door_wood_plain_a 2",
 | 
					        output = "doors:homedecor_wood_plain 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			{ "group:wood", "group:wood", "" },
 | 
								{ "group:wood", "group:wood", "" },
 | 
				
			||||||
			{ "group:wood", "group:wood", "default:steel_ingot" },
 | 
								{ "group:wood", "group:wood", "default:steel_ingot" },
 | 
				
			||||||
@@ -564,7 +553,7 @@ minetest.register_craft( {
 | 
				
			|||||||
-- fancy exterior
 | 
					-- fancy exterior
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
        output = "homedecor:door_exterior_fancy_a 2",
 | 
					        output = "doors:homedecor_exterior_fancy 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			{ "group:wood", "default:glass" },
 | 
								{ "group:wood", "default:glass" },
 | 
				
			||||||
			{ "group:wood", "group:wood" },
 | 
								{ "group:wood", "group:wood" },
 | 
				
			||||||
@@ -572,12 +561,10 @@ minetest.register_craft( {
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- wood and glass (grid style)
 | 
					-- French style wood/glass
 | 
				
			||||||
 | 
					 | 
				
			||||||
-- bare
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
        output = "homedecor:door_wood_glass_oak_a 2",
 | 
					        output = "doors:homedecor_french_oak 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			{ "default:glass", "group:wood" },
 | 
								{ "default:glass", "group:wood" },
 | 
				
			||||||
			{ "group:wood", "default:glass" },
 | 
								{ "group:wood", "default:glass" },
 | 
				
			||||||
@@ -586,7 +573,7 @@ minetest.register_craft( {
 | 
				
			|||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
        output = "homedecor:door_wood_glass_oak_a 2",
 | 
					        output = "doors:homedecor_french_oak 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			{ "group:wood", "default:glass" },
 | 
								{ "group:wood", "default:glass" },
 | 
				
			||||||
			{ "default:glass", "group:wood" },
 | 
								{ "default:glass", "group:wood" },
 | 
				
			||||||
@@ -594,27 +581,23 @@ minetest.register_craft( {
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- mahogany
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	type = "shapeless",
 | 
						type = "shapeless",
 | 
				
			||||||
        output = "homedecor:door_wood_glass_mahogany_a 2",
 | 
					        output = "doors:homedecor_french_mahogany 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			"dye:brown",
 | 
								"dye:brown",
 | 
				
			||||||
			"homedecor:door_wood_glass_oak_a",
 | 
								"doors:homedecor_french_oak",
 | 
				
			||||||
			"homedecor:door_wood_glass_oak_a"
 | 
								"doors:homedecor_french_oak"
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- white
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	type = "shapeless",
 | 
						type = "shapeless",
 | 
				
			||||||
        output = "homedecor:door_wood_glass_white_a 2",
 | 
					        output = "doors:homedecor_french_white 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			"dye:white",
 | 
								"dye:white",
 | 
				
			||||||
			"homedecor:door_wood_glass_oak_a",
 | 
								"doors:homedecor_french_oak",
 | 
				
			||||||
			"homedecor:door_wood_glass_oak_a"
 | 
								"doors:homedecor_french_oak"
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -623,7 +606,7 @@ minetest.register_craft( {
 | 
				
			|||||||
-- oak
 | 
					-- oak
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
        output = "homedecor:door_closet_oak_a 2",
 | 
					        output = "doors:homedecor_closet_oak 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			{ "", "group:stick", "group:stick" },
 | 
								{ "", "group:stick", "group:stick" },
 | 
				
			||||||
			{ "default:steel_ingot", "group:stick", "group:stick" },
 | 
								{ "default:steel_ingot", "group:stick", "group:stick" },
 | 
				
			||||||
@@ -635,18 +618,18 @@ minetest.register_craft( {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	type = "shapeless",
 | 
						type = "shapeless",
 | 
				
			||||||
        output = "homedecor:door_closet_mahogany_a 2",
 | 
					        output = "doors:homedecor_closet_mahogany 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			"homedecor:door_closet_oak_a",
 | 
								"doors:homedecor_closet_oak_a",
 | 
				
			||||||
			"homedecor:door_closet_oak_a",
 | 
								"doors:homedecor_closet_oak_a",
 | 
				
			||||||
			"dye:brown"
 | 
								"dye:brown"
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- wrought fence-like door
 | 
					-- wrought iron fence-like door
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
        output = "homedecor:door_wrought_iron_a 2",
 | 
					        output = "doors:homedecor_wrought_iron 2",
 | 
				
			||||||
        recipe = {
 | 
					        recipe = {
 | 
				
			||||||
			{ "homedecor:pole_wrought_iron", "default:iron_lump" },
 | 
								{ "homedecor:pole_wrought_iron", "default:iron_lump" },
 | 
				
			||||||
			{ "homedecor:pole_wrought_iron", "default:iron_lump" },
 | 
								{ "homedecor:pole_wrought_iron", "default:iron_lump" },
 | 
				
			||||||
@@ -654,21 +637,21 @@ minetest.register_craft( {
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- bedroom door
 | 
					-- bedroom/panel door
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	output = "homedecor:door_bedroom_a",
 | 
						output = "doors:homedecor_basic_panel",
 | 
				
			||||||
	recipe = {
 | 
						recipe = {
 | 
				
			||||||
		{ "dye:white", "dye:white", "" },
 | 
							{ "dye:white", "dye:white", "" },
 | 
				
			||||||
		{ "homedecor:door_wood_plain_a", "basic_materials:brass_ingot", "" },
 | 
							{ "doors:homedecor_wood_plain_a", "basic_materials:brass_ingot", "" },
 | 
				
			||||||
		{ "", "", "" },
 | 
							{ "", "", "" },
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- woodglass door
 | 
					-- basic wood/glass single-lite door
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	output = "homedecor:door_woodglass_a",
 | 
						output = "doors:homedecor_woodglass",
 | 
				
			||||||
	recipe = {
 | 
						recipe = {
 | 
				
			||||||
		{ "group:wood", "default:glass", "" },
 | 
							{ "group:wood", "default:glass", "" },
 | 
				
			||||||
		{ "group:wood", "default:glass", "basic_materials:brass_ingot" },
 | 
							{ "group:wood", "default:glass", "basic_materials:brass_ingot" },
 | 
				
			||||||
@@ -676,10 +659,10 @@ minetest.register_craft( {
 | 
				
			|||||||
	},
 | 
						},
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- woodglass door type 2
 | 
					-- "Carolina" door
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	output = "homedecor:door_woodglass2_a",
 | 
						output = "doors:homedecor_carolina",
 | 
				
			||||||
	recipe = {
 | 
						recipe = {
 | 
				
			||||||
		{ "default:glass", "default:glass", "" },
 | 
							{ "default:glass", "default:glass", "" },
 | 
				
			||||||
		{ "group:wood", "group:wood", "default:iron_lump" },
 | 
							{ "group:wood", "group:wood", "default:iron_lump" },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,8 +16,6 @@ function homedecor.toggle_switch(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			|||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local on_rc
 | 
					local on_rc
 | 
				
			||||||
local switch_receptor
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if minetest.get_modpath("mesecons") then
 | 
					if minetest.get_modpath("mesecons") then
 | 
				
			||||||
	on_rc = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rc = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		local t = homedecor.toggle_switch(pos, node, clicker, itemstack, pointed_thing)
 | 
							local t = homedecor.toggle_switch(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
@@ -28,12 +26,6 @@ if minetest.get_modpath("mesecons") then
 | 
				
			|||||||
			mesecon.receptor_on(pos, mesecon.rules.buttonlike_get(node))
 | 
								mesecon.receptor_on(pos, mesecon.rules.buttonlike_get(node))
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
	switch_receptor = {
 | 
					 | 
				
			||||||
		receptor = {
 | 
					 | 
				
			||||||
			state = mesecon.state[onoff],
 | 
					 | 
				
			||||||
			rules = mesecon.rules.buttonlike_get
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
homedecor.register("power_outlet", {
 | 
					homedecor.register("power_outlet", {
 | 
				
			||||||
@@ -65,6 +57,16 @@ homedecor.register("power_outlet", {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
for _, onoff in ipairs ({"on", "off"}) do
 | 
					for _, onoff in ipairs ({"on", "off"}) do
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						local switch_receptor
 | 
				
			||||||
 | 
						if minetest.get_modpath("mesecons") then
 | 
				
			||||||
 | 
							switch_receptor = {
 | 
				
			||||||
 | 
								receptor = {
 | 
				
			||||||
 | 
									state = mesecon.state[onoff],
 | 
				
			||||||
 | 
									rules = mesecon.rules.buttonlike_get
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	local model = {
 | 
						local model = {
 | 
				
			||||||
		{ -0.125,   -0.1875, 0.4375,  0.125,   0.125,  0.5 },
 | 
							{ -0.125,   -0.1875, 0.4375,  0.125,   0.125,  0.5 },
 | 
				
			||||||
		{ -0.03125,  0,      0.40625, 0.03125, 0.0625, 0.5 },
 | 
							{ -0.03125,  0,      0.40625, 0.03125, 0.0625, 0.5 },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,19 +1,5 @@
 | 
				
			|||||||
-- This file adds fences of various types
 | 
					-- This file adds fences of various types
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local signs_modpath = minetest.get_modpath("signs_lib")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
local sign_post_model = {
 | 
					 | 
				
			||||||
	type = "fixed",
 | 
					 | 
				
			||||||
	fixed = {
 | 
					 | 
				
			||||||
			{-0.4375, -0.25, -0.1875, 0.4375, 0.375, -0.125},
 | 
					 | 
				
			||||||
			{-0.125, -0.5, -0.125, 0.125, 0.5, 0.125},
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if signs_modpath then
 | 
					 | 
				
			||||||
	sign_post_model = signs_lib.sign_post_model.nodebox
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
local S = homedecor.gettext
 | 
					local S = homedecor.gettext
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local materials = {
 | 
					local materials = {
 | 
				
			||||||
@@ -23,43 +9,17 @@ local materials = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
for _, m in ipairs(materials) do
 | 
					for _, m in ipairs(materials) do
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local desc, name = unpack(m)
 | 
						local desc, name = unpack(m)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
homedecor.register("fence_"..name, {
 | 
						homedecor.register("fence_"..name, {
 | 
				
			||||||
	description = S("Fence/railing (@1)", desc),
 | 
							description = S("Fence/railing (@1)", desc),
 | 
				
			||||||
	drawtype = "fencelike",
 | 
							drawtype = "fencelike",
 | 
				
			||||||
	tiles = {"homedecor_generic_metal_"..name..".png"},
 | 
							tiles = {"homedecor_generic_metal_"..name..".png"},
 | 
				
			||||||
	inventory_image = "homedecor_fence_"..name..".png",
 | 
							inventory_image = "homedecor_fence_"..name..".png",
 | 
				
			||||||
	selection_box = homedecor.nodebox.bar_y(1/7),
 | 
							selection_box = homedecor.nodebox.bar_y(1/7),
 | 
				
			||||||
	groups = {snappy=3},
 | 
							groups = {snappy=3},
 | 
				
			||||||
	sounds = default.node_sound_wood_defaults(),
 | 
							sounds = default.node_sound_wood_defaults(),
 | 
				
			||||||
})
 | 
						})
 | 
				
			||||||
 | 
					 | 
				
			||||||
-- brass/wrought iron with signs:
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
homedecor.register("fence_"..name.."_with_sign", {
 | 
					 | 
				
			||||||
	description = S("Fence/railing with sign (@1)", desc),
 | 
					 | 
				
			||||||
	tiles = {
 | 
					 | 
				
			||||||
		"homedecor_sign_"..name.."_post_top.png",
 | 
					 | 
				
			||||||
		"homedecor_sign_"..name.."_post_bottom.png",
 | 
					 | 
				
			||||||
		"homedecor_sign_"..name.."_post_side.png",
 | 
					 | 
				
			||||||
		"homedecor_sign_"..name.."_post_side.png",
 | 
					 | 
				
			||||||
		"homedecor_sign_"..name.."_post_back.png",
 | 
					 | 
				
			||||||
		"homedecor_sign_"..name.."_post_front.png",
 | 
					 | 
				
			||||||
	},
 | 
					 | 
				
			||||||
	wield_image = "homedecor_sign_"..name.."_post.png",
 | 
					 | 
				
			||||||
	node_box = sign_post_model,
 | 
					 | 
				
			||||||
	groups = {snappy=3,not_in_creative_inventory=1},
 | 
					 | 
				
			||||||
	sounds = default.node_sound_wood_defaults(),
 | 
					 | 
				
			||||||
	sunlight_propagates = true,
 | 
					 | 
				
			||||||
	drop = {
 | 
					 | 
				
			||||||
		max_items = 2,
 | 
					 | 
				
			||||||
		items = {
 | 
					 | 
				
			||||||
			{ items = { "default:sign_wall" }},
 | 
					 | 
				
			||||||
			{ items = { "homedecor:fence_"..name }},
 | 
					 | 
				
			||||||
		},
 | 
					 | 
				
			||||||
	},
 | 
					 | 
				
			||||||
})
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -303,9 +263,15 @@ homedecor.register("fence_wrought_iron_2_corner", {
 | 
				
			|||||||
	},
 | 
						},
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if signs_modpath then
 | 
					-- insert the old wood signs-on-metal-fences into signs_lib's conversion LBM
 | 
				
			||||||
	signs_lib.register_fence_with_sign("homedecor:fence_brass", "homedecor:fence_brass_with_sign")
 | 
					if minetest.get_modpath("signs_lib") then
 | 
				
			||||||
	signs_lib.register_fence_with_sign("homedecor:fence_wrought_iron", "homedecor:fence_wrought_iron_with_sign")
 | 
						table.insert(signs_lib.old_fenceposts_with_signs, "homedecor:fence_brass_with_sign")
 | 
				
			||||||
 | 
						signs_lib.old_fenceposts["homedecor:fence_brass_with_sign"] = "homedecor:fence_brass"
 | 
				
			||||||
 | 
						signs_lib.old_fenceposts_replacement_signs["homedecor:fence_brass_with_sign"] = "default:sign_wall_wood_onpole"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						table.insert(signs_lib.old_fenceposts_with_signs, "homedecor:fence_wrought_iron_with_sign")
 | 
				
			||||||
 | 
						signs_lib.old_fenceposts["homedecor:fence_wrought_iron_with_sign"] = "homedecor:fence_wrought_iron"
 | 
				
			||||||
 | 
						signs_lib.old_fenceposts_replacement_signs["homedecor:fence_wrought_iron_with_sign"] = "default:sign_wall_wood_onpole"
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- crafting
 | 
					-- crafting
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -164,18 +164,7 @@ homedecor.register("beer_mug", {
 | 
				
			|||||||
	on_use = function(itemstack, user, pointed_thing)
 | 
						on_use = function(itemstack, user, pointed_thing)
 | 
				
			||||||
		local inv = user:get_inventory()
 | 
							local inv = user:get_inventory()
 | 
				
			||||||
		if not creative.is_enabled_for(user:get_player_name()) then
 | 
							if not creative.is_enabled_for(user:get_player_name()) then
 | 
				
			||||||
			if inv:room_for_item("main", "vessels:drinking_glass 1") then
 | 
								minetest.do_item_eat(2, "vessels:drinking_glass 1", itemstack, user, pointed_thing)
 | 
				
			||||||
				inv:add_item("main", "vessels:drinking_glass 1")
 | 
					 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
				local pos = user:get_pos()
 | 
					 | 
				
			||||||
				local dir = user:get_look_dir()
 | 
					 | 
				
			||||||
				local fdir = minetest.dir_to_facedir(dir)
 | 
					 | 
				
			||||||
				local pos_fwd = {	x = pos.x + homedecor.fdir_to_fwd[fdir+1][1],
 | 
					 | 
				
			||||||
									y = pos.y + 1,
 | 
					 | 
				
			||||||
									z = pos.z + homedecor.fdir_to_fwd[fdir+1][2] }
 | 
					 | 
				
			||||||
				minetest.add_item(pos_fwd, "vessels:drinking_glass 1")
 | 
					 | 
				
			||||||
			end
 | 
					 | 
				
			||||||
			minetest.do_item_eat(2, nil, itemstack, user, pointed_thing)
 | 
					 | 
				
			||||||
			return itemstack
 | 
								return itemstack
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,6 +11,8 @@ local function is_protected(pos, clicker)
 | 
				
			|||||||
	return false
 | 
						return false
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					local hd_mesecons = minetest.get_modpath("mesecons")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- control and brightness for dimmable lamps
 | 
					-- control and brightness for dimmable lamps
 | 
				
			||||||
 | 
					
 | 
				
			||||||
local brightn_cycle = {
 | 
					local brightn_cycle = {
 | 
				
			||||||
@@ -51,7 +53,7 @@ local rules_alldir = {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
local actions
 | 
					local actions
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if minetest.get_modpath("mesecons") then
 | 
					if hd_mesecons then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	actions = {
 | 
						actions = {
 | 
				
			||||||
		action_off = function(pos, node)
 | 
							action_off = function(pos, node)
 | 
				
			||||||
@@ -96,11 +98,12 @@ local digiline_on_punch
 | 
				
			|||||||
if minetest.get_modpath("digilines") then
 | 
					if minetest.get_modpath("digilines") then
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	local on_digiline_receive_string = function(pos, node, channel, msg)
 | 
						local on_digiline_receive_string = function(pos, node, channel, msg)
 | 
				
			||||||
 | 
							if not msg or not channel then return end
 | 
				
			||||||
		local meta = minetest.get_meta(pos)
 | 
							local meta = minetest.get_meta(pos)
 | 
				
			||||||
		local setchan = meta:get_string("channel")
 | 
							local setchan = meta:get_string("channel")
 | 
				
			||||||
		if setchan ~= channel then return end
 | 
							if setchan ~= channel then return end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if msg and msg ~= "" then
 | 
							if msg ~= "" and (type(msg) == "string" or type(msg) == "number" ) then
 | 
				
			||||||
			local n = tonumber(msg)
 | 
								local n = tonumber(msg)
 | 
				
			||||||
			local suff = word_to_bright[msg] or "invalid"
 | 
								local suff = word_to_bright[msg] or "invalid"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -132,7 +135,7 @@ if minetest.get_modpath("digilines") then
 | 
				
			|||||||
		end
 | 
							end
 | 
				
			||||||
	end)
 | 
						end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if minetest.get_modpath("mesecons") then
 | 
						if hd_mesecons then
 | 
				
			||||||
		homedecor.digiline_wall_light = {
 | 
							homedecor.digiline_wall_light = {
 | 
				
			||||||
			effector = {
 | 
								effector = {
 | 
				
			||||||
				action = on_digiline_receive_string,
 | 
									action = on_digiline_receive_string,
 | 
				
			||||||
@@ -182,10 +185,14 @@ function homedecor.toggle_light(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			|||||||
	local level = string.sub(node.name, sep + 1)
 | 
						local level = string.sub(node.name, sep + 1)
 | 
				
			||||||
	local n = tonumber(level) or 0
 | 
						local n = tonumber(level) or 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if level == "off" or n < 4 then
 | 
						if level == "on" then
 | 
				
			||||||
		newsuff = "_14"
 | 
							newsuff = "_off"
 | 
				
			||||||
	else
 | 
						elseif level == "off" then
 | 
				
			||||||
 | 
							newsuff = "_on"
 | 
				
			||||||
 | 
						elseif n > 3 then
 | 
				
			||||||
		newsuff = "_0"
 | 
							newsuff = "_0"
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							newsuff = "_14"
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	minetest.swap_node(pos, {name = string.sub(node.name, 1, sep - 1)..newsuff, param2 = node.param2})
 | 
						minetest.swap_node(pos, {name = string.sub(node.name, 1, sep - 1)..newsuff, param2 = node.param2})
 | 
				
			||||||
@@ -279,6 +286,7 @@ for brightness_level = 0, 14 do
 | 
				
			|||||||
		after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
							after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
			unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
								unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		end,
 | 
							end,
 | 
				
			||||||
 | 
							on_dig = unifieddyes.on_dig,
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
							on_rightclick = homedecor.toggle_light,
 | 
				
			||||||
		drop = {
 | 
							drop = {
 | 
				
			||||||
			items = {
 | 
								items = {
 | 
				
			||||||
@@ -344,6 +352,7 @@ for brightness_level = 0, 14 do
 | 
				
			|||||||
		after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
							after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
			unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
								unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		end,
 | 
							end,
 | 
				
			||||||
 | 
							on_dig = unifieddyes.on_dig,
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
							on_rightclick = homedecor.toggle_light,
 | 
				
			||||||
		drop = {
 | 
							drop = {
 | 
				
			||||||
			items = {
 | 
								items = {
 | 
				
			||||||
@@ -410,6 +419,7 @@ for brightness_level = 0, 14 do
 | 
				
			|||||||
		after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
							after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
			unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
								unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		end,
 | 
							end,
 | 
				
			||||||
 | 
							on_dig = unifieddyes.on_dig,
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
							on_rightclick = homedecor.toggle_light,
 | 
				
			||||||
		drop = {
 | 
							drop = {
 | 
				
			||||||
			items = {
 | 
								items = {
 | 
				
			||||||
@@ -630,6 +640,7 @@ for brightness_level = 0, 14 do
 | 
				
			|||||||
		after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
							after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
			unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
								unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		end,
 | 
							end,
 | 
				
			||||||
 | 
							on_dig = unifieddyes.on_dig,
 | 
				
			||||||
		on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
							on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
				
			||||||
		light_source = brightness_level,
 | 
							light_source = brightness_level,
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
							on_rightclick = homedecor.toggle_light,
 | 
				
			||||||
@@ -707,7 +718,8 @@ for brightness_level = 0, 14 do
 | 
				
			|||||||
		digiline =      homedecor.digiline_alldir_light,
 | 
							digiline =      homedecor.digiline_alldir_light,
 | 
				
			||||||
		mesecons =      homedecor.mesecon_wall_light,
 | 
							mesecons =      homedecor.mesecon_wall_light,
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
							on_rightclick = homedecor.toggle_light,
 | 
				
			||||||
		on_punch =      digiline_on_punch
 | 
							on_punch =      digiline_on_punch,
 | 
				
			||||||
 | 
							on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	homedecor.register("standing_lamp_"..brightness_level, {
 | 
						homedecor.register("standing_lamp_"..brightness_level, {
 | 
				
			||||||
@@ -738,7 +750,8 @@ for brightness_level = 0, 14 do
 | 
				
			|||||||
		digiline =      homedecor.digiline_alldir_light,
 | 
							digiline =      homedecor.digiline_alldir_light,
 | 
				
			||||||
		mesecons =      homedecor.mesecon_wall_light,
 | 
							mesecons =      homedecor.mesecon_wall_light,
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
							on_rightclick = homedecor.toggle_light,
 | 
				
			||||||
		on_punch =      digiline_on_punch
 | 
							on_punch =      digiline_on_punch,
 | 
				
			||||||
 | 
							on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -749,6 +762,15 @@ for _, light_brightn_name in ipairs({"off", "on"}) do
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	local onflag = (light_brightn_name == "on")
 | 
						local onflag = (light_brightn_name == "on")
 | 
				
			||||||
	local nici = (light_brightn_name == "off") and 1 or nil
 | 
						local nici = (light_brightn_name == "off") and 1 or nil
 | 
				
			||||||
 | 
						local nici_m = (light_brightn_name == "off") and 1 or nil
 | 
				
			||||||
 | 
						local on_rc = homedecor.toggle_light
 | 
				
			||||||
 | 
						local di = "on"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if hd_mesecons then
 | 
				
			||||||
 | 
							nici_m = (light_brightn_name ~= "off") and 1 or nil
 | 
				
			||||||
 | 
							on_rc = nil
 | 
				
			||||||
 | 
							di = "off"
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	local gen_ls_tex_white =           "homedecor_generic_light_source_off.png"
 | 
						local gen_ls_tex_white =           "homedecor_generic_light_source_off.png"
 | 
				
			||||||
	if onflag then gen_ls_tex_white =  "homedecor_generic_light_source_white.png" end
 | 
						if onflag then gen_ls_tex_white =  "homedecor_generic_light_source_white.png" end
 | 
				
			||||||
@@ -829,14 +851,14 @@ for _, light_brightn_name in ipairs({"off", "on"}) do
 | 
				
			|||||||
			"homedecor:rope_light_on_floor_off",
 | 
								"homedecor:rope_light_on_floor_off",
 | 
				
			||||||
			"group:mesecon_conductor_craftable"
 | 
								"group:mesecon_conductor_craftable"
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
		groups = {cracky=3, not_in_creative_inventory = nici},
 | 
							groups = {cracky=3, oddly_breakable_by_hand=3, not_in_creative_inventory = nici_m},
 | 
				
			||||||
		sounds =  default.node_sound_stone_defaults(),
 | 
							sounds =  default.node_sound_stone_defaults(),
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
					 | 
				
			||||||
		drop = {
 | 
							drop = {
 | 
				
			||||||
			items = {
 | 
								items = {
 | 
				
			||||||
				{items = {"homedecor:rope_light_on_floor_on"} },
 | 
									{items = {"homedecor:rope_light_on_floor_"..di} },
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
 | 
							on_rightclick = on_rc,
 | 
				
			||||||
		mesecons = {
 | 
							mesecons = {
 | 
				
			||||||
			conductor = {
 | 
								conductor = {
 | 
				
			||||||
				state = mesecon and (onflag and mesecon.state.on or mesecon.state.off),
 | 
									state = mesecon and (onflag and mesecon.state.on or mesecon.state.off),
 | 
				
			||||||
@@ -875,14 +897,14 @@ for _, light_brightn_name in ipairs({"off", "on"}) do
 | 
				
			|||||||
			"homedecor:rope_light_on_ceiling_off",
 | 
								"homedecor:rope_light_on_ceiling_off",
 | 
				
			||||||
			"group:mesecon_conductor_craftable"
 | 
								"group:mesecon_conductor_craftable"
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
		groups = {cracky=3, not_in_creative_inventory = nici},
 | 
							groups = {cracky=3, oddly_breakable_by_hand=3, not_in_creative_inventory = nici_m},
 | 
				
			||||||
		sounds =  default.node_sound_stone_defaults(),
 | 
							sounds =  default.node_sound_stone_defaults(),
 | 
				
			||||||
		on_rightclick = homedecor.toggle_light,
 | 
					 | 
				
			||||||
		drop = {
 | 
							drop = {
 | 
				
			||||||
			items = {
 | 
								items = {
 | 
				
			||||||
				{items = {"homedecor:rope_light_on_ceiling_on"}},
 | 
									{items = {"homedecor:rope_light_on_ceiling_"..di}},
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
 | 
							on_rightclick = on_rc,
 | 
				
			||||||
		mesecons = {
 | 
							mesecons = {
 | 
				
			||||||
			conductor = {
 | 
								conductor = {
 | 
				
			||||||
				state = mesecon and (onflag and mesecon.state.on or mesecon.state.off),
 | 
									state = mesecon and (onflag and mesecon.state.on or mesecon.state.off),
 | 
				
			||||||
@@ -1837,6 +1859,11 @@ minetest.register_alias("torch_wall",                          "homedecor:torch_
 | 
				
			|||||||
minetest.register_alias("homedecor:plasma_ball",               "homedecor:plasma_ball_on")
 | 
					minetest.register_alias("homedecor:plasma_ball",               "homedecor:plasma_ball_on")
 | 
				
			||||||
minetest.register_alias("homedecor:wall_lamp",                 "homedecor:wall_lamp_on")
 | 
					minetest.register_alias("homedecor:wall_lamp",                 "homedecor:wall_lamp_on")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					minetest.register_alias("homedecor:rope_light_on_floor_0",     "homedecor:rope_light_on_floor_off")
 | 
				
			||||||
 | 
					minetest.register_alias("homedecor:rope_light_on_floor_14",    "homedecor:rope_light_on_floor_on")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					minetest.register_alias("homedecor:rope_light_on_ceiling_0",   "homedecor:rope_light_on_ceiling_off")
 | 
				
			||||||
 | 
					minetest.register_alias("homedecor:rope_light_on_ceiling_14",  "homedecor:rope_light_on_ceiling_on")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
for name, level in pairs(word_to_bright) do
 | 
					for name, level in pairs(word_to_bright) do
 | 
				
			||||||
	minetest.register_alias("homedecor:glowlight_half_"..name,        "homedecor:glowlight_half_"..level)
 | 
						minetest.register_alias("homedecor:glowlight_half_"..name,        "homedecor:glowlight_half_"..level)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5,3 +5,4 @@ unifieddyes
 | 
				
			|||||||
building_blocks?
 | 
					building_blocks?
 | 
				
			||||||
technic?
 | 
					technic?
 | 
				
			||||||
bucket?
 | 
					bucket?
 | 
				
			||||||
 | 
					signs_lib?
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -130,21 +130,22 @@ for _, f in ipairs(flowers_list) do
 | 
				
			|||||||
end
 | 
					end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
homedecor.register("pole_brass", {
 | 
					homedecor.register("pole_brass", {
 | 
				
			||||||
    description = S("Brass Pole"),
 | 
						description = S("Brass Pole"),
 | 
				
			||||||
	mesh = "homedecor_round_pole.obj",
 | 
						mesh = "homedecor_round_pole.obj",
 | 
				
			||||||
    tiles = {"homedecor_generic_metal_brass.png^homedecor_generic_metal_lines_overlay.png",},
 | 
						tiles = {"homedecor_generic_metal_brass.png^homedecor_generic_metal_lines_overlay.png",},
 | 
				
			||||||
    inventory_image = "homedecor_pole_brass_inv.png",
 | 
						inventory_image = "homedecor_pole_brass_inv.png",
 | 
				
			||||||
    wield_image = "homedecor_pole_brass_inv.png",
 | 
						wield_image = "homedecor_pole_brass_inv.png",
 | 
				
			||||||
    selection_box = {
 | 
						selection_box = {
 | 
				
			||||||
            type = "fixed",
 | 
							type = "fixed",
 | 
				
			||||||
            fixed = { -0.125, -0.5, -0.125, 0.125, 0.5, 0.125 },
 | 
							fixed = { -0.125, -0.5, -0.125, 0.125, 0.5, 0.125 },
 | 
				
			||||||
    },
 | 
						},
 | 
				
			||||||
    collision_box = {
 | 
						collision_box = {
 | 
				
			||||||
            type = "fixed",
 | 
							type = "fixed",
 | 
				
			||||||
            fixed = { -0.125, -0.5, -0.125, 0.125, 0.5, 0.125 },
 | 
							fixed = { -0.125, -0.5, -0.125, 0.125, 0.5, 0.125 },
 | 
				
			||||||
    },
 | 
						},
 | 
				
			||||||
    groups = {snappy=3},
 | 
						groups = {snappy=3},
 | 
				
			||||||
    sounds = default.node_sound_wood_defaults(),
 | 
						sounds = default.node_sound_wood_defaults(),
 | 
				
			||||||
 | 
						check_for_pole = true
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
homedecor.register("pole_wrought_iron", {
 | 
					homedecor.register("pole_wrought_iron", {
 | 
				
			||||||
@@ -478,6 +479,7 @@ for _, side in ipairs({"diagonal_left", "diagonal_right", "horizontal"}) do
 | 
				
			|||||||
			def.airbrush_replacement_node = "homedecor:banister_wood_"..side.."_grey"
 | 
								def.airbrush_replacement_node = "homedecor:banister_wood_"..side.."_grey"
 | 
				
			||||||
			def.groups.ud_param2_colorable = 1
 | 
								def.groups.ud_param2_colorable = 1
 | 
				
			||||||
			def.paramtype2 = "colorfacedir"
 | 
								def.paramtype2 = "colorfacedir"
 | 
				
			||||||
 | 
								def.on_dig = unifieddyes.on_dig
 | 
				
			||||||
		end
 | 
							end
 | 
				
			||||||
		homedecor.register(nodename, def)
 | 
							homedecor.register(nodename, def)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -26,6 +26,7 @@ minetest.register_node(":lrfurn:armchair", {
 | 
				
			|||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
						on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		if not clicker:is_player() then
 | 
							if not clicker:is_player() then
 | 
				
			||||||
@@ -51,10 +52,11 @@ homedecor.register("armchair", {
 | 
				
			|||||||
	palette = "unifieddyes_palette_colorwallmounted.png",
 | 
						palette = "unifieddyes_palette_colorwallmounted.png",
 | 
				
			||||||
	groups = {snappy=3, ud_param2_colorable = 1},
 | 
						groups = {snappy=3, ud_param2_colorable = 1},
 | 
				
			||||||
	sounds = default.node_sound_wood_defaults(),
 | 
						sounds = default.node_sound_wood_defaults(),
 | 
				
			||||||
	node_box = ac_cbox,
 | 
						node_box = armchair_cbox,
 | 
				
			||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
						on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -41,6 +41,7 @@ minetest.register_node(":lrfurn:longsofa", {
 | 
				
			|||||||
		end
 | 
							end
 | 
				
			||||||
		return itemstack
 | 
							return itemstack
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		if not clicker:is_player() then
 | 
							if not clicker:is_player() then
 | 
				
			||||||
			return itemstack
 | 
								return itemstack
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -153,6 +153,7 @@ homedecor.register("kitchen_chair_padded", {
 | 
				
			|||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation_nsew(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
						on_rotate = unifieddyes.fix_after_screwdriver_nsew,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		pos.y = pos.y+0 -- where do I put my ass ?
 | 
							pos.y = pos.y+0 -- where do I put my ass ?
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -41,6 +41,7 @@ minetest.register_node(":lrfurn:sofa", {
 | 
				
			|||||||
		end
 | 
							end
 | 
				
			||||||
		return itemstack
 | 
							return itemstack
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		if not clicker:is_player() then
 | 
							if not clicker:is_player() then
 | 
				
			||||||
			return itemstack
 | 
								return itemstack
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,5 +1,7 @@
 | 
				
			|||||||
homedecor_common
 | 
					homedecor_common
 | 
				
			||||||
default
 | 
					default
 | 
				
			||||||
 | 
					player_api
 | 
				
			||||||
homedecor_kitchen?
 | 
					homedecor_kitchen?
 | 
				
			||||||
homedecor_misc?
 | 
					homedecor_misc?
 | 
				
			||||||
 | 
					3d_armor?
 | 
				
			||||||
skinsdb?
 | 
					skinsdb?
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -106,7 +106,7 @@ minetest.register_node(":homedecor:curtain_closed", {
 | 
				
			|||||||
	drawtype = 'signlike',
 | 
						drawtype = 'signlike',
 | 
				
			||||||
	use_texture_alpha = true,
 | 
						use_texture_alpha = true,
 | 
				
			||||||
	walkable = false,
 | 
						walkable = false,
 | 
				
			||||||
	groups = { snappy = 3, ud_param2_colorable = 1 },
 | 
						groups = { snappy = 3, ud_param2_colorable = 1, not_in_creative_inventory=1 },
 | 
				
			||||||
	sounds = default.node_sound_leaves_defaults(),
 | 
						sounds = default.node_sound_leaves_defaults(),
 | 
				
			||||||
	paramtype = "light",
 | 
						paramtype = "light",
 | 
				
			||||||
	paramtype2 = "colorwallmounted",
 | 
						paramtype2 = "colorwallmounted",
 | 
				
			||||||
@@ -115,13 +115,9 @@ minetest.register_node(":homedecor:curtain_closed", {
 | 
				
			|||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		local topnode = minetest.get_node({x=pos.x, y=pos.y+1.0, z=pos.z})
 | 
							minetest.set_node(pos, { name = "homedecor:curtain_open", param2 = node.param2 })
 | 
				
			||||||
		if string.find(topnode.name, "homedecor:curtainrod") then
 | 
					 | 
				
			||||||
			-- Open the curtains
 | 
					 | 
				
			||||||
			local fdir = node.param2
 | 
					 | 
				
			||||||
			minetest.set_node(pos, { name = "homedecor:curtain_open", param2 = fdir })
 | 
					 | 
				
			||||||
		end
 | 
					 | 
				
			||||||
		return itemstack
 | 
							return itemstack
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
@@ -142,13 +138,9 @@ minetest.register_node(":homedecor:curtain_open", {
 | 
				
			|||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		local topnode = minetest.get_node({x=pos.x, y=pos.y+1.0, z=pos.z})
 | 
							minetest.set_node(pos, { name = "homedecor:curtain_closed", param2 = node.param2 })
 | 
				
			||||||
		if string.find(topnode.name, "homedecor:curtainrod") then
 | 
					 | 
				
			||||||
			-- Close the curtains
 | 
					 | 
				
			||||||
			local fdir = node.param2
 | 
					 | 
				
			||||||
			minetest.set_node(pos, { name = "homedecor:curtain_closed", param2 = fdir })
 | 
					 | 
				
			||||||
		end
 | 
					 | 
				
			||||||
		return itemstack
 | 
							return itemstack
 | 
				
			||||||
	end
 | 
						end
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
@@ -253,6 +245,7 @@ homedecor.register("shutter", {
 | 
				
			|||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
homedecor.register("shutter_colored", {
 | 
					homedecor.register("shutter_colored", {
 | 
				
			||||||
@@ -270,6 +263,7 @@ homedecor.register("shutter_colored", {
 | 
				
			|||||||
	after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
						after_place_node = function(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
		unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
							unifieddyes.fix_rotation(pos, placer, itemstack, pointed_thing)
 | 
				
			||||||
	end,
 | 
						end,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_alias("homedecor:shutter_purple", "homedecor:shutter_violet")
 | 
					minetest.register_alias("homedecor:shutter_purple", "homedecor:shutter_violet")
 | 
				
			||||||
@@ -390,7 +384,7 @@ minetest.register_craft({
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	output = "homedecor:curtain_closed 4",
 | 
						output = "homedecor:curtain_open 4",
 | 
				
			||||||
		recipe = {
 | 
							recipe = {
 | 
				
			||||||
		{ "wool:white", "", ""},
 | 
							{ "wool:white", "", ""},
 | 
				
			||||||
		{ "wool:white", "", ""},
 | 
							{ "wool:white", "", ""},
 | 
				
			||||||
@@ -399,7 +393,7 @@ minetest.register_craft( {
 | 
				
			|||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
minetest.register_craft( {
 | 
					minetest.register_craft( {
 | 
				
			||||||
	output = "homedecor:curtain_closed 4",
 | 
						output = "homedecor:curtain_open 4",
 | 
				
			||||||
		recipe = {
 | 
							recipe = {
 | 
				
			||||||
		{ "cottages:wool", "", ""},
 | 
							{ "cottages:wool", "", ""},
 | 
				
			||||||
		{ "cottages:wool", "", ""},
 | 
							{ "cottages:wool", "", ""},
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -38,6 +38,7 @@ minetest.register_node("lavalamp:lavalamp", {
 | 
				
			|||||||
	groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, ud_param2_colorable = 1},
 | 
						groups = {snappy=2,cracky=3,oddly_breakable_by_hand=3, ud_param2_colorable = 1},
 | 
				
			||||||
	sounds = default.node_sound_glass_defaults(),
 | 
						sounds = default.node_sound_glass_defaults(),
 | 
				
			||||||
	on_construct = unifieddyes.on_construct,
 | 
						on_construct = unifieddyes.on_construct,
 | 
				
			||||||
 | 
						on_dig = unifieddyes.on_dig,
 | 
				
			||||||
	on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
						on_rightclick = function(pos, node, clicker, itemstack, pointed_thing)
 | 
				
			||||||
		node.name = "lavalamp:lavalamp_off"
 | 
							node.name = "lavalamp:lavalamp_off"
 | 
				
			||||||
		minetest.swap_node(pos, node)
 | 
							minetest.swap_node(pos, node)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user