MineClonia/MineClone2 Support (#22)

This commit is contained in:
Github is a non-free platform owned by Microsoft. Reasonable alternatives exist, such as Gitea, Sourcehut. We need a federated, mastodon-like forge based on ForgeFed. See: https://forgefed.org 2023-11-28 20:27:22 +01:00 committed by GitHub
parent be330097a8
commit c382515bca
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 206 additions and 103 deletions

View File

@ -12,6 +12,8 @@ castle_masonry.register_arrowslit = function(material)
description = S("@1 Arrowslit", desc), description = S("@1 Arrowslit", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -33,6 +35,8 @@ castle_masonry.register_arrowslit = function(material)
description = S("@1 Arrowslit with Cross", desc), description = S("@1 Arrowslit with Cross", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -58,6 +62,8 @@ castle_masonry.register_arrowslit = function(material)
description = S("@1 Arrowslit with Hole", desc), description = S("@1 Arrowslit with Hole", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -81,6 +87,8 @@ castle_masonry.register_arrowslit = function(material)
description = S("@1 Embrasure", desc), description = S("@1 Embrasure", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",

102
init.lua
View File

@ -1,6 +1,17 @@
castle_masonry = {} castle_masonry = {}
castle_masonry.sounds = {}
if minetest.get_modpath("default") then
castle_masonry.sounds = default
end
if minetest.get_modpath("mcl_sounds") then
castle_masonry.sounds = mcl_sounds
end
local MP = minetest.get_modpath(minetest.get_current_modname()) local MP = minetest.get_modpath(minetest.get_current_modname())
dofile(MP.."/pillars.lua") dofile(MP.."/pillars.lua")
dofile(MP.."/arrow_slits.lua") dofile(MP.."/arrow_slits.lua")
dofile(MP.."/murder_holes.lua") dofile(MP.."/murder_holes.lua")
@ -12,7 +23,7 @@ local S = minetest.get_translator("castle_masonry")
local read_setting = function(name, default) local read_setting = function(name, default)
local setting = minetest.settings:get_bool(name) local setting = minetest.settings:get_bool(name)
if setting == nil then return default end if not setting then return default end
return setting return setting
end end
@ -26,55 +37,58 @@ end
--} --}
castle_masonry.materials = {} castle_masonry.materials = {}
if read_setting("castle_masonry_stonewall", true) then
table.insert(castle_masonry.materials, {name="stonewall", desc=S("Stonewall"), tile="castle_stonewall.png", craft_material="castle_masonry:stonewall"}) local function register_material(def, setting_default)
if read_setting("castle_masonry_" .. def.name, setting_default) then
table.insert(castle_masonry.materials, def)
end
end end
if read_setting("castle_masonry_cobble", true) then
table.insert(castle_masonry.materials, {name="cobble", desc=S("Cobble"), tile="default_cobble.png", craft_material="default:cobble"}) -- castle masonry materials
register_material({name="stonewall", desc=S("Stonewall"), tile="castle_stonewall.png", craft_material="castle_masonry:stonewall"}, true)
-- MTG materials
if minetest.get_modpath("default") then
register_material({name="cobble", desc=S("Cobble"), tile="default_cobble.png", craft_material="default:cobble"}, true)
register_material({name="stonebrick", desc=S("Stonebrick"), tile="default_stone_brick.png", craft_material="default:stonebrick"}, true)
register_material({name="stone", desc=S("Stone"), tile="default_stone.png", craft_material="default:stone"}, true)
register_material({name="wood", desc=S("Wood"), tile="default_wood.png", craft_material="group:wood", composition_material="default:wood"})
register_material({name="ice", desc=S("Ice"), tile="default_ice.png", craft_material="default:ice"})
register_material({name="snow", desc=S("Snow"), tile="default_snow.png", craft_material="default:snow"})
register_material({name="sandstone", desc=S("Sandstone"), tile="default_sandstone.png", craft_material="default:sandstone"}, true)
register_material({name="sandstonebrick", desc=S("Sandstone Brick"), tile="default_sandstone_brick.png", craft_material="default:sandstonebrick"}, true)
register_material({name="desertstonebrick", desc=S("Desert Stone Brick"), tile="default_desert_stone_brick.png", craft_material="default:desert_stonebrick"}, true)
register_material({name="desertsandstonebrick", desc=S("Desert Sandstone Brick"), tile="default_desert_sandstone_brick.png", craft_material="default:desert_sandstone_brick"}, true)
register_material({name="silversandstonebrick", desc=S("Silver Sandstone Brick"), tile="default_silver_sandstone_brick.png", craft_material="default:silver_sandstone_brick"}, true)
register_material({name="desertstone", desc=S("Desert Stone"), tile="default_desert_stone.png", craft_material="default:desert_stone"}, true)
register_material({name="desertsandstone", desc=S("Desert Sandstone"), tile="default_desert_sandstone.png", craft_material="default:desert_sandstone"}, true)
register_material({name="silversandstone", desc=S("Silver Sandstone"), tile="default_silver_sandstone.png", craft_material="default:silver_sandstone"}, true)
register_material({name="obsidianbrick", desc=S("Obsidian Brick"), tile="default_obsidian_brick.png", craft_material="default:obsidianbrick"})
end end
if read_setting("castle_masonry_stonebrick", true) then
table.insert(castle_masonry.materials, {name="stonebrick", desc=S("Stonebrick"), tile="default_stone_brick.png", craft_material="default:stonebrick"}) -- MCL materials
if minetest.get_modpath("mcl_core") then
register_material({name="cobble", desc=S("Cobble"), craft_material="group:cobble", composition_material="mcl_core:cobble"}, true)
register_material({name="stonebrick", desc=S("Stonebrick"), craft_material="mcl_core:stonebrick"}, true)
register_material({name="stone", desc=S("Stone"), craft_material="group:stone", composition_material="mcl_core:stone"}, true)
register_material({name="wood", desc=S("Wood"), craft_material="group:wood", composition_material="mcl_core:wood"})
register_material({name="ice", desc=S("Ice"), craft_material="mcl_core:ice"})
register_material({name="snow", desc=S("Snow"), craft_material="mcl_core:snowblock"})
register_material({name="sandstone", desc=S("Sandstone"), craft_material="mcl_core:sandstone"}, true)
register_material({name="redsandstone", desc=S("Red Sandstone"), craft_material="mcl_core:redsandstone"}, true)
end end
if read_setting("castle_masonry_sandstonebrick", true) then if minetest.get_modpath("mcl_nether") then
table.insert(castle_masonry.materials, {name="sandstonebrick", desc=S("Sandstone Brick"), tile="default_sandstone_brick.png", craft_material="default:sandstonebrick"}) register_material({name="quartz", desc=S("Quartz"), craft_material="mcl_nether:quartz_block"}, true)
end end
if read_setting("castle_masonry_desertstonebrick", true) then if minetest.get_modpath("mcl_blackstone") then
table.insert(castle_masonry.materials, {name="desertstonebrick", desc=S("Desert Stone Brick"), tile="default_desert_stone_brick.png", craft_material="default:desert_stonebrick"}) register_material({name="blackstone", desc=S("Blackstone"), craft_material="mcl_blackstone:blackstone_brick_polished"}, true)
end end
if read_setting("castle_masonry_desertsandstonebrick", true) then if minetest.get_modpath("mcl_deepslate") then
table.insert(castle_masonry.materials, {name="desertsandstonebrick", desc=S("Desert Sandstone Brick"), tile="default_desert_sandstone_brick.png", craft_material="default:desert_sandstone_brick"}) register_material({name="deepslate_bricks", desc=S("Deepslate Bricks"), craft_material="mcl_deepslate:deepslate_bricks"}, true)
end register_material({name="deepslate_tiles", desc=S("Deepslate Tiles"), craft_material="mcl_deepslate:deepslate_tiles"}, true)
if read_setting("castle_masonry_silversandstonebrick", true) then
table.insert(castle_masonry.materials, {name="silversandstonebrick", desc=S("Silver Sandstone Brick"), tile="default_silver_sandstone_brick.png", craft_material="default:silver_sandstone_brick"})
end
if read_setting("castle_masonry_stone", true) then
table.insert(castle_masonry.materials, {name="stone", desc=S("Stone"), tile="default_stone.png", craft_material="default:stone"})
end
if read_setting("castle_masonry_sandstone", true) then
table.insert(castle_masonry.materials, {name="sandstone", desc=S("Sandstone"), tile="default_sandstone.png", craft_material="default:sandstone"})
end
if read_setting("castle_masonry_desertstone", true) then
table.insert(castle_masonry.materials, {name="desertstone", desc=S("Desert Stone"), tile="default_desert_stone.png", craft_material="default:desert_stone"})
end
if read_setting("castle_masonry_desertsandstone", true) then
table.insert(castle_masonry.materials, {name="desertsandstone", desc=S("Desert Sandstone"), tile="default_desert_sandstone.png", craft_material="default:desert_sandstone"})
end
if read_setting("castle_masonry_silversandstone", true) then
table.insert(castle_masonry.materials, {name="silversandstone", desc=S("Silver Sandstone"), tile="default_silver_sandstone.png", craft_material="default:silver_sandstone"})
end
if read_setting("castle_masonry_wood", false) then
table.insert(castle_masonry.materials, {name="wood", desc=S("Wood"), tile="default_wood.png", craft_material="group:wood", composition_material="default:wood"})
end
if read_setting("castle_masonry_ice", false) then
table.insert(castle_masonry.materials, {name="ice", desc=S("Ice"), tile="default_ice.png", craft_material="default:ice"})
end
if read_setting("castle_masonry_snow", false) then
table.insert(castle_masonry.materials, {name="snow", desc=S("Snow"), tile="default_snow.png", craft_material="default:snow"})
end
if read_setting("castle_masonry_obsidianbrick", false) then
table.insert(castle_masonry.materials, {name="obsidianbrick", desc=S("Obsidian Brick"), tile="default_obsidian_brick.png", craft_material="default:obsidianbrick"})
end end
castle_masonry.get_material_properties = function(material) castle_masonry.get_material_properties = function(material)
local composition_def local composition_def
local burn_time local burn_time
@ -88,7 +102,7 @@ castle_masonry.get_material_properties = function(material)
local tiles = material.tile local tiles = material.tile
if tiles == nil then if tiles == nil then
tiles = composition_def.tile tiles = composition_def.tiles
elseif type(tiles) == "string" then elseif type(tiles) == "string" then
tiles = {tiles} tiles = {tiles}
end end

View File

@ -1,6 +1,6 @@
name = castle_masonry name = castle_masonry
depends = default depends =
optional_depends = moreblocks, stairs, building_blocks, asphalt, streets optional_depends = default, mcl_core, mcl_sounds, mcl_nether, mcl_deepslate, mcl_blackstone, mcl_stairs, moreblocks, stairs, building_blocks, asphalt, streets
description = """ description = """
This is a mod all about creating castles and castle dungeons. This is a mod all about creating castles and castle dungeons.
Many of the nodes are used for the outer-walls or dungeons. Many of the nodes are used for the outer-walls or dungeons.

View File

@ -13,6 +13,8 @@ castle_masonry.register_murderhole = function(material)
description = S("@1 Murder Hole", desc), description = S("@1 Murder Hole", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -32,6 +34,8 @@ castle_masonry.register_murderhole = function(material)
description = S("@1 Machicolation", desc), description = S("@1 Machicolation", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",

View File

@ -10,16 +10,18 @@ minetest.register_node("castle_masonry:pavement_brick", {
description = S("Paving Stone"), description = S("Paving Stone"),
drawtype = "normal", drawtype = "normal",
tiles = {"castle_pavement_brick.png"}, tiles = {"castle_pavement_brick.png"},
groups = {cracky=2}, groups = {cracky=2, pickaxey=2},
_mcl_hardness = 1,
_mcl_blast_resistance = 1,
paramtype = "light", paramtype = "light",
sounds = default.node_sound_stone_defaults(), sounds = castle_masonry.sounds.node_sound_stone_defaults(),
}) })
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:pavement_brick 4", output = "castle_masonry:pavement_brick 4",
recipe = { recipe = {
{"default:stone", "default:cobble"}, {"group:stone", "group:cobble"},
{"default:cobble", "default:stone"}, {"group:cobble", "group:stone"},
} }
}) })
@ -28,18 +30,26 @@ if minetest.get_modpath("moreblocks") then
stairsplus:register_all("castle_masonry", "pavement_brick", "castle_masonry:pavement_brick", { stairsplus:register_all("castle_masonry", "pavement_brick", "castle_masonry:pavement_brick", {
description = S("Pavement Brick"), description = S("Pavement Brick"),
tiles = {"castle_pavement_brick.png"}, tiles = {"castle_pavement_brick.png"},
groups = {cracky=2, not_in_creative_inventory=1}, groups = {cracky=2, pickaxey=2, not_in_creative_inventory=1},
sounds = default.node_sound_stone_defaults(), sounds = castle_masonry.sounds.node_sound_stone_defaults(),
sunlight_propagates = true, sunlight_propagates = true,
}) })
stairsplus:register_alias_all("castle", "pavement_brick", "castle_masonry", "pavement_brick") stairsplus:register_alias_all("castle", "pavement_brick", "castle_masonry", "pavement_brick")
elseif minetest.get_modpath("mcl_stairs") then
mcl_stairs.register_stair_and_slab("pavement_brick", "castle_masonry:pavement_brick",
{pickaxey=2},
{"castle_pavement_brick.png"},
S("Castle Pavement Stair"),
S("Castle Pavement Slab"),
castle_masonry.sounds.node_sound_stone_defaults()
)
elseif minetest.get_modpath("stairs") then elseif minetest.get_modpath("stairs") then
stairs.register_stair_and_slab("pavement_brick", "castle_masonry:pavement_brick", stairs.register_stair_and_slab("pavement_brick", "castle_masonry:pavement_brick",
{cracky=2}, {cracky=2},
{"castle_pavement_brick.png"}, {"castle_pavement_brick.png"},
S("Castle Pavement Stair"), S("Castle Pavement Stair"),
S("Castle Pavement Slab"), S("Castle Pavement Slab"),
default.node_sound_stone_defaults() castle_masonry.sounds.node_sound_stone_defaults()
) )
end end
@ -56,27 +66,31 @@ minetest.register_node("castle_masonry:roofslate", {
type = "fixed", type = "fixed",
fixed = {-1/2, -1/2, -1/2, 1/2, -1/2+1/16, 1/2}, fixed = {-1/2, -1/2, -1/2, 1/2, -1/2+1/16, 1/2},
}, },
groups = {cracky=3,attached_node=1}, groups = {cracky=3, pickaxey=1, attached_node=1},
sounds = default.node_sound_glass_defaults(), _mcl_hardness = 0.8,
_mcl_blast_resistance = 1,
sounds = castle_masonry.sounds.node_sound_stone_defaults(),
}) })
local mod_building_blocks = minetest.get_modpath("building_blocks") local mod_building_blocks = minetest.get_modpath("building_blocks")
local mod_streets = minetest.get_modpath("streets") or minetest.get_modpath("asphalt") local mod_streets = minetest.get_modpath("streets") or minetest.get_modpath("asphalt")
local has_mcl = minetest.get_modpath("mcl_core")
local gravel = has_mcl and "mcl_core:gravel" or "default:gravel"
if mod_building_blocks then if mod_building_blocks then
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:roofslate 4", output = "castle_masonry:roofslate 4",
recipe = { recipe = {
{ "building_blocks:Tar" , "default:gravel" }, { "building_blocks:Tar" , gravel },
{ "default:gravel", "building_blocks:Tar" } { gravel, "building_blocks:Tar" }
} }
}) })
minetest.register_craft( { minetest.register_craft( {
output = "castle_masonry:roofslate 4", output = "castle_masonry:roofslate 4",
recipe = { recipe = {
{ "default:gravel", "building_blocks:Tar" }, { gravel, "building_blocks:Tar" },
{ "building_blocks:Tar" , "default:gravel" } { "building_blocks:Tar" , gravel }
} }
}) })
end end
@ -85,16 +99,16 @@ if mod_streets then
minetest.register_craft( { minetest.register_craft( {
output = "castle_masonry:roofslate 4", output = "castle_masonry:roofslate 4",
recipe = { recipe = {
{ "streets:asphalt" , "default:gravel" }, { "streets:asphalt" , gravel },
{ "default:gravel", "streets:asphalt" } { gravel, "streets:asphalt" }
} }
}) })
minetest.register_craft( { minetest.register_craft( {
output = "castle_masonry:roofslate 4", output = "castle_masonry:roofslate 4",
recipe = { recipe = {
{ "default:gravel", "streets:asphalt" }, { gravel, "streets:asphalt" },
{ "streets:asphalt" , "default:gravel" } { "streets:asphalt" , gravel }
} }
}) })
end end
@ -103,7 +117,7 @@ if not (mod_building_blocks or mod_streets) then
minetest.register_craft({ minetest.register_craft({
type = "cooking", type = "cooking",
output = "castle_masonry:roofslate", output = "castle_masonry:roofslate",
recipe = "default:gravel", recipe = gravel,
}) })
end end

View File

@ -18,6 +18,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Pillar Base", desc), description = S("@1 Pillar Base", desc),
tiles = tile, tiles = tile,
groups = crossbrace_connectable_groups, groups = crossbrace_connectable_groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -36,6 +38,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Half Pillar Base", desc), description = S("@1 Half Pillar Base", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -54,6 +58,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Pillar Top", desc), description = S("@1 Pillar Top", desc),
tiles = tile, tiles = tile,
groups = crossbrace_connectable_groups, groups = crossbrace_connectable_groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -72,6 +78,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Half Pillar Top", desc), description = S("@1 Half Pillar Top", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -90,6 +98,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Pillar Middle", desc), description = S("@1 Pillar Middle", desc),
tiles = tile, tiles = tile,
groups = crossbrace_connectable_groups, groups = crossbrace_connectable_groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -106,6 +116,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Half Pillar Middle", desc), description = S("@1 Half Pillar Middle", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -123,6 +135,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Crossbrace", desc), description = S("@1 Crossbrace", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",
@ -147,6 +161,8 @@ castle_masonry.register_pillar = function(material)
description = S("@1 Extended Crossbrace", desc), description = S("@1 Extended Crossbrace", desc),
tiles = tile, tiles = tile,
groups = composition_def.groups, groups = composition_def.groups,
_mcl_hardness = composition_def._mcl_hardness or 0.8,
_mcl_blast_resistance = composition_def._mcl_blast_resistance or 1,
sounds = composition_def.sounds, sounds = composition_def.sounds,
paramtype = "light", paramtype = "light",
paramtype2 = "facedir", paramtype2 = "facedir",

View File

@ -1,24 +1,31 @@
[Materials] [Materials]
castle_masonry_stonewall (Stonewall) bool true castle_masonry_stonewall (Stonewall) bool true
castle_masonry_cobble (Cobble) bool true castle_masonry_cobble (Cobble) bool true
castle_masonry_stonebrick (Stone Brick) bool true castle_masonry_stonebrick (Stone Brick) bool true
castle_masonry_stone (Stone) bool true
castle_masonry_sandstone (Sandstone) bool true
castle_masonry_wood (Wood) bool false
castle_masonry_ice (Ice) bool false
castle_masonry_snow (Snow) bool false
[Materials MTG]
castle_masonry_sandstonebrick (Sandstone Brick) bool true castle_masonry_sandstonebrick (Sandstone Brick) bool true
castle_masonry_desertstonebrick (Desert Stone Brick) bool true castle_masonry_desertstonebrick (Desert Stone Brick) bool true
castle_masonry_desertsandstonebrick (Desert Sandstone Brick) bool true castle_masonry_desertsandstonebrick (Desert Sandstone Brick) bool true
castle_masonry_silversandstonebrick (Silver Sandstone Brick) bool true castle_masonry_silversandstonebrick (Silver Sandstone Brick) bool true
castle_masonry_stone (Stone) bool true
castle_masonry_sandstone (Sandstone) bool true
castle_masonry_desertstone (Desert Stone) bool true castle_masonry_desertstone (Desert Stone) bool true
castle_masonry_desertsandstone (Desert Sandstone) bool true castle_masonry_desertsandstone (Desert Sandstone) bool true
castle_masonry_silversandstone (Silver Sandstone) bool true castle_masonry_silversandstone (Silver Sandstone) bool true
castle_masonry_wood (Wood) bool false
castle_masonry_ice (Ice) bool false
castle_masonry_snow (Snow) bool false
castle_masonry_obsidianbrick (Obsidian Brick) bool false castle_masonry_obsidianbrick (Obsidian Brick) bool false
[Forms] [Materials MCL]
castle_masonry_redsandstone (Red Sandstone) bool true
castle_masonry_quartz (Quartz) bool true
castle_masonry_blackstone (Blackstone) bool true
castle_masonry_deepslate_bricks (Deepslate Bricks) bool true
castle_masonry_deepslate_tiles (Deepslate Tiles) bool true
[Forms]
castle_masonry_pillar (Pillars) bool true castle_masonry_pillar (Pillars) bool true
castle_masonry_arrowslit (Arrow slits) bool true castle_masonry_arrowslit (Arrow slits) bool true
castle_masonry_murderhole (Murder holes and machicolations) bool true castle_masonry_murderhole (Murder holes and machicolations) bool true

View File

@ -1,5 +1,11 @@
local S = minetest.get_translator("castle_masonry") local S = minetest.get_translator("castle_masonry")
local has_mcl = minetest.get_modpath("mcl_core")
local gravel = has_mcl and "mcl_core:gravel" or "default:gravel"
local desert_stone = has_mcl and "mcl_core:redsandstone" or "default:desert_stone"
local sandstone = has_mcl and "mcl_core:sandstone" or "default:sandstone"
local stonebrick = has_mcl and "mcl_core:stonebrick" or "default:stonebrick"
local obsidian = has_mcl and "mcl_core:obsidian" or "default:obsidian"
minetest.register_alias("castle:stonewall", "castle_masonry:stonewall") minetest.register_alias("castle:stonewall", "castle_masonry:stonewall")
@ -13,9 +19,11 @@ minetest.register_node("castle_masonry:stonewall", {
tiles = {"castle_stonewall.png"}, tiles = {"castle_stonewall.png"},
paramtype = "light", paramtype = "light",
drop = "castle_masonry:stonewall", drop = "castle_masonry:stonewall",
groups = {cracky=3}, groups = {cracky=3, pickaxey=1},
_mcl_hardness = 1,
_mcl_blast_resistance = 1,
sunlight_propagates = false, sunlight_propagates = false,
sounds = default.node_sound_stone_defaults(), sounds = castle_masonry.sounds.node_sound_stone_defaults(),
}) })
minetest.register_node("castle_masonry:rubble", { minetest.register_node("castle_masonry:rubble", {
@ -23,15 +31,17 @@ minetest.register_node("castle_masonry:rubble", {
drawtype = "normal", drawtype = "normal",
tiles = {"castle_rubble.png"}, tiles = {"castle_rubble.png"},
paramtype = "light", paramtype = "light",
groups = {crumbly=3,falling_node=1}, groups = {crumbly=3, shovely=1, falling_node=1},
sounds = default.node_sound_gravel_defaults(), _mcl_hardness = 0.8,
_mcl_blast_resistance = 1,
sounds = castle_masonry.sounds.node_sound_gravel_defaults(),
}) })
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:stonewall", output = "castle_masonry:stonewall",
recipe = { recipe = {
{"default:cobble"}, {"group:cobble"},
{"default:desert_stone"}, {desert_stone},
} }
}) })
@ -45,8 +55,8 @@ minetest.register_craft({
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:rubble 2", output = "castle_masonry:rubble 2",
recipe = { recipe = {
{"default:gravel"}, {gravel},
{"default:desert_stone"}, {desert_stone},
} }
}) })
@ -61,15 +71,17 @@ minetest.register_node("castle_masonry:stonewall_corner", {
"castle_stonewall.png", "castle_stonewall.png",
"castle_stonewall.png", "castle_stonewall.png",
"castle_corner_stonewall2.png"}, "castle_corner_stonewall2.png"},
groups = {cracky=3}, groups = {cracky=3, pickaxey=1},
sounds = default.node_sound_stone_defaults(), _mcl_hardness = 1,
_mcl_blast_resistance = 1,
sounds = castle_masonry.sounds.node_sound_stone_defaults(),
}) })
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:stonewall_corner", output = "castle_masonry:stonewall_corner",
recipe = { recipe = {
{"", "castle_masonry:stonewall"}, {"", "castle_masonry:stonewall"},
{"castle_masonry:stonewall", "default:sandstone"}, {"castle_masonry:stonewall", sandstone},
} }
}) })
@ -77,29 +89,47 @@ if minetest.get_modpath("moreblocks") then
stairsplus:register_all("castle_masonry", "stonewall", "castle_masonry:stonewall", { stairsplus:register_all("castle_masonry", "stonewall", "castle_masonry:stonewall", {
description = S("Stone Wall"), description = S("Stone Wall"),
tiles = {"castle_stonewall.png"}, tiles = {"castle_stonewall.png"},
groups = {cracky=3, not_in_creative_inventory=1}, groups = {cracky=3, pickaxey=1, not_in_creative_inventory=1},
sounds = default.node_sound_stone_defaults(), _mcl_hardness = 0.8,
_mcl_blast_resistance = 1,
sounds = castle_masonry.sounds.node_sound_stone_defaults(),
sunlight_propagates = true, sunlight_propagates = true,
}) })
stairsplus:register_all("castle_masonry", "rubble", "castle_masonry:rubble", { stairsplus:register_all("castle_masonry", "rubble", "castle_masonry:rubble", {
description = S("Rubble"), description = S("Rubble"),
tiles = {"castle_rubble.png"}, tiles = {"castle_rubble.png"},
groups = {cracky=3, not_in_creative_inventory=1}, groups = {cracky=3, pickaxey=1, not_in_creative_inventory=1},
sounds = default.node_sound_gravel_defaults(), sounds = castle_masonry.sounds.node_sound_gravel_defaults(),
sunlight_propagates = true, sunlight_propagates = true,
}) })
stairsplus:register_alias_all("castle", "stonewall", "castle_masonry", "stonewall") stairsplus:register_alias_all("castle", "stonewall", "castle_masonry", "stonewall")
stairsplus:register_alias_all("castle", "rubble", "castle_masonry", "rubble") stairsplus:register_alias_all("castle", "rubble", "castle_masonry", "rubble")
elseif minetest.get_modpath("stairs") then elseif minetest.get_modpath("mcl_stairs") then
stairs.register_stair_and_slab("stonewall", "castle_masonry:stonewall", mcl_stairs.register_stair_and_slab("stonewall", "castle_masonry:stonewall",
{cracky=3}, {pickaxey=1},
{"castle_stonewall.png"}, {"castle_stonewall.png"},
S("Castle Stonewall Stair"), S("Castle Stonewall Stair"),
S("Castle Stonewall Slab"), S("Castle Stonewall Slab"),
default.node_sound_stone_defaults() castle_masonry.sounds.node_sound_stone_defaults()
)
mcl_stairs.register_stair_and_slab("rubble", "castle_masonry:rubble",
{shovely=1},
{"castle_rubble.png"},
S("Castle Rubble Stair"),
S("Castle Rubble Slab"),
castle_masonry.sounds.node_sound_gravel_defaults()
)
elseif minetest.get_modpath("stairs") then
stairs.register_stair_and_slab("stonewall", "castle_masonry:stonewall",
{cracky=3, pickaxey=1},
{"castle_stonewall.png"},
S("Castle Stonewall Stair"),
S("Castle Stonewall Slab"),
castle_masonry.sounds.node_sound_stone_defaults()
) )
stairs.register_stair_and_slab("rubble", "castle_masonry:rubble", stairs.register_stair_and_slab("rubble", "castle_masonry:rubble",
@ -107,7 +137,7 @@ elseif minetest.get_modpath("stairs") then
{"castle_rubble.png"}, {"castle_rubble.png"},
S("Castle Rubble Stair"), S("Castle Rubble Stair"),
S("Castle Rubble Slab"), S("Castle Rubble Slab"),
default.node_sound_stone_defaults() castle_masonry.sounds.node_sound_stone_defaults()
) )
end end
@ -117,23 +147,25 @@ minetest.register_node("castle_masonry:dungeon_stone", {
description = S("Dungeon Stone"), description = S("Dungeon Stone"),
drawtype = "normal", drawtype = "normal",
tiles = {"castle_dungeon_stone.png"}, tiles = {"castle_dungeon_stone.png"},
groups = {cracky=2}, groups = {cracky=2, pickaxey=2},
_mcl_hardness = 1,
_mcl_blast_resistance = 1,
paramtype = "light", paramtype = "light",
sounds = default.node_sound_stone_defaults(), sounds = castle_masonry.sounds.node_sound_stone_defaults(),
}) })
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:dungeon_stone 2", output = "castle_masonry:dungeon_stone 2",
recipe = { recipe = {
{"default:stonebrick", "default:obsidian"}, {stonebrick, obsidian},
} }
}) })
minetest.register_craft({ minetest.register_craft({
output = "castle_masonry:dungeon_stone 2", output = "castle_masonry:dungeon_stone 2",
recipe = { recipe = {
{"default:stonebrick"}, {stonebrick},
{"default:obsidian"}, {obsidian},
} }
}) })
@ -142,19 +174,27 @@ if minetest.get_modpath("moreblocks") then
stairsplus:register_all("castle_masonry", "dungeon_stone", "castle_masonry:dungeon_stone", { stairsplus:register_all("castle_masonry", "dungeon_stone", "castle_masonry:dungeon_stone", {
description = S("Dungeon Stone"), description = S("Dungeon Stone"),
tiles = {"castle_dungeon_stone.png"}, tiles = {"castle_dungeon_stone.png"},
groups = {cracky=2, not_in_creative_inventory=1}, groups = {cracky=2, pickaxey=2, not_in_creative_inventory=1},
sounds = default.node_sound_stone_defaults(), sounds = castle_masonry.sounds.node_sound_stone_defaults(),
sunlight_propagates = true, sunlight_propagates = true,
}) })
stairsplus:register_alias_all("castle", "dungeon_stone", "castle_masonry", "dungeon_stone") stairsplus:register_alias_all("castle", "dungeon_stone", "castle_masonry", "dungeon_stone")
elseif minetest.get_modpath("stairs") then elseif minetest.get_modpath("mcl_stairs") then
stairs.register_stair_and_slab("dungeon_stone", "castle_masonry:dungeon_stone", mcl_stairs.register_stair_and_slab("dungeon_stone", "castle_masonry:dungeon_stone",
{cracky=2}, {pickaxey=2},
{"castle_dungeon_stone.png"}, {"castle_dungeon_stone.png"},
S("Dungeon Stone Stair"), S("Dungeon Stone Stair"),
S("Dungeon Stone Slab"), S("Dungeon Stone Slab"),
default.node_sound_stone_defaults() castle_masonry.sounds.node_sound_stone_defaults()
)
elseif minetest.get_modpath("stairs") then
stairs.register_stair_and_slab("dungeon_stone", "castle_masonry:dungeon_stone",
{cracky=2, pickaxey=2},
{"castle_dungeon_stone.png"},
S("Dungeon Stone Stair"),
S("Dungeon Stone Slab"),
castle_masonry.sounds.node_sound_stone_defaults()
) )
end end