MineClonia/MineClone2 Support (#22)
This commit is contained in:
parent
be330097a8
commit
c382515bca
@ -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
102
init.lua
@ -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
|
||||||
|
4
mod.conf
4
mod.conf
@ -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.
|
||||||
|
@ -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",
|
||||||
|
50
paving.lua
50
paving.lua
@ -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
|
||||||
|
16
pillars.lua
16
pillars.lua
@ -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",
|
||||||
|
@ -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
|
||||||
|
104
stone_wall.lua
104
stone_wall.lua
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user