mirror of
https://github.com/minetest-mods/carpets.git
synced 2024-07-04 15:05:13 +02:00
API cleanup for minetest-mods https://github.com/minetest-mods/minetest-mods.github.io/issues/55
This commit is contained in:
parent
412d3ffcc7
commit
88b41e24f4
70
api.lua
70
api.lua
@ -1,8 +1,3 @@
|
|||||||
local modname = minetest.get_current_modname()
|
|
||||||
local modpath = minetest.get_modpath(modname)
|
|
||||||
|
|
||||||
local config = Settings(modpath .. "/settings.txt")
|
|
||||||
|
|
||||||
local carpet_proto = {
|
local carpet_proto = {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
@ -20,67 +15,42 @@ local carpet_proto = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if config:get_bool("WoolFeeling") then
|
-- Register the carpet and recipe using material
|
||||||
carpet_proto.sounds = default.node_sound_defaults()
|
-- material - already registered material item the textures and sounds applied from
|
||||||
carpet_proto.groups = {snappy = 2, choppy = 2, oddly_breakable_by_hand = 3, flammable = 3}
|
-- def - optional additional - or overriding data passed to minetest.register_node()
|
||||||
end
|
carpets = {}
|
||||||
|
|
||||||
function carpets.register(recipe, def)
|
function carpets.register(material, def)
|
||||||
local node = table.copy(carpet_proto)
|
local node = table.copy(carpet_proto)
|
||||||
if def then
|
if def then
|
||||||
for k,v in pairs(def) do
|
for k,v in pairs(def) do
|
||||||
node.k = v
|
node[k] = v
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local material_def = minetest.registered_nodes[material]
|
||||||
|
node.description = node.description or material_def.description.." Carpet"
|
||||||
|
node.sounds = table.copy(node.sounds or material_def.sounds or default.node_sound_defaults())
|
||||||
|
node.groups = table.copy(node.groups)
|
||||||
|
|
||||||
|
if node.tiles then
|
||||||
|
node.tiles = table.copy(node.tiles)
|
||||||
|
elseif material_def.tiles[6] then
|
||||||
|
node.tiles = {material_def.tiles[6]}
|
||||||
else
|
else
|
||||||
def = {}
|
node.tiles = table.copy(material_def.tiles)
|
||||||
end
|
end
|
||||||
|
|
||||||
local recipe_def = minetest.registered_nodes[recipe]
|
local name = "carpet:" .. (node.name or material:gsub(":", "_"))
|
||||||
node.description = def.description or recipe_def.description.." Carpet"
|
|
||||||
node.tiles = table.copy(def.tiles or recipe_def.tiles or {})
|
|
||||||
node.sounds = table.copy(def.sounds or recipe_def.sounds or {})
|
|
||||||
if def.groups then
|
|
||||||
node.groups = table.copy(def.groups)
|
|
||||||
end
|
|
||||||
|
|
||||||
if node.tiles[6] then
|
|
||||||
node.tiles = {node.tiles[6]}
|
|
||||||
end
|
|
||||||
|
|
||||||
if config:get_bool("FallingCarpet") and node.groups.falling_node == nil then
|
|
||||||
node.groups.falling_node = 1
|
|
||||||
elseif node.groups.falling_node == 1 then
|
|
||||||
node.groups.falling_node = 0
|
|
||||||
end
|
|
||||||
|
|
||||||
local name = "carpet:" .. (node.name or recipe:gsub(":", "_"))
|
|
||||||
node.name = nil
|
node.name = nil
|
||||||
|
|
||||||
if config:get_bool("NoFlyCarpet") then
|
|
||||||
local previous_on_place = node.on_place or minetest.item_place
|
|
||||||
node.on_place = function(itemstack, placer, pointed_thing, ...)
|
|
||||||
if not pointed_thing then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
local above = pointed_thing.above
|
|
||||||
local under = pointed_thing.under
|
|
||||||
local under_node = minetest.get_node(under)
|
|
||||||
|
|
||||||
if above.y == (under.y + 1) and under_node.name == name then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
return previous_on_place(itemstack, placer, pointed_thing, ...)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_node(":" .. name, node)
|
minetest.register_node(":" .. name, node)
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = name .. " 32",
|
output = name .. " 32",
|
||||||
recipe = {
|
recipe = {
|
||||||
{"group:wool", "group:wool", "group:wool"},
|
{"group:wool", "group:wool", "group:wool"},
|
||||||
{"group:wool", recipe, "group:wool"}
|
{"group:wool", material, "group:wool"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
11
depends.txt
11
depends.txt
@ -1,10 +1 @@
|
|||||||
wool
|
wool?
|
||||||
default?
|
|
||||||
farming?
|
|
||||||
bones?
|
|
||||||
castle?
|
|
||||||
darkage?
|
|
||||||
moreblocks?
|
|
||||||
plasticbox?
|
|
||||||
princess?
|
|
||||||
moretrees?
|
|
||||||
|
83
init.lua
83
init.lua
@ -1,68 +1,25 @@
|
|||||||
carpets = {}
|
local modpath = minetest.get_modpath(minetest.get_current_modname())
|
||||||
|
|
||||||
local modname = minetest.get_current_modname()
|
|
||||||
local modpath = minetest.get_modpath(modname)
|
|
||||||
|
|
||||||
dofile(modpath .. "/api.lua")
|
dofile(modpath .. "/api.lua")
|
||||||
|
|
||||||
local modutils = dofile(modpath .. "/modutils.lua")
|
if minetest.get_modpath("wool") then
|
||||||
local depmod = modutils.get_depend_checker(modname)
|
local nodenames = {
|
||||||
|
"wool:black",
|
||||||
local function filter(name, def)
|
"wool:blue",
|
||||||
-- disable carpets from loaded modules but not defined in dependency
|
"wool:brown",
|
||||||
if not depmod:check_depend_by_itemname(name) then
|
"wool:cyan",
|
||||||
return false
|
"wool:dark_green",
|
||||||
end
|
"wool:dark_grey",
|
||||||
|
"wool:green",
|
||||||
-- disable carpets for blocks without description
|
"wool:grey",
|
||||||
if def.description == nil or def.description == "" then
|
"wool:magenta",
|
||||||
return false
|
"wool:orange",
|
||||||
end
|
"wool:pink",
|
||||||
|
"wool:red",
|
||||||
-- no 3rd hand carpets
|
"wool:violet",
|
||||||
local ignore_groups = {
|
"wool:white",
|
||||||
not_in_creative_inventory = true,
|
"wool:yellow",
|
||||||
carpet = true,
|
|
||||||
door = true,
|
|
||||||
fence = true,
|
|
||||||
stair = true,
|
|
||||||
slab = true,
|
|
||||||
wall = true,
|
|
||||||
micro = true,
|
|
||||||
panel = true,
|
|
||||||
slope = true,
|
|
||||||
}
|
}
|
||||||
for k,v in pairs(def.groups) do
|
for _, nodename in ipairs(nodenames) do
|
||||||
if ignore_groups[k] then
|
carpets.register(nodename)
|
||||||
return false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- not supported node types for carpets
|
|
||||||
local ignore_drawtype = {
|
|
||||||
liquid = true,
|
|
||||||
firelike = true,
|
|
||||||
airlike = true,
|
|
||||||
plantlike = true,
|
|
||||||
nodebox = true,
|
|
||||||
raillike = true,
|
|
||||||
}
|
|
||||||
if ignore_drawtype[def.drawtype] then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
-- no carpet for signs, rail, ladder
|
|
||||||
if def.paramtype2 == "wallmounted" then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
-- all checks passed
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
-- main execution
|
|
||||||
for name, def in pairs(minetest.registered_nodes) do
|
|
||||||
if filter(name, def) then
|
|
||||||
carpets.register(name)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
71
modutils.lua
71
modutils.lua
@ -1,71 +0,0 @@
|
|||||||
local modutils = {}
|
|
||||||
|
|
||||||
function modutils.get_modname_by_itemname(itemname)
|
|
||||||
local def = minetest.registered_items[itemname]
|
|
||||||
if def then
|
|
||||||
return def.mod_origin
|
|
||||||
else --not loaded item
|
|
||||||
local delimpos = string.find(itemname, ":")
|
|
||||||
if delimpos then
|
|
||||||
return string.sub(itemname, 1, delimpos - 1)
|
|
||||||
else
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
function modutils.get_depend_checker(modname)
|
|
||||||
local self = {
|
|
||||||
modname = modname,
|
|
||||||
depends = {} -- depends.txt parsed
|
|
||||||
}
|
|
||||||
|
|
||||||
-- Check if dependency exists to mod modname
|
|
||||||
function self:check_depend(modname, deptype)
|
|
||||||
if self.depends[modname] then
|
|
||||||
if not deptype then --"required" or "optional" only
|
|
||||||
return true
|
|
||||||
else
|
|
||||||
return (self.depends[modname] == deptype)
|
|
||||||
end
|
|
||||||
else
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
--Check if dependency exists to item origin mod
|
|
||||||
function self:check_depend_by_itemname(itemname, deptype)
|
|
||||||
local modname = modutils.get_modname_by_itemname(itemname)
|
|
||||||
if modname then
|
|
||||||
return self:check_depend(modname, deptype)
|
|
||||||
else
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- get module path
|
|
||||||
local modpath = minetest.get_modpath(modname)
|
|
||||||
if not modpath then
|
|
||||||
return nil -- module not found
|
|
||||||
end
|
|
||||||
|
|
||||||
-- read the depends file
|
|
||||||
local dependsfile = io.open(modpath .. "/depends.txt")
|
|
||||||
if not dependsfile then
|
|
||||||
return nil
|
|
||||||
end
|
|
||||||
|
|
||||||
-- parse the depends file
|
|
||||||
for line in dependsfile:lines() do
|
|
||||||
if line:sub(-1) == "?" then
|
|
||||||
line = line:sub(1, -2)
|
|
||||||
self.depends[line] = "optional"
|
|
||||||
else
|
|
||||||
self.depends[line] = "required"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
dependsfile:close()
|
|
||||||
return self
|
|
||||||
end
|
|
||||||
|
|
||||||
return modutils
|
|
@ -1,3 +1,2 @@
|
|||||||
NoFlyCarpet = true
|
|
||||||
FallingCarpet = false
|
FallingCarpet = false
|
||||||
WoolFeeling = false
|
WoolFeeling = false
|
||||||
|
Loading…
Reference in New Issue
Block a user