mirror of
				https://github.com/minetest-mods/moreblocks.git
				synced 2025-10-24 19:35:24 +02:00 
			
		
		
		
	Merge branch 'master' into lean-inventory
Conflicts: stairsplus/init.lua stairsplus/microblocks.lua stairsplus/panels.lua stairsplus/slabs.lua stairsplus/slopes.lua stairsplus/stairs.lua
This commit is contained in:
		
							
								
								
									
										22
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -7,16 +7,33 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. | |||||||
|  |  | ||||||
| ## [Unreleased] | ## [Unreleased] | ||||||
|  |  | ||||||
|  | ## [1.2.0] - 2018-11-24 | ||||||
|  |  | ||||||
| ### Added | ### Added | ||||||
|  |  | ||||||
|  | - Stairs+ nodes for `basic_materials`'s concrete, cement and brass blocks. | ||||||
| - Listring add for circular saw. | - Listring add for circular saw. | ||||||
|  | - **Stairs+:** New API function | ||||||
|  |   `stairsplus:register_custom_subset(subset, modname, subname, recipeitem, fields)`. | ||||||
|  |  | ||||||
| ### Fixed | ### Fixed | ||||||
|  |  | ||||||
|  | - The papyrus crafting recipe override is now properly applied over the | ||||||
|  |   `default` mod's recipe. | ||||||
|  | - Centered wooden tiles are now craftable. | ||||||
| - Wool Stairs+ nodes can no longer be used in crafting. | - Wool Stairs+ nodes can no longer be used in crafting. | ||||||
| - The circular saw can no longer replace items from the player's inventory | - The circular saw can no longer replace items from the player's inventory | ||||||
|   when it is full. |   when it is full. | ||||||
|  |  | ||||||
|  | ### Changed | ||||||
|  |  | ||||||
|  | - New craft for: | ||||||
|  |   - Stone Tile | ||||||
|  |   - Circle Stone Bricks | ||||||
|  | - Stairs+: | ||||||
|  |   - Move definitions to `stairsplus.defs` table in a separate file | ||||||
|  |   - Move recipe definitions to `stairsplus.register_recipes` function in a separate file | ||||||
|  |  | ||||||
| ## [1.1.0] - 2017-10-04 | ## [1.1.0] - 2017-10-04 | ||||||
|  |  | ||||||
| ### Added | ### Added | ||||||
| @@ -37,9 +54,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. | |||||||
|   - Wool (all colors) |   - Wool (all colors) | ||||||
| - Other mods can now get a list of all the defined Stairs+ shapes | - Other mods can now get a list of all the defined Stairs+ shapes | ||||||
|  |  | ||||||
| ## [1.0.0] - 2017-02-19 | ## 1.0.0 - 2017-02-19 | ||||||
|  |  | ||||||
| - Initial versioned release. | - Initial versioned release. | ||||||
|  |  | ||||||
| [Unreleased]: https://github.com/minetest-mods/moreblocks/compare/v1.1.0...HEAD | [Unreleased]: https://github.com/minetest-mods/moreblocks/compare/v1.2.0...HEAD | ||||||
|  | [1.2.0]: https://github.com/minetest-mods/moreblocks/compare/v1.1.0...v1.2.0 | ||||||
| [1.1.0]: https://github.com/minetest-mods/moreblocks/compare/v1.0.0...v1.1.0 | [1.1.0]: https://github.com/minetest-mods/moreblocks/compare/v1.0.0...v1.1.0 | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| # zlib license | # zlib license | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors | Copyright (c) 2011-2018 Hugo Locurcio and contributors | ||||||
|  |  | ||||||
| **This software is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software.** | **This software is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software.** | ||||||
|  |  | ||||||
|   | |||||||
| @@ -65,7 +65,7 @@ versions than 0.4.16 will generally not be fixed. | |||||||
|  |  | ||||||
| ## License | ## License | ||||||
|  |  | ||||||
| Copyright © 2011-2017 Hugo Locurcio and contributors | Copyright © 2011-2018 Hugo Locurcio and contributors | ||||||
|  |  | ||||||
| - More Blocks code is licensed under the zlib license, see | - More Blocks code is licensed under the zlib license, see | ||||||
|   [`LICENSE.md`](LICENSE.md) for details. |   [`LICENSE.md`](LICENSE.md) for details. | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: alias definitions | More Blocks: alias definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: circular saw | More Blocks: circular saw | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio, Sokomine and contributors. | Copyright (c) 2011-2018 Hugo Locurcio, Sokomine and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: configuration handling | More Blocks: configuration handling | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										35
									
								
								crafting.lua
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								crafting.lua
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: crafting recipes | More Blocks: crafting recipes | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -35,6 +35,15 @@ minetest.register_craft({ | |||||||
| 	recipe = {"default:junglegrass", "default:cobble"}, | 	recipe = {"default:junglegrass", "default:cobble"}, | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | minetest.register_craft({ | ||||||
|  | 	output = "moreblocks:wood_tile_center 9", | ||||||
|  | 	recipe = { | ||||||
|  | 		{"group:wood", "group:wood", "group:wood"}, | ||||||
|  | 		{"group:wood", "moreblocks:wood_tile", "group:wood"}, | ||||||
|  | 		{"group:wood", "group:wood", "group:wood"}, | ||||||
|  | 	} | ||||||
|  | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "moreblocks:wood_tile 9", | 	output = "moreblocks:wood_tile 9", | ||||||
| 	recipe = { | 	recipe = { | ||||||
| @@ -50,15 +59,6 @@ minetest.register_craft({ | |||||||
| 	recipe = {"moreblocks:wood_tile_flipped"} | 	recipe = {"moreblocks:wood_tile_flipped"} | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ |  | ||||||
| 	output = "moreblocks:wood_tile_center 9", |  | ||||||
| 	recipe = { |  | ||||||
| 		{"group:wood", "group:wood", "group:wood"}, |  | ||||||
| 		{"group:wood", "moreblocks:wood_tile", "group:wood"}, |  | ||||||
| 		{"group:wood", "group:wood", "group:wood"}, |  | ||||||
| 	} |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "moreblocks:wood_tile_full 4", | 	output = "moreblocks:wood_tile_full 4", | ||||||
| 	recipe = { | 	recipe = { | ||||||
| @@ -94,11 +94,11 @@ minetest.register_craft({ | |||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "moreblocks:circle_stone_bricks 8", | 	output = "moreblocks:circle_stone_bricks 5", | ||||||
| 	recipe = { | 	recipe = { | ||||||
| 		{"default:stone", "default:stone", "default:stone"}, | 		{"", "default:stone", ""}, | ||||||
| 		{"default:stone", "", "default:stone"}, | 		{"default:stone", "default:coal_lump", "default:stone"}, | ||||||
| 		{"default:stone", "default:stone", "default:stone"}, | 		{"", "default:stone", ""}, | ||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -156,10 +156,11 @@ minetest.register_craft({ | |||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "moreblocks:stone_tile 4", | 	output = "moreblocks:stone_tile 9", | ||||||
| 	recipe = { | 	recipe = { | ||||||
| 		{"default:cobble", "default:cobble"}, | 		{"default:cobble", "default:cobble", "default:cobble"}, | ||||||
| 		{"default:cobble", "default:cobble"}, | 		{"default:cobble", "default:stone", "default:cobble"}, | ||||||
|  | 		{"default:cobble", "default:cobble", "default:cobble"}, | ||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,3 +3,4 @@ intllib? | |||||||
| stairs? | stairs? | ||||||
| farming? | farming? | ||||||
| wool? | wool? | ||||||
|  | basic_materials? | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								init.lua
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ | |||||||
| ** More Blocks ** | ** More Blocks ** | ||||||
| By Calinou, with the help of ShadowNinja and VanessaE. | By Calinou, with the help of ShadowNinja and VanessaE. | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| ===================================================================== | ===================================================================== | ||||||
| --]] | --]] | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: node definitions | More Blocks: node definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: ownership handling | More Blocks: ownership handling | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: redefinitions of default stuff | More Blocks: redefinitions of default stuff | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -25,6 +25,11 @@ minetest.register_craft({ | |||||||
| 	} | 	} | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | minetest.clear_craft({ | ||||||
|  | 	recipe = { | ||||||
|  | 		{"default:papyrus", "default:papyrus", "default:papyrus"} | ||||||
|  | 	} | ||||||
|  | }) | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	output = "default:paper 4", | 	output = "default:paper 4", | ||||||
| 	recipe = { | 	recipe = { | ||||||
|   | |||||||
| @@ -20,4 +20,63 @@ You will probably never want to use them directly: | |||||||
| * `stairsplus:register_slab(modname, subname, recipeitem, fields)` | * `stairsplus:register_slab(modname, subname, recipeitem, fields)` | ||||||
| * `stairsplus:register_panel(modname, subname, recipeitem, fields)` | * `stairsplus:register_panel(modname, subname, recipeitem, fields)` | ||||||
| * `stairsplus:register_micro(modname, subname, recipeitem, fields)` | * `stairsplus:register_micro(modname, subname, recipeitem, fields)` | ||||||
|  | * `stairsplus:register_slope(modname, subname, recipeitem, fields)` | ||||||
|  |  | ||||||
|  | If you only want to register a subset of stairsplus nodes, | ||||||
|  | you can use the `stairsplus:register_custom_subset(subset, modname, subname, recipeitem, fields)` function. | ||||||
|  | The subset table should have the following format: | ||||||
|  |  | ||||||
|  | ```lua | ||||||
|  |     local subset = { | ||||||
|  |     	{ "micro", "" }, | ||||||
|  |     	{ "micro", "_1" }, | ||||||
|  |     	{ "micro", "_2" }, | ||||||
|  |     	{ "micro", "_4" }, | ||||||
|  |     	{ "micro", "_12" }, | ||||||
|  |     	{ "micro", "_14" }, | ||||||
|  |     	{ "micro", "_15" }, | ||||||
|  |     	{ "panel", "" }, | ||||||
|  |     	{ "panel", "_1" }, | ||||||
|  |     	{ "panel", "_2" }, | ||||||
|  |     	{ "panel", "_4" }, | ||||||
|  |     	{ "panel", "_12" }, | ||||||
|  |     	{ "panel", "_14" }, | ||||||
|  |     	{ "panel", "_15" }, | ||||||
|  |     	{ "slab",  "" }, | ||||||
|  |     	{ "slab",  "_quarter" }, | ||||||
|  |     	{ "slab",  "_three_quarter" }, | ||||||
|  |     	{ "slab",  "_1" }, | ||||||
|  |     	{ "slab",  "_2" }, | ||||||
|  |     	{ "slab",  "_14" }, | ||||||
|  |     	{ "slab",  "_15" }, | ||||||
|  |     	{ "slab",  "_two_sides" }, | ||||||
|  |     	{ "slab",  "_three_sides" }, | ||||||
|  |     	{ "slab",  "_three_sides_u" }, | ||||||
|  |     	{ "slope", "" }, | ||||||
|  |     	{ "slope", "_half" }, | ||||||
|  |     	{ "slope", "_half_raised" }, | ||||||
|  |     	{ "slope", "_inner" }, | ||||||
|  |     	{ "slope", "_inner_half" }, | ||||||
|  |     	{ "slope", "_inner_half_raised" }, | ||||||
|  |     	{ "slope", "_inner_cut" }, | ||||||
|  |     	{ "slope", "_inner_cut_half" }, | ||||||
|  |     	{ "slope", "_inner_cut_half_raised" }, | ||||||
|  |     	{ "slope", "_outer" }, | ||||||
|  |     	{ "slope", "_outer_half" }, | ||||||
|  |     	{ "slope", "_outer_half_raised" }, | ||||||
|  |     	{ "slope", "_outer_cut" }, | ||||||
|  |     	{ "slope", "_outer_cut_half" }, | ||||||
|  |     	{ "slope", "_outer_cut_half_raised" }, | ||||||
|  |     	{ "slope", "_cut" }, | ||||||
|  |     	{ "stair", "" }, | ||||||
|  |     	{ "stair", "_half" }, | ||||||
|  |     	{ "stair", "_right_half" }, | ||||||
|  |     	{ "stair", "_inner" }, | ||||||
|  |     	{ "stair", "_outer" }, | ||||||
|  |     	{ "stair", "_alt" }, | ||||||
|  |     	{ "stair", "_alt_1" }, | ||||||
|  |     	{ "stair", "_alt_2" }, | ||||||
|  |     	{ "stair", "_alt_4" }, | ||||||
|  |     } | ||||||
|  | ``` | ||||||
|  | You can remove entries as needed. | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: alias definitions | More Blocks: alias definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										61
									
								
								stairsplus/common.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								stairsplus/common.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | --[[ | ||||||
|  | More Blocks: registrations | ||||||
|  |  | ||||||
|  | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
|  | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
|  | --]] | ||||||
|  |  | ||||||
|  | local S = moreblocks.intllib | ||||||
|  |  | ||||||
|  |  | ||||||
|  | stairsplus.register_single = function(category, alternate, info, modname, subname, recipeitem, fields) | ||||||
|  | 	local descriptions = { | ||||||
|  | 		["micro"] = "Microblock", | ||||||
|  | 		["slab"] = "Slab", | ||||||
|  | 		["slope"] = "Slope", | ||||||
|  | 		["panel"] = "Panel", | ||||||
|  | 		["stair"] = "Stairs", | ||||||
|  | 	} | ||||||
|  | 	local def = {} | ||||||
|  | 	if category ~= "slab" then | ||||||
|  | 		def = table.copy(info) | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	for k, v in pairs(fields) do | ||||||
|  | 		def[k] = v | ||||||
|  | 	end | ||||||
|  | 	def.drawtype = "nodebox" | ||||||
|  | 	if category == "slope" then | ||||||
|  | 		def.drawtype = "mesh" | ||||||
|  | 	end | ||||||
|  | 	def.paramtype = "light" | ||||||
|  | 	def.paramtype2 = def.paramtype2 or "facedir" | ||||||
|  | 	def.on_place = minetest.rotate_node | ||||||
|  | 	if category ~= "slab" then | ||||||
|  | 		def.description = S("%s " .. descriptions[category]):format(fields.description) | ||||||
|  | 	else | ||||||
|  | 		local desc_base = S("%s " .. descriptions[category]):format(fields.description) | ||||||
|  | 		if type(info) ~= "table" then | ||||||
|  | 			def.node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, -0.5, 0.5, (info/16)-0.5, 0.5}, | ||||||
|  | 			} | ||||||
|  | 			def.description = ("%s (%d/16)"):format(desc_base, info) | ||||||
|  | 		else | ||||||
|  | 			def.node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = info, | ||||||
|  | 			} | ||||||
|  | 			def.description = desc_base .. alternate:gsub("_", " "):gsub("(%a)(%S*)", function(a, b) return a:upper() .. b end) | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  | 	def.groups = stairsplus:prepare_groups(fields.groups) | ||||||
|  | 	if category == "stair" and alternate == "" then | ||||||
|  | 		def.groups.stair = 1 | ||||||
|  | 	end | ||||||
|  | 	if fields.drop and not (type(fields.drop) == "table") then | ||||||
|  | 		def.drop = modname.. ":" .. category .. "_" .. fields.drop .. alternate | ||||||
|  | 	end | ||||||
|  | 	minetest.register_node(":" ..modname.. ":" .. category .. "_" .. subname .. alternate, def) | ||||||
|  | 	stairsplus.register_recipes(category, alternate, modname, subname, recipeitem) | ||||||
|  | end | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: conversion | More Blocks: conversion | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										98
									
								
								stairsplus/custom.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								stairsplus/custom.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | |||||||
|  | --[[ | ||||||
|  | More Blocks: microblock definitions | ||||||
|  |  | ||||||
|  | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
|  | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
|  | --]] | ||||||
|  |  | ||||||
|  | local S = moreblocks.intllib | ||||||
|  |  | ||||||
|  | --[[ | ||||||
|  | Subset table should have the following format: (You can remove entries as needed.) | ||||||
|  |  | ||||||
|  | local subset = { | ||||||
|  | 	{ "micro", "" }, | ||||||
|  | 	{ "micro", "_1" }, | ||||||
|  | 	{ "micro", "_2" }, | ||||||
|  | 	{ "micro", "_4" }, | ||||||
|  | 	{ "micro", "_12" }, | ||||||
|  | 	{ "micro", "_14" }, | ||||||
|  | 	{ "micro", "_15" }, | ||||||
|  | 	{ "panel", "" }, | ||||||
|  | 	{ "panel", "_1" }, | ||||||
|  | 	{ "panel", "_2" }, | ||||||
|  | 	{ "panel", "_4" }, | ||||||
|  | 	{ "panel", "_12" }, | ||||||
|  | 	{ "panel", "_14" }, | ||||||
|  | 	{ "panel", "_15" }, | ||||||
|  | 	{ "slab",  "" }, | ||||||
|  | 	{ "slab",  "_quarter" }, | ||||||
|  | 	{ "slab",  "_three_quarter" }, | ||||||
|  | 	{ "slab",  "_1" }, | ||||||
|  | 	{ "slab",  "_2" }, | ||||||
|  | 	{ "slab",  "_14" }, | ||||||
|  | 	{ "slab",  "_15" }, | ||||||
|  | 	{ "slab",  "_two_sides" }, | ||||||
|  | 	{ "slab",  "_three_sides" }, | ||||||
|  | 	{ "slab",  "_three_sides_u" }, | ||||||
|  | 	{ "slope", "" }, | ||||||
|  | 	{ "slope", "_half" }, | ||||||
|  | 	{ "slope", "_half_raised" }, | ||||||
|  | 	{ "slope", "_inner" }, | ||||||
|  | 	{ "slope", "_inner_half" }, | ||||||
|  | 	{ "slope", "_inner_half_raised" }, | ||||||
|  | 	{ "slope", "_inner_cut" }, | ||||||
|  | 	{ "slope", "_inner_cut_half" }, | ||||||
|  | 	{ "slope", "_inner_cut_half_raised" }, | ||||||
|  | 	{ "slope", "_outer" }, | ||||||
|  | 	{ "slope", "_outer_half" }, | ||||||
|  | 	{ "slope", "_outer_half_raised" }, | ||||||
|  | 	{ "slope", "_outer_cut" }, | ||||||
|  | 	{ "slope", "_outer_cut_half" }, | ||||||
|  | 	{ "slope", "_outer_cut_half_raised" }, | ||||||
|  | 	{ "slope", "_cut" }, | ||||||
|  | 	{ "stair", "" }, | ||||||
|  | 	{ "stair", "_half" }, | ||||||
|  | 	{ "stair", "_right_half" }, | ||||||
|  | 	{ "stair", "_inner" }, | ||||||
|  | 	{ "stair", "_outer" }, | ||||||
|  | 	{ "stair", "_alt" }, | ||||||
|  | 	{ "stair", "_alt_1" }, | ||||||
|  | 	{ "stair", "_alt_2" }, | ||||||
|  | 	{ "stair", "_alt_4" }, | ||||||
|  | } | ||||||
|  | --]] | ||||||
|  |  | ||||||
|  | function register_custom_subset(subset, modname, subname, recipeitem, groups, images, description, drop, light) | ||||||
|  | 	stairsplus:register_custom_subset(subset, modname, subname, recipeitem, { | ||||||
|  | 		groups = groups, | ||||||
|  | 		tiles = images, | ||||||
|  | 		description = description, | ||||||
|  | 		drop = drop, | ||||||
|  | 		light_source = light, | ||||||
|  | 		sounds = default.node_sound_stone_defaults(), | ||||||
|  | 	}) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function stairsplus:register_custom_subset_alias(subset, modname_old, subname_old, modname_new, subname_new) | ||||||
|  | 	local subset = table.copy(subset) | ||||||
|  | 	for k, v in pairs(subset) do | ||||||
|  | 		minetest.register_alias(modname_old .. ":" .. v[1] .. "_" .. subname_old .. v[2], modname_new .. ":" .. v[1] .. "_" .. subname_new .. v[2]) | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function stairsplus:register_custom_subset_alias_force(subset, modname_old, subname_old, modname_new, subname_new) | ||||||
|  | 	local subset = table.copy(subset) | ||||||
|  | 	for k, v in pairs(subset) do | ||||||
|  | 		minetest.register_alias_force(modname_old .. ":" .. v[1] .. "_" .. subname_old .. v[2], modname_new .. ":" .. v[1] .. "_" .. subname_new .. v[2]) | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function stairsplus:register_custom_subset(subset, modname, subname, recipeitem, fields) | ||||||
|  | 	local subset = table.copy(subset) | ||||||
|  | 	for k, v in pairs(subset) do | ||||||
|  | 		stairsplus.register_single(v[1], v[2], stairsplus.defs[v[1]][v[2]], modname, subname, recipeitem, fields) | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	circular_saw.known_nodes[recipeitem] = {modname, subname} | ||||||
|  | end | ||||||
							
								
								
									
										409
									
								
								stairsplus/defs.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										409
									
								
								stairsplus/defs.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,409 @@ | |||||||
|  | --[[ | ||||||
|  | More Blocks: registrations | ||||||
|  |  | ||||||
|  | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
|  | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
|  | --]] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | local box_slope = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5,  -0.5,  -0.5, 0.5, -0.25, 0.5}, | ||||||
|  | 		{-0.5, -0.25, -0.25, 0.5,     0, 0.5}, | ||||||
|  | 		{-0.5,     0,     0, 0.5,  0.25, 0.5}, | ||||||
|  | 		{-0.5,  0.25,  0.25, 0.5,   0.5, 0.5} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | local box_slope_half = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5, -0.5,   -0.5,  0.5, -0.375, 0.5}, | ||||||
|  | 		{-0.5, -0.375, -0.25, 0.5, -0.25,  0.5}, | ||||||
|  | 		{-0.5, -0.25,  0,    0.5, -0.125, 0.5}, | ||||||
|  | 		{-0.5, -0.125, 0.25, 0.5,  0,     0.5}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | local box_slope_half_raised = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5, -0.5,   -0.5,  0.5, 0.125, 0.5}, | ||||||
|  | 		{-0.5, 0.125, -0.25, 0.5, 0.25,  0.5}, | ||||||
|  | 		{-0.5, 0.25,  0,    0.5, 0.375, 0.5}, | ||||||
|  | 		{-0.5, 0.375, 0.25, 0.5,  0.5,     0.5}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | --============================================================== | ||||||
|  |  | ||||||
|  | local box_slope_inner = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5}, | ||||||
|  | 		{-0.5, -0.5, -0.25, 0.5, 0, 0.5}, | ||||||
|  | 		{-0.5, -0.5, -0.5, 0.25, 0, 0.5}, | ||||||
|  | 		{-0.5, 0, -0.5, 0, 0.25, 0.5}, | ||||||
|  | 		{-0.5, 0, 0, 0.5, 0.25, 0.5}, | ||||||
|  | 		{-0.5, 0.25, 0.25, 0.5, 0.5, 0.5}, | ||||||
|  | 		{-0.5, 0.25, -0.5, -0.25, 0.5, 0.5}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | local box_slope_inner_half = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5, -0.5, -0.5, 0.5, -0.375, 0.5}, | ||||||
|  | 		{-0.5, -0.375, -0.25, 0.5, -0.25, 0.5}, | ||||||
|  | 		{-0.5, -0.375, -0.5, 0.25, -0.25, 0.5}, | ||||||
|  | 		{-0.5, -0.25, -0.5, 0, -0.125, 0.5}, | ||||||
|  | 		{-0.5, -0.25, 0, 0.5, -0.125, 0.5}, | ||||||
|  | 		{-0.5, -0.125, 0.25, 0.5, 0, 0.5}, | ||||||
|  | 		{-0.5, -0.125, -0.5, -0.25, 0, 0.5}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | local box_slope_inner_half_raised = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5, -0.5, -0.5, 0.5, 0.125, 0.5}, | ||||||
|  | 		{-0.5, 0.125, -0.25, 0.5, 0.25, 0.5}, | ||||||
|  | 		{-0.5, 0.125, -0.5, 0.25, 0.25, 0.5}, | ||||||
|  | 		{-0.5, 0.25, -0.5, 0, 0.375, 0.5}, | ||||||
|  | 		{-0.5, 0.25, 0, 0.5, 0.375, 0.5}, | ||||||
|  | 		{-0.5, 0.375, 0.25, 0.5, 0.5, 0.5}, | ||||||
|  | 		{-0.5, 0.375, -0.5, -0.25, 0.5, 0.5}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | --============================================================== | ||||||
|  |  | ||||||
|  | local box_slope_outer = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5,  -0.5,  -0.5,   0.5, -0.25, 0.5}, | ||||||
|  | 		{-0.5, -0.25, -0.25,  0.25,     0, 0.5}, | ||||||
|  | 		{-0.5,     0,     0,     0,  0.25, 0.5}, | ||||||
|  | 		{-0.5,  0.25,  0.25, -0.25,   0.5, 0.5} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | local box_slope_outer_half = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5,  -0.5,  -0.5,   0.5, -0.375, 0.5}, | ||||||
|  | 		{-0.5, -0.375, -0.25,  0.25, -0.25, 0.5}, | ||||||
|  | 		{-0.5,  -0.25,     0,     0, -0.125, 0.5}, | ||||||
|  | 		{-0.5,  -0.125,  0.25, -0.25, 0, 0.5} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | local box_slope_outer_half_raised = { | ||||||
|  | 	type = "fixed", | ||||||
|  | 	fixed = { | ||||||
|  | 		{-0.5,  -0.5,  -0.5,   0.5, 0.125, 0.5}, | ||||||
|  | 		{-0.5, 0.125, -0.25,  0.25, 0.25, 0.5}, | ||||||
|  | 		{-0.5,  0.25,     0,     0, 0.375, 0.5}, | ||||||
|  | 		{-0.5,  0.375,  0.25, -0.25, 0.5, 0.5} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | stairsplus.defs = { | ||||||
|  | 	["micro"] = { | ||||||
|  | 		[""] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, 0, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_1"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, -0.4375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_2"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, -0.375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_4"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, -0.25, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_12"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, 0.25, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_14"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, 0.375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_15"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0, 0.4375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	["panel"] = { | ||||||
|  | 		[""] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, 0, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_1"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, -0.4375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_2"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, -0.375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_4"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, -0.25, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_12"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, 0.25, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_14"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, 0.375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_15"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.5, -0.5, 0, 0.5, 0.4375, 0.5}, | ||||||
|  | 			}, | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	["slab"] = { | ||||||
|  | 		[""] = 8, | ||||||
|  | 		["_quarter"] = 4, | ||||||
|  | 		["_three_quarter"] = 12, | ||||||
|  | 		["_1"] = 1, | ||||||
|  | 		["_2"] = 2, | ||||||
|  | 		["_14"] = 14, | ||||||
|  | 		["_15"] = 15, | ||||||
|  | 		["_two_sides"] = { | ||||||
|  | 			{ -0.5, -0.5, -0.5, 0.5, -7/16, 7/16 }, | ||||||
|  | 			{ -0.5, -0.5, 7/16, 0.5, 0.5, 0.5 } | ||||||
|  | 		}, | ||||||
|  | 		["_three_sides"] = { | ||||||
|  | 			{ -7/16, -0.5, -0.5, 0.5, -7/16, 7/16 }, | ||||||
|  | 			{ -7/16, -0.5, 7/16, 0.5, 0.5, 0.5 }, | ||||||
|  | 			{ -0.5, -0.5, -0.5, -7/16, 0.5, 0.5 } | ||||||
|  | 		}, | ||||||
|  | 		["_three_sides_u"] = { | ||||||
|  | 			{ -0.5, -0.5, -0.5, 0.5, 0.5, -7/16 }, | ||||||
|  | 			{ -0.5, -0.5, -7/16, 0.5, -7/16, 7/16 }, | ||||||
|  | 			{ -0.5, -0.5, 7/16, 0.5, 0.5, 0.5 } | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	["slope"] = { | ||||||
|  | 		[""] = { | ||||||
|  | 			mesh = "moreblocks_slope.obj", | ||||||
|  | 			collision_box = box_slope, | ||||||
|  | 			selection_box = box_slope, | ||||||
|  |  | ||||||
|  | 		}, | ||||||
|  | 		["_half"] = { | ||||||
|  | 			mesh = "moreblocks_slope_half.obj", | ||||||
|  | 			collision_box = box_slope_half, | ||||||
|  | 			selection_box = box_slope_half, | ||||||
|  | 		}, | ||||||
|  | 		["_half_raised"] = { | ||||||
|  | 			mesh = "moreblocks_slope_half_raised.obj", | ||||||
|  | 			collision_box = box_slope_half_raised, | ||||||
|  | 			selection_box = box_slope_half_raised, | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		--============================================================== | ||||||
|  |  | ||||||
|  | 		["_inner"] = { | ||||||
|  | 			mesh = "moreblocks_slope_inner.obj", | ||||||
|  | 			collision_box = box_slope_inner, | ||||||
|  | 			selection_box = box_slope_inner, | ||||||
|  | 		}, | ||||||
|  | 		["_inner_half"] = { | ||||||
|  | 			mesh = "moreblocks_slope_inner_half.obj", | ||||||
|  | 			collision_box = box_slope_inner_half, | ||||||
|  | 			selection_box = box_slope_inner_half, | ||||||
|  | 		}, | ||||||
|  | 		["_inner_half_raised"] = { | ||||||
|  | 			mesh = "moreblocks_slope_inner_half_raised.obj", | ||||||
|  | 			collision_box = box_slope_inner_half_raised, | ||||||
|  | 			selection_box = box_slope_inner_half_raised, | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		--============================================================== | ||||||
|  |  | ||||||
|  | 		["_inner_cut"] = { | ||||||
|  | 			mesh = "moreblocks_slope_inner_cut.obj", | ||||||
|  | 			collision_box = box_slope_inner, | ||||||
|  | 			selection_box = box_slope_inner, | ||||||
|  | 		}, | ||||||
|  | 		["_inner_cut_half"] = { | ||||||
|  | 			mesh = "moreblocks_slope_inner_cut_half.obj", | ||||||
|  | 			collision_box = box_slope_inner_half, | ||||||
|  | 			selection_box = box_slope_inner_half, | ||||||
|  | 		}, | ||||||
|  | 		["_inner_cut_half_raised"] = { | ||||||
|  | 			mesh = "moreblocks_slope_inner_cut_half_raised.obj", | ||||||
|  | 			collision_box = box_slope_inner_half_raised, | ||||||
|  | 			selection_box = box_slope_inner_half_raised, | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		--============================================================== | ||||||
|  |  | ||||||
|  | 		["_outer"] = { | ||||||
|  | 			mesh = "moreblocks_slope_outer.obj", | ||||||
|  | 			collision_box = box_slope_outer, | ||||||
|  | 			selection_box = box_slope_outer, | ||||||
|  | 		}, | ||||||
|  | 		["_outer_half"] = { | ||||||
|  | 			mesh = "moreblocks_slope_outer_half.obj", | ||||||
|  | 			collision_box = box_slope_outer_half, | ||||||
|  | 			selection_box = box_slope_outer_half, | ||||||
|  | 		}, | ||||||
|  | 		["_outer_half_raised"] = { | ||||||
|  | 			mesh = "moreblocks_slope_outer_half_raised.obj", | ||||||
|  | 			collision_box = box_slope_outer_half_raised, | ||||||
|  | 			selection_box = box_slope_outer_half_raised, | ||||||
|  | 		}, | ||||||
|  |  | ||||||
|  | 		--============================================================== | ||||||
|  |  | ||||||
|  | 		["_outer_cut"] = { | ||||||
|  | 			mesh = "moreblocks_slope_outer_cut.obj", | ||||||
|  | 			collision_box = box_slope_outer, | ||||||
|  | 			selection_box = box_slope_outer, | ||||||
|  | 		}, | ||||||
|  | 		["_outer_cut_half"] = { | ||||||
|  | 			mesh = "moreblocks_slope_outer_cut_half.obj", | ||||||
|  | 			collision_box = box_slope_outer_half, | ||||||
|  | 			selection_box = box_slope_outer_half, | ||||||
|  | 		}, | ||||||
|  | 		["_outer_cut_half_raised"] = { | ||||||
|  | 			mesh = "moreblocks_slope_outer_cut_half_raised.obj", | ||||||
|  | 			collision_box = box_slope_outer_half_raised, | ||||||
|  | 			selection_box = box_slope_outer_half_raised, | ||||||
|  | 		}, | ||||||
|  | 		["_cut"] = { | ||||||
|  | 			mesh = "moreblocks_slope_cut.obj", | ||||||
|  | 			collision_box = box_slope_outer, | ||||||
|  | 			selection_box = box_slope_outer, | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	["stair"] = { | ||||||
|  | 		[""] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, | ||||||
|  | 					{-0.5, 0, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_half"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.5, -0.5, 0, 0, 0.5}, | ||||||
|  | 					{-0.5, 0, 0, 0, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_right_half"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{0, -0.5, -0.5, 0.5, 0, 0.5}, | ||||||
|  | 					{0, 0, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_inner"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, | ||||||
|  | 					{-0.5, 0, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 					{-0.5, 0, -0.5, 0, 0.5, 0}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_outer"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, | ||||||
|  | 					{-0.5, 0, 0, 0, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_alt"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.5, -0.5, 0.5, 0, 0}, | ||||||
|  | 					{-0.5, 0, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_alt_1"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.0625, -0.5, 0.5, 0, 0}, | ||||||
|  | 					{-0.5, 0.4375, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_alt_2"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.125, -0.5, 0.5, 0, 0}, | ||||||
|  | 					{-0.5, 0.375, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		["_alt_4"] = { | ||||||
|  | 			node_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = { | ||||||
|  | 					{-0.5, -0.25, -0.5, 0.5, 0, 0}, | ||||||
|  | 					{-0.5, 0.25, 0, 0.5, 0.5, 0.5}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | for type,a in pairs(stairsplus.defs) do | ||||||
|  | 	for name,b in pairs(stairsplus.defs[type]) do | ||||||
|  | 		table.insert(stairsplus.shapes_list, { type .. "_", name }) | ||||||
|  | 	end | ||||||
|  | end | ||||||
| @@ -1,11 +1,11 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: Stairs+ | More Blocks: Stairs+ | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| -- Nodes will be called <modname>:{stair,slab,panel,micro}_<subname> | -- Nodes will be called <modname>:{stair,slab,panel,micro,slope}_<subname> | ||||||
|  |  | ||||||
| local modpath = minetest.get_modpath("moreblocks").. "/stairsplus" | local modpath = minetest.get_modpath("moreblocks").. "/stairsplus" | ||||||
|  |  | ||||||
| @@ -19,22 +19,7 @@ and minetest.settings:get_bool("creative_mode") then | |||||||
| 	stairsplus.expect_infinite_stacks = true | 	stairsplus.expect_infinite_stacks = true | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus.copytable(orig) | function stairsplus:prepare_groups(groups) | ||||||
| 	local orig_type = type(orig) |  | ||||||
| 	local copy |  | ||||||
| 	if orig_type == 'table' then |  | ||||||
| 		copy = {} |  | ||||||
| 		for orig_key, orig_value in next, orig, nil do |  | ||||||
| 			copy[stairsplus.copytable(orig_key)] = stairsplus.copytable(orig_value) |  | ||||||
| 		end |  | ||||||
| 		setmetatable(copy, stairsplus.copytable(getmetatable(orig))) |  | ||||||
| 	else |  | ||||||
| 		copy = orig |  | ||||||
| 	end |  | ||||||
| 	return copy |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function stairsplus:prepare_groups(groups, disabled_in_inventory) |  | ||||||
| 	local result = {} | 	local result = {} | ||||||
| 	if groups then | 	if groups then | ||||||
| 		for k, v in pairs(groups) do | 		for k, v in pairs(groups) do | ||||||
| @@ -88,9 +73,13 @@ end | |||||||
|  |  | ||||||
| -- dofile(modpath.. "/aliases.lua") -- Not needed as of Q2 2013, uncomment to fix old maps. | -- dofile(modpath.. "/aliases.lua") -- Not needed as of Q2 2013, uncomment to fix old maps. | ||||||
| -- dofile(modpath.. "/conversion.lua") -- Not needed as of Q2 2013, uncomment to fix old maps. | -- dofile(modpath.. "/conversion.lua") -- Not needed as of Q2 2013, uncomment to fix old maps. | ||||||
|  | dofile(modpath .. "/defs.lua") | ||||||
|  | dofile(modpath .. "/recipes.lua") | ||||||
|  | dofile(modpath .. "/common.lua") | ||||||
| dofile(modpath .. "/stairs.lua") | dofile(modpath .. "/stairs.lua") | ||||||
| dofile(modpath .. "/slabs.lua") | dofile(modpath .. "/slabs.lua") | ||||||
| dofile(modpath .. "/slopes.lua") | dofile(modpath .. "/slopes.lua") | ||||||
| dofile(modpath .. "/panels.lua") | dofile(modpath .. "/panels.lua") | ||||||
| dofile(modpath .. "/microblocks.lua") | dofile(modpath .. "/microblocks.lua") | ||||||
|  | dofile(modpath .. "/custom.lua") | ||||||
| dofile(modpath .. "/registrations.lua") | dofile(modpath .. "/registrations.lua") | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: microblock definitions | More Blocks: microblock definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -20,138 +20,25 @@ function register_micro(modname, subname, recipeitem, groups, images, descriptio | |||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| local microblocks_defs = { |  | ||||||
| 	[""] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, 0, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_1"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, -0.4375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_2"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, -0.375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_4"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, -0.25, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_12"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, 0.25, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_14"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, 0.375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_15"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0, 0.4375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| for k,v in pairs(microblocks_defs) do |  | ||||||
| 	table.insert(stairsplus.shapes_list, { "micro_", k }) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function stairsplus:register_micro_alias(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_micro_alias(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(microblocks_defs) | 	local defs = table.copy(stairsplus.defs["micro"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias(modname_old .. ":micro_" .. subname_old .. alternate, modname_new .. ":micro_" .. subname_new .. alternate) | 		minetest.register_alias(modname_old .. ":micro_" .. subname_old .. alternate, modname_new .. ":micro_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_micro_alias_force(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_micro_alias_force(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(microblocks_defs) | 	local defs = table.copy(stairsplus.defs["micro"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias_force(modname_old .. ":micro_" .. subname_old .. alternate, modname_new .. ":micro_" .. subname_new .. alternate) | 		minetest.register_alias_force(modname_old .. ":micro_" .. subname_old .. alternate, modname_new .. ":micro_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_micro(modname, subname, recipeitem, fields) | function stairsplus:register_micro(modname, subname, recipeitem, fields) | ||||||
| 	local defs = stairsplus.copytable(microblocks_defs) | 	local defs = table.copy(stairsplus.defs["micro"]) | ||||||
| 	local desc = S("%s Microblock"):format(fields.description) |  | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		for k, v in pairs(fields) do | 		stairsplus.register_single("micro", alternate, def, modname, subname, recipeitem, fields) | ||||||
| 			def[k] = v |  | ||||||
| 		end |  | ||||||
| 		def.drawtype = "nodebox" |  | ||||||
| 		def.paramtype = "light" |  | ||||||
| 		def.paramtype2 = def.paramtype2 or "facedir" |  | ||||||
| 		def.on_place = minetest.rotate_node |  | ||||||
| 		def.groups = stairsplus:prepare_groups(fields.groups, moreblocks.config.stairsplus_microblocks_not_in_creative_inventory) |  | ||||||
| 		def.description = desc |  | ||||||
| 		if fields.drop and not (type(fields.drop) == "table") then |  | ||||||
| 			def.drop = modname.. ":micro_" ..fields.drop..alternate |  | ||||||
| 		end |  | ||||||
| 		minetest.register_node(":" ..modname.. ":micro_" ..subname..alternate, def) |  | ||||||
| 	end | 	end | ||||||
| 	minetest.register_alias(modname.. ":micro_" ..subname.. "_bottom", modname.. ":micro_" ..subname) |  | ||||||
|  |  | ||||||
| 	circular_saw.known_nodes[recipeitem] = {modname, subname} | 	circular_saw.known_nodes[recipeitem] = {modname, subname} | ||||||
|  |  | ||||||
| 	-- Some saw-less recipes: |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":micro_" .. subname .. " 7", |  | ||||||
| 		recipe = {modname .. ":stair_" .. subname .. "_inner"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 	output = modname .. ":micro_" .. subname .. " 6", |  | ||||||
| 		type = "shapeless", |  | ||||||
| 	recipe = {modname .. ":stair_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":micro_" .. subname .. " 5", |  | ||||||
| 		recipe = {modname .. ":stair_" .. subname .. "_outer"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":micro_" .. subname .. " 4", |  | ||||||
| 		recipe = {modname .. ":slab_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":micro_" .. subname .. " 4", |  | ||||||
| 		recipe = {modname .. ":stair_" .. subname .. "_alt"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":micro_" .. subname .. " 3", |  | ||||||
| 		recipe = {modname .. ":stair_" .. subname .. "_right_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":micro_" .. subname .. " 2", |  | ||||||
| 		recipe = {modname .. ":panel_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
| end | end | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: panel definitions | More Blocks: panel definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -20,118 +20,25 @@ function register_panel(modname, subname, recipeitem, groups, images, descriptio | |||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| local panels_defs = { |  | ||||||
| 	[""] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, 0, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_1"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, -0.4375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_2"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, -0.375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_4"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, -0.25, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_12"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, 0.25, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_14"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, 0.375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_15"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.5, -0.5, 0, 0.5, 0.4375, 0.5}, |  | ||||||
| 		}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| for k,v in pairs(panels_defs) do |  | ||||||
| 	table.insert(stairsplus.shapes_list, { "panel_", k }) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function stairsplus:register_panel_alias(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_panel_alias(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(panels_defs) | 	local defs = table.copy(stairsplus.defs["panel"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias(modname_old .. ":panel_" .. subname_old .. alternate, modname_new .. ":panel_" .. subname_new .. alternate) | 		minetest.register_alias(modname_old .. ":panel_" .. subname_old .. alternate, modname_new .. ":panel_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_panel_alias_force(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_panel_alias_force(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(panels_defs) | 	local defs = table.copy(stairsplus.defs["panel"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias_force(modname_old .. ":panel_" .. subname_old .. alternate, modname_new .. ":panel_" .. subname_new .. alternate) | 		minetest.register_alias_force(modname_old .. ":panel_" .. subname_old .. alternate, modname_new .. ":panel_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_panel(modname, subname, recipeitem, fields) | function stairsplus:register_panel(modname, subname, recipeitem, fields) | ||||||
| 	local defs = stairsplus.copytable(panels_defs) | 	local defs = table.copy(stairsplus.defs["panel"]) | ||||||
| 	local desc = S("%s Panel"):format(fields.description) |  | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		for k, v in pairs(fields) do | 		stairsplus.register_single("panel", alternate, def, modname, subname, recipeitem, fields) | ||||||
| 			def[k] = v |  | ||||||
| 		end |  | ||||||
| 		def.drawtype = "nodebox" |  | ||||||
| 		def.paramtype = "light" |  | ||||||
| 		def.paramtype2 = def.paramtype2 or "facedir" |  | ||||||
| 		def.on_place = minetest.rotate_node |  | ||||||
| 		def.description = desc |  | ||||||
| 		def.groups = stairsplus:prepare_groups(fields.groups, moreblocks.config.stairsplus_panels_not_in_creative_inventory) |  | ||||||
| 		if fields.drop and not (type(fields.drop) == "table") then |  | ||||||
| 			def.drop = modname.. ":panel_" ..fields.drop..alternate |  | ||||||
| 		end |  | ||||||
| 		minetest.register_node(":" ..modname.. ":panel_" ..subname..alternate, def) |  | ||||||
| 	end | 	end | ||||||
| 	minetest.register_alias(modname.. ":panel_" ..subname.. "_bottom", modname.. ":panel_" ..subname) |  | ||||||
|  |  | ||||||
| 	circular_saw.known_nodes[recipeitem] = {modname, subname} | 	circular_saw.known_nodes[recipeitem] = {modname, subname} | ||||||
|  |  | ||||||
| 	-- Some saw-less recipes: |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		output = modname .. ":panel_" .. subname .. " 12", |  | ||||||
| 		recipe = { |  | ||||||
| 			{recipeitem, ""}, |  | ||||||
| 			{recipeitem, recipeitem}, |  | ||||||
| 		}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		output = modname .. ":panel_" .. subname .. " 12", |  | ||||||
| 		recipe = { |  | ||||||
| 			{"", recipeitem}, |  | ||||||
| 			{recipeitem, recipeitem}, |  | ||||||
| 		}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":panel_" .. subname, |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, |  | ||||||
| 	}) |  | ||||||
| end | end | ||||||
|   | |||||||
							
								
								
									
										443
									
								
								stairsplus/recipes.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										443
									
								
								stairsplus/recipes.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,443 @@ | |||||||
|  | --[[ | ||||||
|  | More Blocks: Stairs+ | ||||||
|  |  | ||||||
|  | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
|  | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
|  | --]] | ||||||
|  |  | ||||||
|  |  | ||||||
|  | stairsplus.register_recipes = function(category, alternate, modname, subname, recipeitem) | ||||||
|  | 	if category == "micro" and alternate == "" then | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 7", | ||||||
|  | 			recipe = {modname .. ":stair_" .. subname .. "_inner"}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 6", | ||||||
|  | 			recipe = {modname .. ":stair_" .. subname}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 5", | ||||||
|  | 			recipe = {modname .. ":stair_" .. subname .. "_outer"}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 4", | ||||||
|  | 			recipe = {modname .. ":slab_" .. subname}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 4", | ||||||
|  | 			recipe = {modname .. ":stair_" .. subname .. "_alt"}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 3", | ||||||
|  | 			recipe = {modname .. ":stair_" .. subname .. "_right_half"}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":micro_" .. subname .. " 2", | ||||||
|  | 			recipe = {modname .. ":panel_" .. subname}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = recipeitem, | ||||||
|  | 			recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_alias(modname .. ":micro_" .. subname .. "_bottom", modname .. ":micro_" .. subname) | ||||||
|  | 	elseif category == "panel" and alternate == "" then | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			output = modname .. ":panel_" .. subname .. " 12", | ||||||
|  | 			recipe = { | ||||||
|  | 				{recipeitem, ""}, | ||||||
|  | 				{recipeitem, recipeitem}, | ||||||
|  | 			}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			output = modname .. ":panel_" .. subname .. " 12", | ||||||
|  | 			recipe = { | ||||||
|  | 				{"", recipeitem}, | ||||||
|  | 				{recipeitem, recipeitem}, | ||||||
|  | 			}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = modname .. ":panel_" .. subname, | ||||||
|  | 			recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_craft({ | ||||||
|  | 			type = "shapeless", | ||||||
|  | 			output = recipeitem, | ||||||
|  | 			recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_alias(modname.. ":panel_" ..subname.. "_bottom", modname.. ":panel_" ..subname) | ||||||
|  | 	elseif category == "slab" then | ||||||
|  | 		if alternate == "" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				output = modname .. ":slab_" .. subname .. " 6", | ||||||
|  | 				recipe = {{recipeitem, recipeitem, recipeitem}}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			-- uncomment this rule when conflict is no longer likely to happen | ||||||
|  | 			--	https://github.com/minetest/minetest/issues/2881 | ||||||
|  | 			-- minetest.register_craft({ | ||||||
|  | 			--	type = "shapeless", | ||||||
|  | 			--	output = modname .. ":slab_" .. subname, | ||||||
|  | 			--	recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, | ||||||
|  | 			-- }) | ||||||
|  |  | ||||||
|  | 			-- then remove these two | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe = {{modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe = { | ||||||
|  | 					{modname .. ":panel_" .. subname}, | ||||||
|  | 					{modname .. ":panel_" .. subname}, | ||||||
|  | 				}, | ||||||
|  | 			}) | ||||||
|  | 			------------------------------ | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname, modname .. ":slab_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. " 3", | ||||||
|  | 				recipe = {modname .. ":stair_" .. subname, modname .. ":stair_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer_half", modname .. ":slope_" .. subname .. "_inner_half"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer_cut_half", modname .. ":slope_" .. subname .. "_inner_cut_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_quarter" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_three_quarter", modname .. ":slab_" .. subname .. "_quarter"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_quarter", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_quarter", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_three_quarter" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_three_quarter", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname, modname .. ":slab_" .. subname .. "_quarter"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_three_quarter", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_three_quarter", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_2" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_14", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_2", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_14" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_14", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_three_quarter", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_14", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_15" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_15", modname .. ":slab_" .. subname .. "_1"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slab_" .. subname .. "_15", | ||||||
|  | 				recipe = {modname .. ":slab_" .. subname .. "_14", modname .. ":slab_" .. subname .. "_1"}, | ||||||
|  | 			}) | ||||||
|  | 		end | ||||||
|  | 	elseif category == "slope" then | ||||||
|  | 		if alternate == "" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname, modname .. ":slope_" .. subname}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_half" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half_raised"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half", | ||||||
|  | 					modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_outer" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer", modname .. ":slope_" .. subname .. "_inner"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_outer_half" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer_half", modname .. ":slope_" .. subname .. "_inner_half_raised"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_inner_half" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer_half_raised", modname .. ":slope_" .. subname .. "_inner_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_outer_cut" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer_cut", modname .. ":slope_" .. subname .. "_inner_cut"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_outer_cut_half" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_outer_cut_half", modname .. ":slope_" .. subname .. "_inner_cut_half_raised"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_cut" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = recipeitem, | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_cut", modname .. ":slope_" .. subname .. "_cut"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_half_raised" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slope_" .. subname .. "_half_raised", | ||||||
|  | 				recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half", | ||||||
|  | 					modname .. ":slope_" .. subname .. "_half"}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slope_" .. subname .. "_half_raised", | ||||||
|  | 				recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_inner_half_raised" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slope_" .. subname .. "_inner_half_raised", | ||||||
|  | 				recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_inner_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_outer_half_raised" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slope_" .. subname .. "_outer_half_raised", | ||||||
|  | 				recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_outer_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_inner_cut_half_raised" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":slope_" .. subname .. "_inner_cut_half_raised", | ||||||
|  | 				recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_inner_cut_half"}, | ||||||
|  | 			}) | ||||||
|  | 		end | ||||||
|  | 	elseif category == "stair" then | ||||||
|  | 		if alternate == "" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				output = modname .. ":stair_" .. subname .. " 8", | ||||||
|  | 				recipe = { | ||||||
|  | 					{recipeitem, "", ""}, | ||||||
|  | 					{recipeitem, recipeitem, ""}, | ||||||
|  | 					{recipeitem, recipeitem, recipeitem}, | ||||||
|  | 				}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				output = modname .. ":stair_" .. subname .. " 8", | ||||||
|  | 				recipe = { | ||||||
|  | 					{"", "", recipeitem}, | ||||||
|  | 					{"", recipeitem, recipeitem}, | ||||||
|  | 					{recipeitem, recipeitem, recipeitem}, | ||||||
|  | 				}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname, | ||||||
|  | 				recipe = {modname .. ":panel_" .. subname, modname .. ":slab_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname, | ||||||
|  | 				recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname, | ||||||
|  | 				recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname, | ||||||
|  | 				recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_inner" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_inner", | ||||||
|  | 				recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_outer" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_outer", | ||||||
|  | 				recipe = {modname .. ":micro_" .. subname, modname .. ":slab_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_outer", | ||||||
|  | 				recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_half" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_half", | ||||||
|  | 				recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_half", | ||||||
|  | 				recipe = {modname .. ":panel_" .. subname, modname .. ":micro_" .. subname}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_right_half" then | ||||||
|  | 			minetest.register_craft({ | ||||||
|  | 				type = "shapeless", | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_right_half", | ||||||
|  | 				recipe = {modname .. ":stair_" .. subname .. "_half"}, | ||||||
|  | 			}) | ||||||
|  | 		elseif alternate == "_alt" then | ||||||
|  | 			minetest.register_craft({ -- See mirrored variation of the recipe below. | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_alt", | ||||||
|  | 				recipe = { | ||||||
|  | 					{modname .. ":panel_" .. subname, ""}, | ||||||
|  | 					{""                            , modname .. ":panel_" .. subname}, | ||||||
|  | 				}, | ||||||
|  | 			}) | ||||||
|  |  | ||||||
|  | 			minetest.register_craft({ -- Mirrored variation of the recipe above. | ||||||
|  | 				output = modname .. ":stair_" .. subname .. "_alt", | ||||||
|  | 				recipe = { | ||||||
|  | 					{""                            , modname .. ":panel_" .. subname}, | ||||||
|  | 					{modname .. ":panel_" .. subname, ""}, | ||||||
|  | 				}, | ||||||
|  | 			}) | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  | end | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: registrations | More Blocks: registrations | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -71,6 +71,8 @@ for _, name in pairs(default_nodes) do | |||||||
| 	mod = "moreblocks" | 	mod = "moreblocks" | ||||||
| 	stairsplus:register_all(mod, name, nodename, ndef) | 	stairsplus:register_all(mod, name, nodename, ndef) | ||||||
| 	minetest.register_alias_force("stairs:stair_" .. name, mod .. ":stair_" .. name) | 	minetest.register_alias_force("stairs:stair_" .. name, mod .. ":stair_" .. name) | ||||||
|  | 	minetest.register_alias_force("stairs:stair_outer_" .. name, mod .. ":stair_" .. name .. "_outer") | ||||||
|  | 	minetest.register_alias_force("stairs:stair_inner_" .. name, mod .. ":stair_" .. name .. "_inner") | ||||||
| 	minetest.register_alias_force("stairs:slab_"  .. name, mod .. ":slab_"  .. name) | 	minetest.register_alias_force("stairs:slab_"  .. name, mod .. ":slab_"  .. name) | ||||||
| end | end | ||||||
|  |  | ||||||
| @@ -86,6 +88,8 @@ if minetest.get_modpath("farming") then | |||||||
| 		mod = "moreblocks" | 		mod = "moreblocks" | ||||||
| 		stairsplus:register_all(mod, name, nodename, ndef) | 		stairsplus:register_all(mod, name, nodename, ndef) | ||||||
| 		minetest.register_alias_force("stairs:stair_" .. name, mod .. ":stair_" .. name) | 		minetest.register_alias_force("stairs:stair_" .. name, mod .. ":stair_" .. name) | ||||||
|  | 		minetest.register_alias_force("stairs:stair_outer_" .. name, mod .. ":stair_" .. name .. "_outer") | ||||||
|  | 		minetest.register_alias_force("stairs:stair_inner_" .. name, mod .. ":stair_" .. name .. "_inner") | ||||||
| 		minetest.register_alias_force("stairs:slab_"  .. name, mod .. ":slab_"  .. name) | 		minetest.register_alias_force("stairs:slab_"  .. name, mod .. ":slab_"  .. name) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
| @@ -108,6 +112,36 @@ if minetest.get_modpath("wool") then | |||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | -- basic_materials, keeping the original other-mod-oriented names | ||||||
|  | -- for backwards compatibility | ||||||
|  |  | ||||||
|  | if minetest.get_modpath("basic_materials") then | ||||||
|  | 	stairsplus:register_all("technic","concrete","basic_materials:concrete_block",{ | ||||||
|  | 		description = "Concrete", | ||||||
|  | 		tiles = {"basic_materials_concrete_block.png",}, | ||||||
|  | 		groups = {cracky=1, level=2, concrete=1}, | ||||||
|  | 		sounds = default.node_sound_stone_defaults(), | ||||||
|  | 	}) | ||||||
|  |  | ||||||
|  | 	minetest.register_alias("prefab:concrete_stair","technic:stair_concrete") | ||||||
|  | 	minetest.register_alias("prefab:concrete_slab","technic:slab_concrete") | ||||||
|  |  | ||||||
|  | 	stairsplus:register_all("gloopblocks", "cement", "basic_materials:cement_block", { | ||||||
|  | 		description = "Cement", | ||||||
|  | 		tiles = {"basic_materials_cement_block.png"}, | ||||||
|  | 		groups = {cracky=2, not_in_creative_inventory=1}, | ||||||
|  | 		sounds = default.node_sound_stone_defaults(), | ||||||
|  | 		sunlight_propagates = true, | ||||||
|  | 	}) | ||||||
|  |  | ||||||
|  | 	stairsplus:register_all("technic", "brass_block", "basic_materials:brass_block", { | ||||||
|  | 		description="Brass Block", | ||||||
|  | 		groups={cracky=1, not_in_creative_inventory=1}, | ||||||
|  | 		tiles={"basic_materials_brass_block.png"}, | ||||||
|  | 	}) | ||||||
|  |  | ||||||
|  | end | ||||||
|  |  | ||||||
| -- Alias cuts of split_stone_tile_alt which was renamed checker_stone_tile. | -- Alias cuts of split_stone_tile_alt which was renamed checker_stone_tile. | ||||||
| stairsplus:register_alias_all("moreblocks", "split_stone_tile_alt", "moreblocks", "checker_stone_tile") | stairsplus:register_alias_all("moreblocks", "split_stone_tile_alt", "moreblocks", "checker_stone_tile") | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: slab definitions | More Blocks: slab definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -20,235 +20,26 @@ function register_slab(modname, subname, recipeitem, groups, images, description | |||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| local slabs_defs = { |  | ||||||
| 	[""] = 8, |  | ||||||
| 	["_quarter"] = 4, |  | ||||||
| 	["_three_quarter"] = 12, |  | ||||||
| 	["_1"] = 1, |  | ||||||
| 	["_2"] = 2, |  | ||||||
| 	["_14"] = 14, |  | ||||||
| 	["_15"] = 15, |  | ||||||
| 	["_two_sides"] = { |  | ||||||
| 						{ -0.5, -0.5, -0.5, 0.5, -7/16, 7/16 }, |  | ||||||
| 						{ -0.5, -0.5, 7/16, 0.5, 0.5, 0.5 } |  | ||||||
| 					}, |  | ||||||
| 	["_three_sides"] = { |  | ||||||
| 						{ -7/16, -0.5, -0.5, 0.5, -7/16, 7/16 }, |  | ||||||
| 						{ -7/16, -0.5, 7/16, 0.5, 0.5, 0.5 }, |  | ||||||
| 						{ -0.5, -0.5, -0.5, -7/16, 0.5, 0.5 } |  | ||||||
| 					}, |  | ||||||
| 	["_three_sides_u"] = { |  | ||||||
| 						{ -0.5, -0.5, -0.5, 0.5, 0.5, -7/16 }, |  | ||||||
| 						{ -0.5, -0.5, -7/16, 0.5, -7/16, 7/16 }, |  | ||||||
| 						{ -0.5, -0.5, 7/16, 0.5, 0.5, 0.5 } |  | ||||||
| 					} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| for k,v in pairs(slabs_defs) do |  | ||||||
| 	table.insert(stairsplus.shapes_list, { "slab_", k }) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function stairsplus:register_slab_alias(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_slab_alias(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(slabs_defs) | 	local defs = table.copy(stairsplus.defs["slab"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias(modname_old .. ":slab_" .. subname_old .. alternate, modname_new .. ":slab_" .. subname_new .. alternate) | 		minetest.register_alias(modname_old .. ":slab_" .. subname_old .. alternate, modname_new .. ":slab_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_slab_alias_force(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_slab_alias_force(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(slabs_defs) | 	local defs = table.copy(stairsplus.defs["slab"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias_force(modname_old .. ":slab_" .. subname_old .. alternate, modname_new .. ":slab_" .. subname_new .. alternate) | 		minetest.register_alias_force(modname_old .. ":slab_" .. subname_old .. alternate, modname_new .. ":slab_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_slab(modname, subname, recipeitem, fields) | function stairsplus:register_slab(modname, subname, recipeitem, fields) | ||||||
| 	local defs = stairsplus.copytable(slabs_defs) | 	local defs = table.copy(stairsplus.defs["slab"]) | ||||||
| 	local desc_base = S("%s Slab"):format(fields.description) | 	local desc_base = S("%s Slab"):format(fields.description) | ||||||
| 	for alternate, shape in pairs(defs) do | 	for alternate, shape in pairs(defs) do | ||||||
| 		local def = {} | 		stairsplus.register_single("slab", alternate, shape, modname, subname, recipeitem, fields) | ||||||
| 		for k, v in pairs(fields) do |  | ||||||
| 			def[k] = v |  | ||||||
| 		end |  | ||||||
| 		if type(shape) ~= "table" then |  | ||||||
| 			def.node_box = { |  | ||||||
| 						type = "fixed", |  | ||||||
| 						fixed = {-0.5, -0.5, -0.5, 0.5, (shape/16)-0.5, 0.5}, |  | ||||||
| 					} |  | ||||||
| 			def.description = ("%s (%d/16)"):format(desc_base, shape) |  | ||||||
| 		else |  | ||||||
| 			def.node_box = { |  | ||||||
| 					type = "fixed", |  | ||||||
| 					fixed = shape, |  | ||||||
| 				} |  | ||||||
| 			local desc_x = alternate:gsub("_", " ") |  | ||||||
| 			desc_x = desc_x:gsub("(%a)(%S*)", function(a, b) return a:upper() .. b end) |  | ||||||
| 			def.description = desc_base .. desc_x |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		def.drawtype = "nodebox" |  | ||||||
| 		def.paramtype = "light" |  | ||||||
| 		def.paramtype2 = def.paramtype2 or "facedir" |  | ||||||
| 		def.on_place = minetest.rotate_node |  | ||||||
| 		def.groups = stairsplus:prepare_groups(fields.groups, moreblocks.config.stairsplus_slabs_not_in_creative_inventory) |  | ||||||
| 		if alternate == "" then |  | ||||||
| 			def.groups.slab = 1 |  | ||||||
| 		end |  | ||||||
| 		if fields.drop and not (type(fields.drop) == "table") then |  | ||||||
| 			def.drop = modname.. ":slab_" .. fields.drop .. alternate |  | ||||||
| 		end |  | ||||||
| 		minetest.register_node(":" .. modname .. ":slab_" .. subname .. alternate, def) |  | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	circular_saw.known_nodes[recipeitem] = {modname, subname} | 	circular_saw.known_nodes[recipeitem] = {modname, subname} | ||||||
|  |  | ||||||
| 	-- Some saw-less recipes: |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			output = modname .. ":slab_" .. subname .. " 6", |  | ||||||
| 			recipe = {{recipeitem, recipeitem, recipeitem}}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname, |  | ||||||
| 			recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		-- uncomment this rule when conflict is no longer likely to happen |  | ||||||
| 		--	https://github.com/minetest/minetest/issues/2881 |  | ||||||
| 		-- minetest.register_craft({ |  | ||||||
| 		--	type = "shapeless", |  | ||||||
| 		--	output = modname .. ":slab_" .. subname, |  | ||||||
| 		--	recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, |  | ||||||
| 		-- }) |  | ||||||
|  |  | ||||||
| 		-- then remove these two |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			output = modname .. ":slab_" .. subname, |  | ||||||
| 			recipe = {{modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			output = modname .. ":slab_" .. subname, |  | ||||||
| 			recipe = { |  | ||||||
| 				{modname .. ":panel_" .. subname}, |  | ||||||
| 				{modname .. ":panel_" .. subname}, |  | ||||||
| 			}, |  | ||||||
| 		}) |  | ||||||
| 		------------------------------ |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = recipeitem, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname, modname .. ":slab_" .. subname}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = recipeitem, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = recipeitem, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = recipeitem, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_three_quarter", modname .. ":slab_" .. subname .. "_quarter"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = recipeitem, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_14", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = recipeitem, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_15", modname .. ":slab_" .. subname .. "_1"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname, |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_quarter", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_quarter", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_2", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_1", modname .. ":slab_" .. subname .. "_1"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_three_quarter", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname, modname .. ":slab_" .. subname .. "_quarter"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_three_quarter", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter", modname .. ":slab_" .. subname .. "_quarter"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_three_quarter", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_14", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_three_quarter", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_14", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2", modname .. ":slab_" .. subname .. "_2"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. "_15", |  | ||||||
| 			recipe = {modname .. ":slab_" .. subname .. "_14", modname .. ":slab_" .. subname .. "_1"}, |  | ||||||
| 		}) |  | ||||||
|  |  | ||||||
| 		minetest.register_craft({ |  | ||||||
| 			type = "shapeless", |  | ||||||
| 			output = modname .. ":slab_" .. subname .. " 3", |  | ||||||
| 			recipe = {modname .. ":stair_" .. subname, modname .. ":stair_" .. subname}, |  | ||||||
| 		}) |  | ||||||
| end | end | ||||||
|   | |||||||
| @@ -1,115 +1,12 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: slope definitions | More Blocks: slope definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| local S = moreblocks.intllib | local S = moreblocks.intllib | ||||||
|  |  | ||||||
| local box_slope = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5,  -0.5,  -0.5, 0.5, -0.25, 0.5}, |  | ||||||
| 		{-0.5, -0.25, -0.25, 0.5,     0, 0.5}, |  | ||||||
| 		{-0.5,     0,     0, 0.5,  0.25, 0.5}, |  | ||||||
| 		{-0.5,  0.25,  0.25, 0.5,   0.5, 0.5} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local box_slope_half = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5, -0.5,   -0.5,  0.5, -0.375, 0.5}, |  | ||||||
| 		{-0.5, -0.375, -0.25, 0.5, -0.25,  0.5}, |  | ||||||
| 		{-0.5, -0.25,  0,    0.5, -0.125, 0.5}, |  | ||||||
| 		{-0.5, -0.125, 0.25, 0.5,  0,     0.5}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local box_slope_half_raised = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5, -0.5,   -0.5,  0.5, 0.125, 0.5}, |  | ||||||
| 		{-0.5, 0.125, -0.25, 0.5, 0.25,  0.5}, |  | ||||||
| 		{-0.5, 0.25,  0,    0.5, 0.375, 0.5}, |  | ||||||
| 		{-0.5, 0.375, 0.25, 0.5,  0.5,     0.5}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| --============================================================== |  | ||||||
|  |  | ||||||
| local box_slope_inner = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5}, |  | ||||||
| 		{-0.5, -0.5, -0.25, 0.5, 0, 0.5}, |  | ||||||
| 		{-0.5, -0.5, -0.5, 0.25, 0, 0.5}, |  | ||||||
| 		{-0.5, 0, -0.5, 0, 0.25, 0.5}, |  | ||||||
| 		{-0.5, 0, 0, 0.5, 0.25, 0.5}, |  | ||||||
| 		{-0.5, 0.25, 0.25, 0.5, 0.5, 0.5}, |  | ||||||
| 		{-0.5, 0.25, -0.5, -0.25, 0.5, 0.5}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local box_slope_inner_half = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5, -0.5, -0.5, 0.5, -0.375, 0.5}, |  | ||||||
| 		{-0.5, -0.375, -0.25, 0.5, -0.25, 0.5}, |  | ||||||
| 		{-0.5, -0.375, -0.5, 0.25, -0.25, 0.5}, |  | ||||||
| 		{-0.5, -0.25, -0.5, 0, -0.125, 0.5}, |  | ||||||
| 		{-0.5, -0.25, 0, 0.5, -0.125, 0.5}, |  | ||||||
| 		{-0.5, -0.125, 0.25, 0.5, 0, 0.5}, |  | ||||||
| 		{-0.5, -0.125, -0.5, -0.25, 0, 0.5}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local box_slope_inner_half_raised = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5, -0.5, -0.5, 0.5, 0.125, 0.5}, |  | ||||||
| 		{-0.5, 0.125, -0.25, 0.5, 0.25, 0.5}, |  | ||||||
| 		{-0.5, 0.125, -0.5, 0.25, 0.25, 0.5}, |  | ||||||
| 		{-0.5, 0.25, -0.5, 0, 0.375, 0.5}, |  | ||||||
| 		{-0.5, 0.25, 0, 0.5, 0.375, 0.5}, |  | ||||||
| 		{-0.5, 0.375, 0.25, 0.5, 0.5, 0.5}, |  | ||||||
| 		{-0.5, 0.375, -0.5, -0.25, 0.5, 0.5}, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| --============================================================== |  | ||||||
|  |  | ||||||
| local box_slope_outer = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5,  -0.5,  -0.5,   0.5, -0.25, 0.5}, |  | ||||||
| 		{-0.5, -0.25, -0.25,  0.25,     0, 0.5}, |  | ||||||
| 		{-0.5,     0,     0,     0,  0.25, 0.5}, |  | ||||||
| 		{-0.5,  0.25,  0.25, -0.25,   0.5, 0.5} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local box_slope_outer_half = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5,  -0.5,  -0.5,   0.5, -0.375, 0.5}, |  | ||||||
| 		{-0.5, -0.375, -0.25,  0.25, -0.25, 0.5}, |  | ||||||
| 		{-0.5,  -0.25,     0,     0, -0.125, 0.5}, |  | ||||||
| 		{-0.5,  -0.125,  0.25, -0.25, 0, 0.5} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local box_slope_outer_half_raised = { |  | ||||||
| 	type = "fixed", |  | ||||||
| 	fixed = { |  | ||||||
| 		{-0.5,  -0.5,  -0.5,   0.5, 0.125, 0.5}, |  | ||||||
| 		{-0.5, 0.125, -0.25,  0.25, 0.25, 0.5}, |  | ||||||
| 		{-0.5,  0.25,     0,     0, 0.375, 0.5}, |  | ||||||
| 		{-0.5,  0.375,  0.25, -0.25, 0.5, 0.5} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| -- Node will be called <modname>:slope_<subname> | -- Node will be called <modname>:slope_<subname> | ||||||
|  |  | ||||||
| function register_slope(modname, subname, recipeitem, groups, images, description, drop, light) | function register_slope(modname, subname, recipeitem, groups, images, description, drop, light) | ||||||
| @@ -123,244 +20,25 @@ function register_slope(modname, subname, recipeitem, groups, images, descriptio | |||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| local slopes_defs = { |  | ||||||
| 	[""] = { |  | ||||||
| 		mesh = "moreblocks_slope.obj", |  | ||||||
| 		collision_box = box_slope, |  | ||||||
| 		selection_box = box_slope, |  | ||||||
|  |  | ||||||
| 	}, |  | ||||||
| 	["_half"] = { |  | ||||||
| 		mesh = "moreblocks_slope_half.obj", |  | ||||||
| 		collision_box = box_slope_half, |  | ||||||
| 		selection_box = box_slope_half, |  | ||||||
| 	}, |  | ||||||
| 	["_half_raised"] = { |  | ||||||
| 		mesh = "moreblocks_slope_half_raised.obj", |  | ||||||
| 		collision_box = box_slope_half_raised, |  | ||||||
| 		selection_box = box_slope_half_raised, |  | ||||||
| 	}, |  | ||||||
|  |  | ||||||
| 	--============================================================== |  | ||||||
|  |  | ||||||
| 	["_inner"] = { |  | ||||||
| 		mesh = "moreblocks_slope_inner.obj", |  | ||||||
| 		collision_box = box_slope_inner, |  | ||||||
| 		selection_box = box_slope_inner, |  | ||||||
| 	}, |  | ||||||
| 	["_inner_half"] = { |  | ||||||
| 		mesh = "moreblocks_slope_inner_half.obj", |  | ||||||
| 		collision_box = box_slope_inner_half, |  | ||||||
| 		selection_box = box_slope_inner_half, |  | ||||||
| 	}, |  | ||||||
| 	["_inner_half_raised"] = { |  | ||||||
| 		mesh = "moreblocks_slope_inner_half_raised.obj", |  | ||||||
| 		collision_box = box_slope_inner_half_raised, |  | ||||||
| 		selection_box = box_slope_inner_half_raised, |  | ||||||
| 	}, |  | ||||||
|  |  | ||||||
| 	--============================================================== |  | ||||||
|  |  | ||||||
| 	["_inner_cut"] = { |  | ||||||
| 		mesh = "moreblocks_slope_inner_cut.obj", |  | ||||||
| 		collision_box = box_slope_inner, |  | ||||||
| 		selection_box = box_slope_inner, |  | ||||||
| 	}, |  | ||||||
| 	["_inner_cut_half"] = { |  | ||||||
| 		mesh = "moreblocks_slope_inner_cut_half.obj", |  | ||||||
| 		collision_box = box_slope_inner_half, |  | ||||||
| 		selection_box = box_slope_inner_half, |  | ||||||
| 	}, |  | ||||||
| 	["_inner_cut_half_raised"] = { |  | ||||||
| 		mesh = "moreblocks_slope_inner_cut_half_raised.obj", |  | ||||||
| 		collision_box = box_slope_inner_half_raised, |  | ||||||
| 		selection_box = box_slope_inner_half_raised, |  | ||||||
| 	}, |  | ||||||
|  |  | ||||||
| 	--============================================================== |  | ||||||
|  |  | ||||||
| 	["_outer"] = { |  | ||||||
| 		mesh = "moreblocks_slope_outer.obj", |  | ||||||
| 		collision_box = box_slope_outer, |  | ||||||
| 		selection_box = box_slope_outer, |  | ||||||
| 	}, |  | ||||||
| 	["_outer_half"] = { |  | ||||||
| 		mesh = "moreblocks_slope_outer_half.obj", |  | ||||||
| 		collision_box = box_slope_outer_half, |  | ||||||
| 		selection_box = box_slope_outer_half, |  | ||||||
| 	}, |  | ||||||
| 	["_outer_half_raised"] = { |  | ||||||
| 		mesh = "moreblocks_slope_outer_half_raised.obj", |  | ||||||
| 		collision_box = box_slope_outer_half_raised, |  | ||||||
| 		selection_box = box_slope_outer_half_raised, |  | ||||||
| 	}, |  | ||||||
|  |  | ||||||
| 	--============================================================== |  | ||||||
|  |  | ||||||
| 	["_outer_cut"] = { |  | ||||||
| 		mesh = "moreblocks_slope_outer_cut.obj", |  | ||||||
| 		collision_box = box_slope_outer, |  | ||||||
| 		selection_box = box_slope_outer, |  | ||||||
| 	}, |  | ||||||
| 	["_outer_cut_half"] = { |  | ||||||
| 		mesh = "moreblocks_slope_outer_cut_half.obj", |  | ||||||
| 		collision_box = box_slope_outer_half, |  | ||||||
| 		selection_box = box_slope_outer_half, |  | ||||||
| 	}, |  | ||||||
| 	["_outer_cut_half_raised"] = { |  | ||||||
| 		mesh = "moreblocks_slope_outer_cut_half_raised.obj", |  | ||||||
| 		collision_box = box_slope_outer_half_raised, |  | ||||||
| 		selection_box = box_slope_outer_half_raised, |  | ||||||
| 	}, |  | ||||||
| 	["_cut"] = { |  | ||||||
| 		mesh = "moreblocks_slope_cut.obj", |  | ||||||
| 		collision_box = box_slope_outer, |  | ||||||
| 		selection_box = box_slope_outer, |  | ||||||
| 	}, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| for k,v in pairs(slopes_defs) do |  | ||||||
| 	table.insert(stairsplus.shapes_list, { "slope_", k }) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function stairsplus:register_slope_alias(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_slope_alias(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(slopes_defs) | 	local defs = table.copy(stairsplus.defs["slope"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias(modname_old .. ":slope_" .. subname_old .. alternate, modname_new .. ":slope_" .. subname_new .. alternate) | 		minetest.register_alias(modname_old .. ":slope_" .. subname_old .. alternate, modname_new .. ":slope_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_slope_alias_force(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_slope_alias_force(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(slopes_defs) | 	local defs = table.copy(stairsplus.defs["slope"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias_force(modname_old .. ":slope_" .. subname_old .. alternate, modname_new .. ":slope_" .. subname_new .. alternate) | 		minetest.register_alias_force(modname_old .. ":slope_" .. subname_old .. alternate, modname_new .. ":slope_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_slope(modname, subname, recipeitem, fields) | function stairsplus:register_slope(modname, subname, recipeitem, fields) | ||||||
| 	local defs = stairsplus.copytable(slopes_defs) | 	local defs = table.copy(stairsplus.defs["slope"]) | ||||||
| 	local desc = S("%s Slope"):format(fields.description) |  | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		for k, v in pairs(fields) do | 		stairsplus.register_single("slope", alternate, def, modname, subname, recipeitem, fields) | ||||||
| 			def[k] = v |  | ||||||
| 		end |  | ||||||
| 		def.drawtype = "mesh" |  | ||||||
| 		def.paramtype = "light" |  | ||||||
| 		def.paramtype2 = def.paramtype2 or "facedir" |  | ||||||
| 		def.on_place = minetest.rotate_node |  | ||||||
| 		def.description = desc |  | ||||||
| 		def.groups = stairsplus:prepare_groups(fields.groups, moreblocks.config.stairsplus_slopes_not_in_creative_inventory) |  | ||||||
| 		if fields.drop and not (type(fields.drop) == "table") then |  | ||||||
| 			def.drop = modname.. ":slope_" ..fields.drop..alternate |  | ||||||
| 		end |  | ||||||
| 		minetest.register_node(":" ..modname.. ":slope_" ..subname..alternate, def) |  | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	circular_saw.known_nodes[recipeitem] = {modname, subname} | 	circular_saw.known_nodes[recipeitem] = {modname, subname} | ||||||
|  |  | ||||||
| 	-- Some saw-less recipes: |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname, modname .. ":slope_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half_raised"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half", |  | ||||||
| 				   modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer", modname .. ":slope_" .. subname .. "_inner"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer_half", modname .. ":slope_" .. subname .. "_inner_half_raised"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer_half_raised", modname .. ":slope_" .. subname .. "_inner_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer_cut", modname .. ":slope_" .. subname .. "_inner_cut"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer_cut_half", modname .. ":slope_" .. subname .. "_inner_cut_half_raised"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = recipeitem, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_cut", modname .. ":slope_" .. subname .. "_cut"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slab_" .. subname, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slab_" .. subname, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer_half", modname .. ":slope_" .. subname .. "_inner_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slab_" .. subname, |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_outer_cut_half", modname .. ":slope_" .. subname .. "_inner_cut_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slope_" .. subname .. "_half_raised", |  | ||||||
| 		recipe =  {modname .. ":slope_" .. subname .. "_half", modname .. ":slope_" .. subname .. "_half", |  | ||||||
| 				   modname .. ":slope_" .. subname .. "_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slope_" .. subname .. "_half_raised", |  | ||||||
| 		recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slope_" .. subname .. "_inner_half_raised", |  | ||||||
| 		recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_inner_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slope_" .. subname .. "_outer_half_raised", |  | ||||||
| 		recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_outer_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":slope_" .. subname .. "_inner_cut_half_raised", |  | ||||||
| 		recipe =  {modname .. ":slab_" .. subname, modname .. ":slope_" .. subname .. "_inner_cut_half"}, |  | ||||||
| 	}) |  | ||||||
| end | end | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| --[[ | --[[ | ||||||
| More Blocks: stair definitions | More Blocks: stair definitions | ||||||
|  |  | ||||||
| Copyright (c) 2011-2017 Hugo Locurcio and contributors. | Copyright (c) 2011-2018 Hugo Locurcio and contributors. | ||||||
| Licensed under the zlib license. See LICENSE.md for more information. | Licensed under the zlib license. See LICENSE.md for more information. | ||||||
| --]] | --]] | ||||||
|  |  | ||||||
| @@ -20,226 +20,25 @@ function register_stair(modname, subname, recipeitem, groups, images, descriptio | |||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| local stairs_defs = { |  | ||||||
| 	[""] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, |  | ||||||
| 				{-0.5, 0, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_half"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.5, -0.5, 0, 0, 0.5}, |  | ||||||
| 				{-0.5, 0, 0, 0, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_right_half" ]= { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{0, -0.5, -0.5, 0.5, 0, 0.5}, |  | ||||||
| 				{0, 0, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_inner"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, |  | ||||||
| 				{-0.5, 0, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 				{-0.5, 0, -0.5, 0, 0.5, 0}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_outer"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.5, -0.5, 0.5, 0, 0.5}, |  | ||||||
| 				{-0.5, 0, 0, 0, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_alt"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.5, -0.5, 0.5, 0, 0}, |  | ||||||
| 				{-0.5, 0, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_alt_1"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.0625, -0.5, 0.5, 0, 0}, |  | ||||||
| 				{-0.5, 0.4375, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_alt_2"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.125, -0.5, 0.5, 0, 0}, |  | ||||||
| 				{-0.5, 0.375, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	["_alt_4"] = { |  | ||||||
| 		node_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = { |  | ||||||
| 				{-0.5, -0.25, -0.5, 0.5, 0, 0}, |  | ||||||
| 				{-0.5, 0.25, 0, 0.5, 0.5, 0.5}, |  | ||||||
| 			}, |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| for k,v in pairs(stairs_defs) do |  | ||||||
| 	table.insert(stairsplus.shapes_list, { "stair_", k }) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function stairsplus:register_stair_alias(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_stair_alias(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(stairs_defs) | 	local defs = table.copy(stairsplus.defs["stair"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias(modname_old .. ":stair_" .. subname_old .. alternate, modname_new .. ":stair_" .. subname_new .. alternate) | 		minetest.register_alias(modname_old .. ":stair_" .. subname_old .. alternate, modname_new .. ":stair_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_stair_alias_force(modname_old, subname_old, modname_new, subname_new) | function stairsplus:register_stair_alias_force(modname_old, subname_old, modname_new, subname_new) | ||||||
| 	local defs = stairsplus.copytable(stairs_defs) | 	local defs = table.copy(stairsplus.defs["stair"]) | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		minetest.register_alias_force(modname_old .. ":stair_" .. subname_old .. alternate, modname_new .. ":stair_" .. subname_new .. alternate) | 		minetest.register_alias_force(modname_old .. ":stair_" .. subname_old .. alternate, modname_new .. ":stair_" .. subname_new .. alternate) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| function stairsplus:register_stair(modname, subname, recipeitem, fields) | function stairsplus:register_stair(modname, subname, recipeitem, fields) | ||||||
| 	local defs = stairsplus.copytable(stairs_defs) | 	local defs = table.copy(stairsplus.defs["stair"]) | ||||||
| 	local desc = S("%s Stairs"):format(fields.description) |  | ||||||
| 	for alternate, def in pairs(defs) do | 	for alternate, def in pairs(defs) do | ||||||
| 		for k, v in pairs(fields) do | 		stairsplus.register_single("stair", alternate, def, modname, subname, recipeitem, fields) | ||||||
| 			def[k] = v |  | ||||||
| 		end |  | ||||||
| 		def.drawtype = "nodebox" |  | ||||||
| 		def.paramtype = "light" |  | ||||||
| 		def.paramtype2 = def.paramtype2 or "facedir" |  | ||||||
| 		def.on_place = minetest.rotate_node |  | ||||||
| 		def.description = desc |  | ||||||
| 		def.groups = stairsplus:prepare_groups(fields.groups, moreblocks.config.stairsplus_stairs_not_in_creative_inventory) |  | ||||||
| 		if alternate == "" then |  | ||||||
| 			def.groups.stair = 1 |  | ||||||
| 		end |  | ||||||
| 		if fields.drop and not (type(fields.drop) == "table") then |  | ||||||
| 			def.drop = modname .. ":stair_" .. fields.drop .. alternate |  | ||||||
| 		end |  | ||||||
| 		minetest.register_node(":" .. modname .. ":stair_" .. subname .. alternate, def) |  | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	circular_saw.known_nodes[recipeitem] = {modname, subname} | 	circular_saw.known_nodes[recipeitem] = {modname, subname} | ||||||
|  |  | ||||||
| 	-- Some saw-less recipes: |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		output = modname .. ":stair_" .. subname .. " 8", |  | ||||||
| 		recipe = { |  | ||||||
| 			{recipeitem, "", ""}, |  | ||||||
| 			{recipeitem, recipeitem, ""}, |  | ||||||
| 			{recipeitem, recipeitem, recipeitem}, |  | ||||||
| 		}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		output = modname .. ":stair_" .. subname .. " 8", |  | ||||||
| 		recipe = { |  | ||||||
| 			{"", "", recipeitem}, |  | ||||||
| 			{"", recipeitem, recipeitem}, |  | ||||||
| 			{recipeitem, recipeitem, recipeitem}, |  | ||||||
| 		}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname, |  | ||||||
| 		recipe = {modname .. ":panel_" .. subname, modname .. ":slab_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname, |  | ||||||
| 		recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_outer", |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":slab_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_half", |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_half", |  | ||||||
| 		recipe = {modname .. ":panel_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_right_half", |  | ||||||
| 		recipe = {modname .. ":stair_" .. subname .. "_half"}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname, |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_inner", |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_outer", |  | ||||||
| 		recipe = {modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname, modname .. ":micro_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = modname .. ":stair_" .. subname, |  | ||||||
| 		recipe = {modname .. ":panel_" .. subname, modname .. ":panel_" .. subname, modname .. ":panel_" .. subname}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ -- See mirrored variation of the recipe below. |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_alt", |  | ||||||
| 		recipe = { |  | ||||||
| 			{modname .. ":panel_" .. subname, ""}, |  | ||||||
| 			{""                            , modname .. ":panel_" .. subname}, |  | ||||||
| 		}, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.register_craft({ -- Mirrored variation of the recipe above. |  | ||||||
| 		output = modname .. ":stair_" .. subname .. "_alt", |  | ||||||
| 		recipe = { |  | ||||||
| 			{""                            , modname .. ":panel_" .. subname}, |  | ||||||
| 			{modname .. ":panel_" .. subname, ""}, |  | ||||||
| 		}, |  | ||||||
| 	}) |  | ||||||
| end | end | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user