summaryrefslogtreecommitdiff
path: root/moreblocks/stairsplus/stairs.lua
diff options
context:
space:
mode:
Diffstat (limited to 'moreblocks/stairsplus/stairs.lua')
-rw-r--r--moreblocks/stairsplus/stairs.lua209
1 files changed, 4 insertions, 205 deletions
diff --git a/moreblocks/stairsplus/stairs.lua b/moreblocks/stairsplus/stairs.lua
index 815f7ac..5c38864 100644
--- a/moreblocks/stairsplus/stairs.lua
+++ b/moreblocks/stairsplus/stairs.lua
@@ -20,226 +20,25 @@ function register_stair(modname, subname, recipeitem, groups, images, descriptio
})
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)
- local defs = stairsplus.copytable(stairs_defs)
+ local defs = table.copy(stairsplus.defs["stair"])
for alternate, def in pairs(defs) do
minetest.register_alias(modname_old .. ":stair_" .. subname_old .. alternate, modname_new .. ":stair_" .. subname_new .. alternate)
end
end
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
minetest.register_alias_force(modname_old .. ":stair_" .. subname_old .. alternate, modname_new .. ":stair_" .. subname_new .. alternate)
end
end
function stairsplus:register_stair(modname, subname, recipeitem, fields)
- local defs = stairsplus.copytable(stairs_defs)
- local desc = S("%s Stairs"):format(fields.description)
+ local defs = table.copy(stairsplus.defs["stair"])
for alternate, def in pairs(defs) do
- for k, v in pairs(fields) do
- 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)
- 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)
+ stairsplus.register_single("stair", alternate, def, modname, subname, recipeitem, fields)
end
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