update cool trees, plantlife, bees, digistuff, farming redo,
led_marquee, mesecons, moreblocks, stained_glass, technic, and titanium
1
build-date
Normal file
@ -0,0 +1 @@
|
|||||||
|
20210328-0214
|
@ -25,6 +25,7 @@ end
|
|||||||
--
|
--
|
||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
|
name = "baldcypress:baldcypress_tree",
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:sand"},
|
place_on = {"default:sand"},
|
||||||
|
@ -115,6 +115,7 @@ end
|
|||||||
--
|
--
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "bamboo:bamboo_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_grass"},
|
place_on = {"default:dirt_with_grass"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -412,7 +412,10 @@ minetest.register_node("bees:hive_wild", {
|
|||||||
if meta:get_int("agressive") == 1
|
if meta:get_int("agressive") == 1
|
||||||
and inv:contains_item("queen", "bees:queen") then
|
and inv:contains_item("queen", "bees:queen") then
|
||||||
|
|
||||||
clicker:set_hp(clicker:get_hp() - 4)
|
-- damage inside timer to stop death duplication glitch
|
||||||
|
minetest.after(0.1, function()
|
||||||
|
clicker:set_hp(clicker:get_hp() - 4)
|
||||||
|
end, clicker)
|
||||||
else
|
else
|
||||||
meta:set_int("agressive", 1)
|
meta:set_int("agressive", 1)
|
||||||
end
|
end
|
||||||
@ -509,7 +512,10 @@ minetest.register_node("bees:hive_artificial", {
|
|||||||
if meta:get_int("agressive") == 1
|
if meta:get_int("agressive") == 1
|
||||||
and inv:contains_item("queen", "bees:queen") then
|
and inv:contains_item("queen", "bees:queen") then
|
||||||
|
|
||||||
clicker:set_hp(clicker:get_hp() - 4)
|
-- damage inside timer to stop death duplication glitch
|
||||||
|
minetest.after(0.1, function()
|
||||||
|
clicker:set_hp(clicker:get_hp() - 4)
|
||||||
|
end, clicker)
|
||||||
else
|
else
|
||||||
meta:set_int("agressive", 1)
|
meta:set_int("agressive", 1)
|
||||||
end
|
end
|
||||||
@ -691,16 +697,23 @@ minetest.register_abm({
|
|||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
nodenames = {"group:leaves"},
|
nodenames = {"group:leaves"},
|
||||||
neighbors = {"air"},
|
neighbors = {"air"},
|
||||||
interval = 800,
|
interval = 300,
|
||||||
chance = 10,
|
chance = 4,
|
||||||
|
|
||||||
action = function(pos)
|
action = function(pos)
|
||||||
|
|
||||||
if floor(pos.x / 40) ~= pos.x / 40
|
if floor(pos.x / 20) ~= pos.x / 20
|
||||||
or floor(pos.z / 40) ~= pos.z / 40
|
or floor(pos.z / 20) ~= pos.z / 20
|
||||||
or floor(pos.y / 5) ~= pos.y / 5 then return end
|
or floor(pos.y / 3) ~= pos.y / 3 then return end
|
||||||
|
|
||||||
local p = {x = pos.x, y = pos.y - 1, z = pos.z}
|
local p = {x = pos.x, y = pos.y - 1, z = pos.z}
|
||||||
|
|
||||||
|
-- skip if nearby hive found
|
||||||
|
if minetest.find_node_near(p, 25, {"bees:hive_artificial", "bees:hive_wild",
|
||||||
|
"bees:hive_industrial"}) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local nod = minetest.get_node_or_nil(p)
|
local nod = minetest.get_node_or_nil(p)
|
||||||
local def = nod and minetest.registered_nodes[nod.name]
|
local def = nod and minetest.registered_nodes[nod.name]
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@ FEATURES
|
|||||||
- Make wild hive abm less intensive (thanks VanessaE)
|
- Make wild hive abm less intensive (thanks VanessaE)
|
||||||
- Added 9x Lucky Blocks
|
- Added 9x Lucky Blocks
|
||||||
- Smokers have 200 uses before breaking
|
- Smokers have 200 uses before breaking
|
||||||
|
- Hives are spread out 20 blocks apart, 3 high and only spawn when no other hives around
|
||||||
|
|
||||||
2.2.2
|
2.2.2
|
||||||
- Pipeworks compatibility (Industrial beehive)
|
- Pipeworks compatibility (Industrial beehive)
|
||||||
|
@ -104,6 +104,7 @@ else
|
|||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "birch:birch_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {place_on},
|
place_on = {place_on},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -44,7 +44,9 @@ if farming and farming.mod and farming.mod == "redo" then
|
|||||||
{"farming:lettuce_", 5},
|
{"farming:lettuce_", 5},
|
||||||
{"farming:blackberry_", 4},
|
{"farming:blackberry_", 4},
|
||||||
{"farming:vanilla_", 8},
|
{"farming:vanilla_", 8},
|
||||||
{"farming:soy_", 7}
|
{"farming:soy_", 7},
|
||||||
|
{"farming:artichoke_", 5},
|
||||||
|
{"farming:parsley_", 3}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -70,6 +70,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "cherrytree:cherry_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_grass"},
|
place_on = {"default:dirt_with_grass"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -86,6 +86,7 @@ if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
|||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "chestnuttree:chestnut_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {place_on},
|
place_on = {place_on},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -50,6 +50,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "clementinetree:clementine_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_grass"},
|
place_on = {"default:dirt_with_grass"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -147,3 +147,26 @@ y1 [integer 1-64]: The Y position of the start of the line.
|
|||||||
y2 [integer 1-64]: The Y position of the end of the line.
|
y2 [integer 1-64]: The Y position of the end of the line.
|
||||||
color [hex color, default "000000"]: The nominal color of the line (may not be the color of every pixel, see the "antialias" setting)
|
color [hex color, default "000000"]: The nominal color of the line (may not be the color of every pixel, see the "antialias" setting)
|
||||||
antialias [boolean, default false]: Whether to apply a (very) crude smoothing algorithm to the line to reduce jagged edges at the expense of making the line slightly blurry.
|
antialias [boolean, default false]: Whether to apply a (very) crude smoothing algorithm to the line to reduce jagged edges at the expense of making the line slightly blurry.
|
||||||
|
|
||||||
|
Command: sendpacked
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
Converts the image in a buffer into a string representation that can be loaded again later with the "loadpacked" command.
|
||||||
|
The result uses 4 bytes per pixel and consists entirely of printable characters (A-Z, a-z, 0-9, +, and /).
|
||||||
|
|
||||||
|
Parameters:
|
||||||
|
buffer [integer 0-7]: The buffer to convert.
|
||||||
|
channel [string]: The digilines channel to send the packed image on.
|
||||||
|
|
||||||
|
Command: loadpacked
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
Load a string representation of an image (created by the "sendpacked" command) back into a buffer.
|
||||||
|
|
||||||
|
Parameters:
|
||||||
|
buffer [integer 0-7]: The buffer to load the image into.
|
||||||
|
x [integer 1-64]: The X position of the left side of the image.
|
||||||
|
y [integer 1-64]: The Y position of the top of the image.
|
||||||
|
xsize [integer 1-64]: The width of the image. Must be the same as the original image or the image will be severely distorted.
|
||||||
|
ysize [integer 1-64]: The height of the image. Should be the same as the original image.
|
||||||
|
data [string]: The packed image to load.
|
||||||
|
@ -1,21 +1,70 @@
|
|||||||
local font = dofile(minetest.get_modpath("digistuff")..DIR_DELIM.."gpu-font.lua")
|
local font = dofile(minetest.get_modpath("digistuff")..DIR_DELIM.."gpu-font.lua")
|
||||||
|
|
||||||
local function explodebits(input)
|
local function explodebits(input,count)
|
||||||
local output = {}
|
local output = {}
|
||||||
for i=0,7,1 do
|
if not count then count = 8 end
|
||||||
|
for i=0,count-1,1 do
|
||||||
output[i] = input%(2^(i+1)) >= 2^i
|
output[i] = input%(2^(i+1)) >= 2^i
|
||||||
end
|
end
|
||||||
return output
|
return output
|
||||||
end
|
end
|
||||||
|
|
||||||
local function implodebits(input)
|
local function implodebits(input,count)
|
||||||
local output = 0
|
local output = 0
|
||||||
for i=0,7,1 do
|
if not count then count = 8 end
|
||||||
|
for i=0,count-1,1 do
|
||||||
output = output + (input[i] and 2^i or 0)
|
output = output + (input[i] and 2^i or 0)
|
||||||
end
|
end
|
||||||
return output
|
return output
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local packtable = {}
|
||||||
|
local unpacktable = {}
|
||||||
|
for i=0,25,1 do
|
||||||
|
packtable[i] = string.char(i+65)
|
||||||
|
packtable[i+26] = string.char(i+97)
|
||||||
|
unpacktable[string.char(i+65)] = i
|
||||||
|
unpacktable[string.char(i+97)] = i+26
|
||||||
|
end
|
||||||
|
for i=0,9,1 do
|
||||||
|
packtable[i+52] = tostring(i)
|
||||||
|
unpacktable[tostring(i)] = i+52
|
||||||
|
end
|
||||||
|
packtable[62] = "+"
|
||||||
|
packtable[63] = "/"
|
||||||
|
unpacktable["+"] = 62
|
||||||
|
unpacktable["/"] = 63
|
||||||
|
|
||||||
|
local function packpixel(pixel)
|
||||||
|
pixel = tonumber(pixel,16)
|
||||||
|
if not pixel then return "AAAA" end
|
||||||
|
local bits = explodebits(pixel,24)
|
||||||
|
local block1 = {}
|
||||||
|
local block2 = {}
|
||||||
|
local block3 = {}
|
||||||
|
local block4 = {}
|
||||||
|
for i=0,5,1 do
|
||||||
|
block1[i] = bits[i]
|
||||||
|
block2[i] = bits[i+6]
|
||||||
|
block3[i] = bits[i+12]
|
||||||
|
block4[i] = bits[i+18]
|
||||||
|
end
|
||||||
|
local char1 = packtable[implodebits(block1,6)] or "A"
|
||||||
|
local char2 = packtable[implodebits(block2,6)] or "A"
|
||||||
|
local char3 = packtable[implodebits(block3,6)] or "A"
|
||||||
|
local char4 = packtable[implodebits(block4,6)] or "A"
|
||||||
|
return char1..char2..char3..char4
|
||||||
|
end
|
||||||
|
|
||||||
|
local function unpackpixel(pack)
|
||||||
|
local block1 = unpacktable[pack:sub(1,1)] or 0
|
||||||
|
local block2 = unpacktable[pack:sub(2,2)] or 0
|
||||||
|
local block3 = unpacktable[pack:sub(3,3)] or 0
|
||||||
|
local block4 = unpacktable[pack:sub(4,4)] or 0
|
||||||
|
local out = block1+(2^6*block2)+(2^12*block3)+(2^18*block4)
|
||||||
|
return string.format("%06X",out)
|
||||||
|
end
|
||||||
|
|
||||||
local function rgbtohsv(r,g,b)
|
local function rgbtohsv(r,g,b)
|
||||||
r = r/255
|
r = r/255
|
||||||
g = g/255
|
g = g/255
|
||||||
@ -416,6 +465,49 @@ local function runcommand(pos,meta,command)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
meta:set_string("buffer"..bufnum,minetest.serialize(buffer))
|
meta:set_string("buffer"..bufnum,minetest.serialize(buffer))
|
||||||
|
elseif command.command == "sendpacked" then
|
||||||
|
if type(command.buffer) ~= "number" or type(command.channel) ~= "string" then return end
|
||||||
|
local bufnum = math.floor(command.buffer)
|
||||||
|
if bufnum < 0 or bufnum > 7 then return end
|
||||||
|
local buffer = meta:get_string("buffer"..bufnum)
|
||||||
|
if string.len(buffer) == 0 then return end
|
||||||
|
buffer = minetest.deserialize(buffer)
|
||||||
|
if type(buffer) == "table" then
|
||||||
|
local packeddata = ""
|
||||||
|
for y=1,buffer.ysize,1 do
|
||||||
|
for x=1,buffer.xsize,1 do
|
||||||
|
packeddata = packeddata..packpixel(buffer[y][x])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
digiline:receptor_send(pos,digiline.rules.default,command.channel,packeddata)
|
||||||
|
end
|
||||||
|
elseif command.command == "loadpacked" then
|
||||||
|
if type(command.buffer) ~= "number" or type(command.data) ~= "string" then return end
|
||||||
|
if type(command.x) ~= "number" or type(command.y) ~= "number" or type(command.xsize) ~= "number" or type(command.ysize) ~= "number" then return end
|
||||||
|
command.x = math.floor(command.x)
|
||||||
|
command.y = math.floor(command.y)
|
||||||
|
command.xsize = math.floor(command.xsize)
|
||||||
|
command.ysize = math.floor(command.ysize)
|
||||||
|
if command.x < 1 or command.y < 1 or command.xsize < 1 or command.ysize < 1 then return end
|
||||||
|
local bufnum = math.floor(command.buffer)
|
||||||
|
if bufnum < 0 or bufnum > 7 then return end
|
||||||
|
local buffer = meta:get_string("buffer"..bufnum)
|
||||||
|
if string.len(buffer) == 0 then return end
|
||||||
|
buffer = minetest.deserialize(buffer)
|
||||||
|
if type(buffer) == "table" then
|
||||||
|
if command.x + command.xsize - 1 > buffer.xsize then return end
|
||||||
|
if command.y + command.ysize - 1 > buffer.ysize then return end
|
||||||
|
for y=0,command.ysize-1,1 do
|
||||||
|
local dsty = command.y+y
|
||||||
|
for x=0,command.xsize-1,1 do
|
||||||
|
local dstx = command.x+x
|
||||||
|
local packidx = (y*command.xsize+x)*4+1
|
||||||
|
local packeddata = string.sub(command.data,packidx,packidx+3)
|
||||||
|
buffer[dsty][dstx] = unpackpixel(packeddata)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
meta:set_string("buffer"..bufnum,minetest.serialize(buffer))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "ebony:ebony_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_rainforest_litter"},
|
place_on = {"default:dirt_with_rainforest_litter"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
64
mods/farming/crops/artichoke.lua
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
local S = farming.intllib
|
||||||
|
|
||||||
|
-- item definition
|
||||||
|
minetest.register_craftitem("farming:artichoke", {
|
||||||
|
description = S("Artichoke"),
|
||||||
|
inventory_image = "farming_artichoke.png",
|
||||||
|
groups = {seed = 2, food_artichoke = 1, flammable = 2},
|
||||||
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
|
return farming.place_seed(itemstack, placer, pointed_thing, "farming:artichoke_1")
|
||||||
|
end,
|
||||||
|
on_use = minetest.item_eat(4)
|
||||||
|
})
|
||||||
|
|
||||||
|
-- crop definition
|
||||||
|
local def = {
|
||||||
|
drawtype = "plantlike",
|
||||||
|
tiles = {"farming_artichoke_1.png"},
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
walkable = false,
|
||||||
|
buildable_to = true,
|
||||||
|
drop = "",
|
||||||
|
selection_box = farming.select,
|
||||||
|
groups = {
|
||||||
|
snappy = 3, flammable = 2, plant = 1, attached_node = 1,
|
||||||
|
not_in_creative_inventory = 1, growing = 1
|
||||||
|
},
|
||||||
|
sounds = default.node_sound_leaves_defaults()
|
||||||
|
}
|
||||||
|
|
||||||
|
-- stage 1
|
||||||
|
minetest.register_node("farming:artichoke_1", table.copy(def))
|
||||||
|
|
||||||
|
-- stage 2
|
||||||
|
def.tiles = {"farming_artichoke_2.png"}
|
||||||
|
minetest.register_node("farming:artichoke_2", table.copy(def))
|
||||||
|
|
||||||
|
-- stage 3
|
||||||
|
def.tiles = {"farming_artichoke_3.png"}
|
||||||
|
minetest.register_node("farming:artichoke_3", table.copy(def))
|
||||||
|
|
||||||
|
-- stage 4
|
||||||
|
def.tiles = {"farming_artichoke_4.png"}
|
||||||
|
minetest.register_node("farming:artichoke_4", table.copy(def))
|
||||||
|
|
||||||
|
-- stage 5 (final)
|
||||||
|
def.tiles = {"farming_artichoke_5.png"}
|
||||||
|
def.groups.growing = nil
|
||||||
|
def.drop = {
|
||||||
|
items = {
|
||||||
|
{items = {"farming:artichoke 2"}, rarity = 1},
|
||||||
|
{items = {"farming:artichoke"}, rarity = 2}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
minetest.register_node("farming:artichoke_5", table.copy(def))
|
||||||
|
|
||||||
|
-- add to registered_plants
|
||||||
|
farming.registered_plants["farming:artichoke"] = {
|
||||||
|
crop = "farming:artichoke",
|
||||||
|
seed = "farming:artichoke",
|
||||||
|
minlight = 13,
|
||||||
|
maxlight = 15,
|
||||||
|
steps = 5
|
||||||
|
}
|
@ -36,7 +36,7 @@ minetest.register_craft({
|
|||||||
minetest.register_craftitem("farming:cornstarch", {
|
minetest.register_craftitem("farming:cornstarch", {
|
||||||
description = S("Cornstarch"),
|
description = S("Cornstarch"),
|
||||||
inventory_image = "farming_cornstarch.png",
|
inventory_image = "farming_cornstarch.png",
|
||||||
groups = {food_cornstarch = 1, flammable = 2}
|
groups = {food_cornstarch = 1, food_gelatin = 1, food_flammable = 2}
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
|
56
mods/farming/crops/parsley.lua
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
local S = farming.intllib
|
||||||
|
|
||||||
|
-- item definition
|
||||||
|
minetest.register_craftitem("farming:parsley", {
|
||||||
|
description = S("Parsley"),
|
||||||
|
inventory_image = "farming_parsley.png",
|
||||||
|
groups = {seed = 2, food_parsley = 1, flammable = 2},
|
||||||
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
|
return farming.place_seed(itemstack, placer, pointed_thing, "farming:parsley_1")
|
||||||
|
end
|
||||||
|
})
|
||||||
|
|
||||||
|
-- crop definition
|
||||||
|
local def = {
|
||||||
|
drawtype = "plantlike",
|
||||||
|
tiles = {"farming_parsley_1.png"},
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
walkable = false,
|
||||||
|
buildable_to = true,
|
||||||
|
drop = "",
|
||||||
|
selection_box = farming.select,
|
||||||
|
groups = {
|
||||||
|
snappy = 3, flammable = 2, plant = 1, attached_node = 1,
|
||||||
|
not_in_creative_inventory = 1, growing = 1
|
||||||
|
},
|
||||||
|
sounds = default.node_sound_leaves_defaults()
|
||||||
|
}
|
||||||
|
|
||||||
|
-- stage 1
|
||||||
|
minetest.register_node("farming:parsley_1", table.copy(def))
|
||||||
|
|
||||||
|
-- stage 2
|
||||||
|
def.tiles = {"farming_parsley_2.png"}
|
||||||
|
minetest.register_node("farming:parsley_2", table.copy(def))
|
||||||
|
|
||||||
|
-- stage 3 (final)
|
||||||
|
def.tiles = {"farming_parsley_3.png"}
|
||||||
|
def.groups.growing = nil
|
||||||
|
def.drop = {
|
||||||
|
items = {
|
||||||
|
{items = {"farming:parsley 2"}, rarity = 1},
|
||||||
|
{items = {"farming:parsley"}, rarity = 2},
|
||||||
|
{items = {"farming:parsley"}, rarity = 3}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
minetest.register_node("farming:parsley_3", table.copy(def))
|
||||||
|
|
||||||
|
-- add to registered_plants
|
||||||
|
farming.registered_plants["farming:parsley"] = {
|
||||||
|
crop = "farming:parsley",
|
||||||
|
seed = "farming:parsley",
|
||||||
|
minlight = 13,
|
||||||
|
maxlight = 15,
|
||||||
|
steps = 3
|
||||||
|
}
|
@ -35,6 +35,8 @@ farming.blackberry = 0.002
|
|||||||
farming.lettuce = 0.001
|
farming.lettuce = 0.001
|
||||||
farming.soy = 0.001
|
farming.soy = 0.001
|
||||||
farming.vanilla = 0.001
|
farming.vanilla = 0.001
|
||||||
|
farming.artichoke = 0.001
|
||||||
|
farming.parsley = 0.002
|
||||||
farming.grains = true -- true or false only
|
farming.grains = true -- true or false only
|
||||||
|
|
||||||
-- default rarety of crops on map (higher number = more crops)
|
-- default rarety of crops on map (higher number = more crops)
|
||||||
|
@ -16,6 +16,19 @@ minetest.register_craft({
|
|||||||
recipe = "default:papyrus"
|
recipe = "default:papyrus"
|
||||||
})
|
})
|
||||||
|
|
||||||
|
--= Sugar caramel
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:caramel", {
|
||||||
|
description = S("Caramel"),
|
||||||
|
inventory_image = "farming_caramel.png",
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "cooking",
|
||||||
|
cooktime = 6,
|
||||||
|
output = "farming:caramel",
|
||||||
|
recipe = "group:food_sugar",
|
||||||
|
})
|
||||||
|
|
||||||
--= Salt
|
--= Salt
|
||||||
|
|
||||||
@ -180,7 +193,7 @@ minetest.register_craft({
|
|||||||
recipe = {
|
recipe = {
|
||||||
{"group:food_gelatin", "group:food_sugar", "group:food_gelatin"},
|
{"group:food_gelatin", "group:food_sugar", "group:food_gelatin"},
|
||||||
{"group:food_sugar", "group:food_rose_water", "group:food_sugar"},
|
{"group:food_sugar", "group:food_rose_water", "group:food_sugar"},
|
||||||
{"group:food_cornstarch", "group:food_sugar", "dye:pink"}
|
{"group:food_sugar", "dye:pink", "group:food_sugar"}
|
||||||
},
|
},
|
||||||
replacements = {
|
replacements = {
|
||||||
{"group:food_cornstarch", "farming:bowl"},
|
{"group:food_cornstarch", "farming:bowl"},
|
||||||
@ -472,3 +485,157 @@ minetest.register_craft({
|
|||||||
"vessels:drinking_glass"
|
"vessels:drinking_glass"
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- Patatas a la importancia
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:spanish_potatoes", {
|
||||||
|
description = S("Spanish Potatoes"),
|
||||||
|
inventory_image = "farming_spanish_potatoes.png",
|
||||||
|
on_use = minetest.item_eat(8, "farming:bowl"),
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:spanish_potatoes",
|
||||||
|
recipe = {
|
||||||
|
"farming:potato", "group:food_parsley", "farming:potato",
|
||||||
|
"group:food_egg", "group:food_flour", "farming:onion",
|
||||||
|
"farming:garlic_clove", "group:food_bowl", "group:food_skillet"
|
||||||
|
},
|
||||||
|
replacements = {{"group:food_skillet", "farming:skillet"}}
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Potato omelet
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:potato_omelet", {
|
||||||
|
description = S("Potato omelet"),
|
||||||
|
inventory_image = "farming_potato_omelet.png",
|
||||||
|
on_use = minetest.item_eat(6, "farming:bowl"),
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:potato_omelet",
|
||||||
|
recipe = {
|
||||||
|
"group:food_egg", "farming:potato", "group:food_onion",
|
||||||
|
"group:food_skillet", "group:food_bowl"},
|
||||||
|
replacements = {{"group:food_skillet", "farming:skillet"}}
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Paella
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:paella", {
|
||||||
|
description = S("Paella"),
|
||||||
|
inventory_image = "farming_paella.png",
|
||||||
|
on_use = minetest.item_eat(8, "farming:bowl")
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:paella",
|
||||||
|
recipe = {
|
||||||
|
"group:food_rice", "dye:orange", "farming:pepper_red",
|
||||||
|
"group:food_peas", "group:food_chicken", "group:food_bowl", "group:food_skillet"
|
||||||
|
},
|
||||||
|
replacements = {{"group:food_skillet", "farming:skillet"}}
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Flan
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:flan", {
|
||||||
|
description = S("Vanilla Flan"),
|
||||||
|
inventory_image = "farming_vanilla_flan.png",
|
||||||
|
on_use = minetest.item_eat(6)
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:flan",
|
||||||
|
recipe = {
|
||||||
|
"group:food_sugar", "group:food_milk", "farming:caramel",
|
||||||
|
"group:food_egg", "group:food_egg", "farming:vanilla_extract"
|
||||||
|
},
|
||||||
|
replacements = {
|
||||||
|
{"cucina_vegana:soy_milk", "vessels:drinking_glass"},
|
||||||
|
{"group:food_milk", "bucket:bucket_empty"},
|
||||||
|
{"farming:vanilla_extract", "vessels:glass_bottle"}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Vegan Cheese
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:cheese_vegan", {
|
||||||
|
description = S("Vegan Cheese"),
|
||||||
|
inventory_image = "farming_cheese_vegan.png",
|
||||||
|
on_use = minetest.item_eat(2),
|
||||||
|
groups = {food_cheese = 1, flammable = 2},
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:cheese_vegan",
|
||||||
|
recipe = {
|
||||||
|
"farming:soy_milk", "farming:soy_milk", "farming:soy_milk",
|
||||||
|
"group:food_salt", "group:food_peppercorn", "farming:bottle_ethanol",
|
||||||
|
"group:food_gelatin", "group:food_pot"
|
||||||
|
},
|
||||||
|
replacements = {
|
||||||
|
{"farming:soy_milk", "vessels:drinking_glass 3"},
|
||||||
|
{"farming:pot", "farming:pot"},
|
||||||
|
{"farming:bottle_ethanol", "vessels:glass_bottle"}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:cheese_vegan",
|
||||||
|
recipe = {
|
||||||
|
"farming:soy_milk", "farming:soy_milk", "farming:soy_milk",
|
||||||
|
"group:food_salt", "group:food_peppercorn", "group:food_lemon",
|
||||||
|
"group:food_gelatin", "group:food_pot"
|
||||||
|
},
|
||||||
|
replacements = {
|
||||||
|
{"farming:soy_milk", "vessels:drinking_glass 3"},
|
||||||
|
{"farming:pot", "farming:pot"},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Onigiri
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:onigiri", {
|
||||||
|
description = S("Onirigi"),
|
||||||
|
inventory_image = "farming_onigiri.png",
|
||||||
|
on_use = minetest.item_eat(2),
|
||||||
|
groups = {flammable = 2},
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:onigiri",
|
||||||
|
recipe = {
|
||||||
|
"group:food_rice", "group:food_rice", "group:food_seaweed", "group:food_salt"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
-- Gyoza
|
||||||
|
|
||||||
|
minetest.register_craftitem("farming:gyoza", {
|
||||||
|
description = S("Gyoza"),
|
||||||
|
inventory_image = "farming_gyoza.png",
|
||||||
|
on_use = minetest.item_eat(4),
|
||||||
|
groups = {flammable = 2},
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "shapeless",
|
||||||
|
output = "farming:gyoza 4",
|
||||||
|
recipe = {
|
||||||
|
"group:food_cabbage", "group:food_garlic_clove", "group:food_onion",
|
||||||
|
"group:food_meat_raw", "group:food_salt", "group:food_skillet",
|
||||||
|
"group:food_flour"
|
||||||
|
},
|
||||||
|
replacements = {
|
||||||
|
{"group:food_skillet", "farming:skillet"}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
farming = {
|
farming = {
|
||||||
mod = "redo",
|
mod = "redo",
|
||||||
version = "20201213",
|
version = "20210311",
|
||||||
path = minetest.get_modpath("farming"),
|
path = minetest.get_modpath("farming"),
|
||||||
select = {
|
select = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
@ -633,6 +633,8 @@ farming.blackberry = 0.002
|
|||||||
farming.soy = 0.001
|
farming.soy = 0.001
|
||||||
farming.vanilla = 0.001
|
farming.vanilla = 0.001
|
||||||
farming.lettuce = 0.001
|
farming.lettuce = 0.001
|
||||||
|
farming.artichoke = 0.001
|
||||||
|
farming.parsley = 0.002
|
||||||
farming.grains = true
|
farming.grains = true
|
||||||
farming.rarety = 0.002
|
farming.rarety = 0.002
|
||||||
|
|
||||||
@ -703,6 +705,8 @@ ddoo("blackberry.lua", farming.blackberry)
|
|||||||
ddoo("soy.lua", farming.soy)
|
ddoo("soy.lua", farming.soy)
|
||||||
ddoo("vanilla.lua", farming.vanilla)
|
ddoo("vanilla.lua", farming.vanilla)
|
||||||
ddoo("lettuce.lua", farming.lettuce)
|
ddoo("lettuce.lua", farming.lettuce)
|
||||||
|
ddoo("artichoke.lua", farming.artichoke)
|
||||||
|
ddoo("parsley.lua", farming.parsley)
|
||||||
|
|
||||||
dofile(farming.path .. "/food.lua")
|
dofile(farming.path .. "/food.lua")
|
||||||
dofile(farming.path .. "/mapgen.lua")
|
dofile(farming.path .. "/mapgen.lua")
|
||||||
|
@ -155,6 +155,12 @@ Created by Felfa (CC0)
|
|||||||
farming_burger.png
|
farming_burger.png
|
||||||
farming_soy*.png
|
farming_soy*.png
|
||||||
farming_vanilla*.png
|
farming_vanilla*.png
|
||||||
|
farming_artichoke*.png
|
||||||
|
farming_parsley*.png
|
||||||
|
farming_paella.png
|
||||||
|
farming_potato_omelette.png
|
||||||
|
farming_spanish_potatoes.png
|
||||||
|
farming_vanilla_flan.png
|
||||||
|
|
||||||
Created by gorlock (CC0)
|
Created by gorlock (CC0)
|
||||||
farming_salt_crystal.png
|
farming_salt_crystal.png
|
||||||
|
@ -53,6 +53,7 @@ register_plant("cabbage_6", 2, 10, nil, "", -1, farming.cabbage)
|
|||||||
register_plant("lettuce_5", 5, 30, nil, "", -1, farming.lettuce)
|
register_plant("lettuce_5", 5, 30, nil, "", -1, farming.lettuce)
|
||||||
register_plant("blackberry_4", 3, 10, nil, "", -1, farming.blackberry)
|
register_plant("blackberry_4", 3, 10, nil, "", -1, farming.blackberry)
|
||||||
register_plant("vanilla_7", 5, 35, nil, "", -1, farming.vanilla)
|
register_plant("vanilla_7", 5, 35, nil, "", -1, farming.vanilla)
|
||||||
|
register_plant("parsley_3", 10, 40, nil, "", -1, farming.parsley)
|
||||||
register_plant("mint_4", 1, 75, {
|
register_plant("mint_4", 1, 75, {
|
||||||
"default:dirt_with_grass", "default:dirt_with_coniferous_litter"},
|
"default:dirt_with_grass", "default:dirt_with_coniferous_litter"},
|
||||||
"group:water", 1, farming.mint)
|
"group:water", 1, farming.mint)
|
||||||
@ -127,6 +128,28 @@ minetest.register_decoration({
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
if farming.artichoke then
|
||||||
|
minetest.register_decoration({
|
||||||
|
deco_type = "simple",
|
||||||
|
place_on = {"default:dirt_with_grass"},
|
||||||
|
sidelen = 16,
|
||||||
|
noise_params = {
|
||||||
|
offset = 0,
|
||||||
|
scale = tonumber(farming.artichoke) or farming.rarety,
|
||||||
|
spread = {x = 100, y = 100, z = 100},
|
||||||
|
seed = 448,
|
||||||
|
octaves = 3,
|
||||||
|
persist = 0.6
|
||||||
|
},
|
||||||
|
y_min = 1,
|
||||||
|
y_max = 13,
|
||||||
|
decoration = {"farming:artichoke_5"},
|
||||||
|
spawn_by = "group:tree",
|
||||||
|
num_spawn_by = 1,
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
if farming.pepper then
|
if farming.pepper then
|
||||||
|
|
||||||
local tmp1 = {"default:dirt_with_rainforest_litter"} -- v7
|
local tmp1 = {"default:dirt_with_rainforest_litter"} -- v7
|
||||||
|
BIN
mods/farming/textures/farming_artichoke.png
Normal file
After Width: | Height: | Size: 263 B |
BIN
mods/farming/textures/farming_artichoke_1.png
Normal file
After Width: | Height: | Size: 118 B |
BIN
mods/farming/textures/farming_artichoke_2.png
Normal file
After Width: | Height: | Size: 120 B |
BIN
mods/farming/textures/farming_artichoke_3.png
Normal file
After Width: | Height: | Size: 183 B |
BIN
mods/farming/textures/farming_artichoke_4.png
Normal file
After Width: | Height: | Size: 160 B |
BIN
mods/farming/textures/farming_artichoke_5.png
Normal file
After Width: | Height: | Size: 216 B |
BIN
mods/farming/textures/farming_caramel.png
Normal file
After Width: | Height: | Size: 133 B |
BIN
mods/farming/textures/farming_cheese_vegan.png
Normal file
After Width: | Height: | Size: 256 B |
BIN
mods/farming/textures/farming_gyoza.png
Normal file
After Width: | Height: | Size: 603 B |
BIN
mods/farming/textures/farming_onigiri.png
Normal file
After Width: | Height: | Size: 204 B |
BIN
mods/farming/textures/farming_paella.png
Normal file
After Width: | Height: | Size: 487 B |
BIN
mods/farming/textures/farming_parsley.png
Normal file
After Width: | Height: | Size: 606 B |
BIN
mods/farming/textures/farming_parsley_1.png
Normal file
After Width: | Height: | Size: 167 B |
BIN
mods/farming/textures/farming_parsley_2.png
Normal file
After Width: | Height: | Size: 195 B |
BIN
mods/farming/textures/farming_parsley_3.png
Normal file
After Width: | Height: | Size: 270 B |
BIN
mods/farming/textures/farming_potato_omelet.png
Normal file
After Width: | Height: | Size: 687 B |
BIN
mods/farming/textures/farming_spanish_potatoes.png
Normal file
After Width: | Height: | Size: 557 B |
BIN
mods/farming/textures/farming_vanilla_flan.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
@ -44,6 +44,7 @@ if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
|||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "hollytree:holly_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {place_on},
|
place_on = {place_on},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -26,6 +26,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "jacaranda:jacaranda_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_rainforest_litter"},
|
place_on = {"default:dirt_with_rainforest_litter"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -26,6 +26,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "larch:larch_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_coniferous_litter"},
|
place_on = {"default:dirt_with_coniferous_litter"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -388,7 +388,7 @@ local on_digiline_receive_string = function(pos, node, channel, msg)
|
|||||||
end
|
end
|
||||||
else
|
else
|
||||||
local asc = string.byte(msg)
|
local asc = string.byte(msg)
|
||||||
if asc > 29 and asc < 256 then
|
if asc > 30 and asc < 256 then
|
||||||
minetest.swap_node(pos, { name = "led_marquee:char_"..asc, param2 = fdir + (last_color*8)})
|
minetest.swap_node(pos, { name = "led_marquee:char_"..asc, param2 = fdir + (last_color*8)})
|
||||||
meta:set_string("last_msg", tostring(msg))
|
meta:set_string("last_msg", tostring(msg))
|
||||||
meta:set_int("index", 1)
|
meta:set_int("index", 1)
|
||||||
|
@ -69,6 +69,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "lemontree:lemon_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_grass"},
|
place_on = {"default:dirt_with_grass"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -28,6 +28,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "mahogany:mahogany_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_rainforest_litter"},
|
place_on = {"default:dirt_with_rainforest_litter"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -40,6 +40,7 @@ if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
|||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "maple:maple_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {place_on},
|
place_on = {place_on},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
62
mods/mesecons/fifo_queue.lua
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
|
||||||
|
-- a simple first-in-first-out queue
|
||||||
|
-- very similar to the one in https://github.com/minetest/minetest/pull/7683
|
||||||
|
|
||||||
|
local fifo_queue = {}
|
||||||
|
|
||||||
|
local metatable = {__index = fifo_queue}
|
||||||
|
|
||||||
|
-- creates a new empty queue
|
||||||
|
function fifo_queue.new()
|
||||||
|
local q = {n_in = 0, n_out = 0, i_out = 1, buf_in = {}, buf_out = {}}
|
||||||
|
setmetatable(q, metatable)
|
||||||
|
return q
|
||||||
|
end
|
||||||
|
|
||||||
|
-- adds an element to the queue
|
||||||
|
function fifo_queue.add(self, v)
|
||||||
|
local n = self.n_in + 1
|
||||||
|
self.n_in = n
|
||||||
|
self.buf_in[n] = v
|
||||||
|
end
|
||||||
|
|
||||||
|
-- removes and returns the next element, or nil of empty
|
||||||
|
function fifo_queue.take(self)
|
||||||
|
local i_out = self.i_out
|
||||||
|
if i_out <= self.n_out then
|
||||||
|
local v = self.buf_out[i_out]
|
||||||
|
self.i_out = i_out + 1
|
||||||
|
self.buf_out[i_out] = true
|
||||||
|
return v
|
||||||
|
end
|
||||||
|
|
||||||
|
-- buf_out is empty, try to swap
|
||||||
|
self.i_out = 1
|
||||||
|
self.n_out = 0
|
||||||
|
if self.n_in == 0 then
|
||||||
|
return nil -- empty
|
||||||
|
end
|
||||||
|
|
||||||
|
-- swap
|
||||||
|
self.n_out = self.n_in
|
||||||
|
self.n_in = 0
|
||||||
|
self.buf_out, self.buf_in = self.buf_in, self.buf_out
|
||||||
|
|
||||||
|
local v = self.buf_out[1]
|
||||||
|
self.i_out = 2
|
||||||
|
self.buf_out[1] = true
|
||||||
|
return v
|
||||||
|
end
|
||||||
|
|
||||||
|
-- returns whether the queue is empty
|
||||||
|
function fifo_queue.is_empty(self)
|
||||||
|
return self.n_out == self.i_out + 1 and self.n_in == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
-- returns stuff for iteration in a for loop, like pairs
|
||||||
|
-- adding new elements while iterating is no problem
|
||||||
|
function fifo_queue.iter(self)
|
||||||
|
return fifo_queue.take, self, nil
|
||||||
|
end
|
||||||
|
|
||||||
|
return fifo_queue
|
@ -11,7 +11,7 @@
|
|||||||
|
|
||||||
-- RECEPTORS
|
-- RECEPTORS
|
||||||
-- mesecon.is_receptor(nodename) --> Returns true if nodename is a receptor
|
-- mesecon.is_receptor(nodename) --> Returns true if nodename is a receptor
|
||||||
-- mesecon.is_receptor_on(nodename --> Returns true if nodename is an receptor with state = mesecon.state.on
|
-- mesecon.is_receptor_on(nodename) --> Returns true if nodename is an receptor with state = mesecon.state.on
|
||||||
-- mesecon.is_receptor_off(nodename) --> Returns true if nodename is an receptor with state = mesecon.state.off
|
-- mesecon.is_receptor_off(nodename) --> Returns true if nodename is an receptor with state = mesecon.state.off
|
||||||
-- mesecon.receptor_get_rules(node) --> Returns the rules of the receptor (mesecon.rules.default if none specified)
|
-- mesecon.receptor_get_rules(node) --> Returns the rules of the receptor (mesecon.rules.default if none specified)
|
||||||
|
|
||||||
@ -46,6 +46,8 @@
|
|||||||
-- mesecon.rotate_rules_down(rules)
|
-- mesecon.rotate_rules_down(rules)
|
||||||
-- These functions return rules that have been rotated in the specific direction
|
-- These functions return rules that have been rotated in the specific direction
|
||||||
|
|
||||||
|
local fifo_queue = dofile(minetest.get_modpath("mesecons").."/fifo_queue.lua")
|
||||||
|
|
||||||
-- General
|
-- General
|
||||||
function mesecon.get_effector(nodename)
|
function mesecon.get_effector(nodename)
|
||||||
if minetest.registered_nodes[nodename]
|
if minetest.registered_nodes[nodename]
|
||||||
@ -371,32 +373,39 @@ end
|
|||||||
-- Follow all all conductor paths replacing conductors that were already
|
-- Follow all all conductor paths replacing conductors that were already
|
||||||
-- looked at, activating / changing all effectors along the way.
|
-- looked at, activating / changing all effectors along the way.
|
||||||
function mesecon.turnon(pos, link)
|
function mesecon.turnon(pos, link)
|
||||||
local frontiers = {{pos = pos, link = link}}
|
local frontiers = fifo_queue.new()
|
||||||
|
frontiers:add({pos = pos, link = link})
|
||||||
|
local pos_can_be_skipped = {}
|
||||||
|
|
||||||
local depth = 1
|
local depth = 1
|
||||||
while frontiers[1] do
|
for f in frontiers:iter() do
|
||||||
local f = table.remove(frontiers, 1)
|
|
||||||
local node = mesecon.get_node_force(f.pos)
|
local node = mesecon.get_node_force(f.pos)
|
||||||
|
|
||||||
if not node then
|
if not node then
|
||||||
-- Area does not exist; do nothing
|
-- Area does not exist; do nothing
|
||||||
|
pos_can_be_skipped[minetest.hash_node_position(f.pos)] = true
|
||||||
elseif mesecon.is_conductor_off(node, f.link) then
|
elseif mesecon.is_conductor_off(node, f.link) then
|
||||||
local rules = mesecon.conductor_get_rules(node)
|
local rules = mesecon.conductor_get_rules(node)
|
||||||
|
|
||||||
-- Call turnon on neighbors
|
-- Call turnon on neighbors
|
||||||
for _, r in ipairs(mesecon.rule2meta(f.link, rules)) do
|
for _, r in ipairs(mesecon.rule2meta(f.link, rules)) do
|
||||||
local np = vector.add(f.pos, r)
|
local np = vector.add(f.pos, r)
|
||||||
for _, l in ipairs(mesecon.rules_link_rule_all(f.pos, r)) do
|
if not pos_can_be_skipped[minetest.hash_node_position(np)] then
|
||||||
table.insert(frontiers, {pos = np, link = l})
|
for _, l in ipairs(mesecon.rules_link_rule_all(f.pos, r)) do
|
||||||
|
frontiers:add({pos = np, link = l})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
mesecon.swap_node_force(f.pos, mesecon.get_conductor_on(node, f.link))
|
mesecon.swap_node_force(f.pos, mesecon.get_conductor_on(node, f.link))
|
||||||
|
pos_can_be_skipped[minetest.hash_node_position(f.pos)] = true
|
||||||
elseif mesecon.is_effector(node.name) then
|
elseif mesecon.is_effector(node.name) then
|
||||||
mesecon.changesignal(f.pos, node, f.link, mesecon.state.on, depth)
|
mesecon.changesignal(f.pos, node, f.link, mesecon.state.on, depth)
|
||||||
if mesecon.is_effector_off(node.name) then
|
if mesecon.is_effector_off(node.name) then
|
||||||
mesecon.activate(f.pos, node, f.link, depth)
|
mesecon.activate(f.pos, node, f.link, depth)
|
||||||
end
|
end
|
||||||
|
else
|
||||||
|
pos_can_be_skipped[minetest.hash_node_position(f.pos)] = true
|
||||||
end
|
end
|
||||||
depth = depth + 1
|
depth = depth + 1
|
||||||
end
|
end
|
||||||
@ -419,37 +428,42 @@ end
|
|||||||
-- depth = indicates order in which signals wire fired, higher is later
|
-- depth = indicates order in which signals wire fired, higher is later
|
||||||
-- }
|
-- }
|
||||||
function mesecon.turnoff(pos, link)
|
function mesecon.turnoff(pos, link)
|
||||||
local frontiers = {{pos = pos, link = link}}
|
local frontiers = fifo_queue.new()
|
||||||
|
frontiers:add({pos = pos, link = link})
|
||||||
local signals = {}
|
local signals = {}
|
||||||
|
local pos_can_be_skipped = {}
|
||||||
|
|
||||||
local depth = 1
|
local depth = 1
|
||||||
while frontiers[1] do
|
for f in frontiers:iter() do
|
||||||
local f = table.remove(frontiers, 1)
|
|
||||||
local node = mesecon.get_node_force(f.pos)
|
local node = mesecon.get_node_force(f.pos)
|
||||||
|
|
||||||
if not node then
|
if not node then
|
||||||
-- Area does not exist; do nothing
|
-- Area does not exist; do nothing
|
||||||
|
pos_can_be_skipped[minetest.hash_node_position(f.pos)] = true
|
||||||
elseif mesecon.is_conductor_on(node, f.link) then
|
elseif mesecon.is_conductor_on(node, f.link) then
|
||||||
local rules = mesecon.conductor_get_rules(node)
|
local rules = mesecon.conductor_get_rules(node)
|
||||||
for _, r in ipairs(mesecon.rule2meta(f.link, rules)) do
|
for _, r in ipairs(mesecon.rule2meta(f.link, rules)) do
|
||||||
local np = vector.add(f.pos, r)
|
local np = vector.add(f.pos, r)
|
||||||
|
|
||||||
-- Check if an onstate receptor is connected. If that is the case,
|
if not pos_can_be_skipped[minetest.hash_node_position(np)] then
|
||||||
-- abort this turnoff process by returning false. `receptor_off` will
|
-- Check if an onstate receptor is connected. If that is the case,
|
||||||
-- discard all the changes that we made in the voxelmanip:
|
-- abort this turnoff process by returning false. `receptor_off` will
|
||||||
for _, l in ipairs(mesecon.rules_link_rule_all_inverted(f.pos, r)) do
|
-- discard all the changes that we made in the voxelmanip:
|
||||||
if mesecon.is_receptor_on(mesecon.get_node_force(np).name) then
|
if mesecon.rules_link_rule_all_inverted(f.pos, r)[1] then
|
||||||
return false
|
if mesecon.is_receptor_on(mesecon.get_node_force(np).name) then
|
||||||
|
return false
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
-- Call turnoff on neighbors
|
-- Call turnoff on neighbors
|
||||||
for _, l in ipairs(mesecon.rules_link_rule_all(f.pos, r)) do
|
for _, l in ipairs(mesecon.rules_link_rule_all(f.pos, r)) do
|
||||||
table.insert(frontiers, {pos = np, link = l})
|
frontiers:add({pos = np, link = l})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
mesecon.swap_node_force(f.pos, mesecon.get_conductor_off(node, f.link))
|
mesecon.swap_node_force(f.pos, mesecon.get_conductor_off(node, f.link))
|
||||||
|
pos_can_be_skipped[minetest.hash_node_position(f.pos)] = true
|
||||||
elseif mesecon.is_effector(node.name) then
|
elseif mesecon.is_effector(node.name) then
|
||||||
table.insert(signals, {
|
table.insert(signals, {
|
||||||
pos = f.pos,
|
pos = f.pos,
|
||||||
@ -457,6 +471,8 @@ function mesecon.turnoff(pos, link)
|
|||||||
link = f.link,
|
link = f.link,
|
||||||
depth = depth
|
depth = depth
|
||||||
})
|
})
|
||||||
|
else
|
||||||
|
pos_can_be_skipped[minetest.hash_node_position(f.pos)] = true
|
||||||
end
|
end
|
||||||
depth = depth + 1
|
depth = depth + 1
|
||||||
end
|
end
|
||||||
|
@ -194,7 +194,7 @@ local nodes = {
|
|||||||
description = S("Iron Glass"),
|
description = S("Iron Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^[colorize:#DEDEDE", "default_glass_detail.png^[colorize:#DEDEDE"},
|
tiles = {"default_glass.png^[colorize:#DEDEDE", "default_glass_detail.png^[colorize:#DEDEDE"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -205,7 +205,7 @@ local nodes = {
|
|||||||
description = S("Coal Glass"),
|
description = S("Coal Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^[colorize:#828282", "default_glass_detail.png^[colorize:#828282"},
|
tiles = {"default_glass.png^[colorize:#828282", "default_glass_detail.png^[colorize:#828282"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -216,7 +216,7 @@ local nodes = {
|
|||||||
description = S("Clean Glass"),
|
description = S("Clean Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"moreblocks_clean_glass.png", "moreblocks_clean_glass_detail.png"},
|
tiles = {"moreblocks_clean_glass.png", "moreblocks_clean_glass_detail.png"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -316,7 +316,7 @@ local nodes = {
|
|||||||
description = S("Trap Glass"),
|
description = S("Trap Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^moreblocks_trap_box_glass.png", "default_glass_detail.png"},
|
tiles = {"default_glass.png^moreblocks_trap_box_glass.png", "default_glass_detail.png"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -329,7 +329,7 @@ local nodes = {
|
|||||||
description = S("Trap Obsidian Glass"),
|
description = S("Trap Obsidian Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_obsidian_glass.png^moreblocks_trap_box_glass.png", "default_obsidian_glass_detail.png"},
|
tiles = {"default_obsidian_glass.png^moreblocks_trap_box_glass.png", "default_obsidian_glass_detail.png"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -353,7 +353,7 @@ local nodes = {
|
|||||||
description = S("Trap Clean Glass"),
|
description = S("Trap Clean Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"moreblocks_clean_glass.png^moreblocks_trap_box_glass.png", "moreblocks_clean_glass_detail.png"},
|
tiles = {"moreblocks_clean_glass.png^moreblocks_trap_box_glass.png", "moreblocks_clean_glass_detail.png"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -412,7 +412,7 @@ local nodes = {
|
|||||||
description = S("Glow Glass"),
|
description = S("Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^[colorize:#E9CD61", "default_glass_detail.png^[colorize:#E9CD61"},
|
tiles = {"default_glass.png^[colorize:#E9CD61", "default_glass_detail.png^[colorize:#E9CD61"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -424,7 +424,7 @@ local nodes = {
|
|||||||
description = S("Clean Glow Glass"),
|
description = S("Clean Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"moreblocks_clean_glass.png^[colorize:#E9CD61", "moreblocks_clean_glass_detail.png^[colorize:#E9CD61"},
|
tiles = {"moreblocks_clean_glass.png^[colorize:#E9CD61", "moreblocks_clean_glass_detail.png^[colorize:#E9CD61"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -436,7 +436,7 @@ local nodes = {
|
|||||||
description = S("Trap Glow Glass"),
|
description = S("Trap Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^[colorize:#E9CD61^moreblocks_trap_box_glass.png", "default_glass_detail.png^[colorize:#E9CD61"},
|
tiles = {"default_glass.png^[colorize:#E9CD61^moreblocks_trap_box_glass.png", "default_glass_detail.png^[colorize:#E9CD61"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -450,7 +450,7 @@ local nodes = {
|
|||||||
description = S("Trap Clean Glow Glass"),
|
description = S("Trap Clean Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"moreblocks_clean_glass.png^[colorize:#E9CD61^moreblocks_trap_box_glass.png", "moreblocks_clean_glass_detail.png^[colorize:#E9CD61"},
|
tiles = {"moreblocks_clean_glass.png^[colorize:#E9CD61^moreblocks_trap_box_glass.png", "moreblocks_clean_glass_detail.png^[colorize:#E9CD61"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -464,7 +464,7 @@ local nodes = {
|
|||||||
description = S("Super Glow Glass"),
|
description = S("Super Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^[colorize:#FFFF78", "default_glass_detail.png^[colorize:#FFFF78"},
|
tiles = {"default_glass.png^[colorize:#FFFF78", "default_glass_detail.png^[colorize:#FFFF78"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -476,7 +476,7 @@ local nodes = {
|
|||||||
description = S("Clean Super Glow Glass"),
|
description = S("Clean Super Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"moreblocks_clean_glass.png^[colorize:#FFFF78", "moreblocks_clean_glass_detail.png^[colorize:#FFFF78"},
|
tiles = {"moreblocks_clean_glass.png^[colorize:#FFFF78", "moreblocks_clean_glass_detail.png^[colorize:#FFFF78"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -488,7 +488,7 @@ local nodes = {
|
|||||||
description = S("Trap Super Glow Glass"),
|
description = S("Trap Super Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"default_glass.png^[colorize:#FFFF78^moreblocks_trap_box_glass.png", "default_glass_detail.png^[colorize:#FFFF78"},
|
tiles = {"default_glass.png^[colorize:#FFFF78^moreblocks_trap_box_glass.png", "default_glass_detail.png^[colorize:#FFFF78"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
@ -502,7 +502,7 @@ local nodes = {
|
|||||||
description = S("Trap Clean Super Glow Glass"),
|
description = S("Trap Clean Super Glow Glass"),
|
||||||
drawtype = "glasslike_framed_optional",
|
drawtype = "glasslike_framed_optional",
|
||||||
tiles = {"moreblocks_clean_glass.png^[colorize:#FFFF78^moreblocks_trap_box_glass.png", "moreblocks_clean_glass_detail.png^[colorize:#FFFF78"},
|
tiles = {"moreblocks_clean_glass.png^[colorize:#FFFF78^moreblocks_trap_box_glass.png", "moreblocks_clean_glass_detail.png^[colorize:#FFFF78"},
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "clip",
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
|
@ -65,6 +65,7 @@ if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
|||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "oak:oak_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {place_on},
|
place_on = {place_on},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -22,6 +22,7 @@ end
|
|||||||
--
|
--
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "palm:palm_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:sand"},
|
place_on = {"default:sand"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -27,6 +27,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "pineapple:pineapple_shrub",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt_with_rainforest_litter"},
|
place_on = {"default:dirt_with_rainforest_litter"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -88,6 +88,7 @@ if minetest.get_modpath("rainf") then
|
|||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "plumtree:plum_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {place_on},
|
place_on = {place_on},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -50,6 +50,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "pomegranate:pomegranate_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dry_dirt"},
|
place_on = {"default:dry_dirt"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|
@ -52,7 +52,7 @@ minetest.register_node("stained_glass:stained_glass", {
|
|||||||
paramtype2 = "color",
|
paramtype2 = "color",
|
||||||
palette = "unifieddyes_palette_extended.png",
|
palette = "unifieddyes_palette_extended.png",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "blend",
|
||||||
light_source = myglow,
|
light_source = myglow,
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
walkable = true,
|
walkable = true,
|
||||||
@ -78,7 +78,7 @@ minetest.register_node("stained_glass:stained_trap_glass", {
|
|||||||
paramtype2 = "color",
|
paramtype2 = "color",
|
||||||
palette = "unifieddyes_palette_extended.png",
|
palette = "unifieddyes_palette_extended.png",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
use_texture_alpha = true,
|
use_texture_alpha = "blend",
|
||||||
light_source = myglow,
|
light_source = myglow,
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
|
@ -6,7 +6,6 @@ local defaults = {
|
|||||||
enable_granite_generation = "true",
|
enable_granite_generation = "true",
|
||||||
enable_marble_generation = "true",
|
enable_marble_generation = "true",
|
||||||
enable_rubber_tree_generation = "true",
|
enable_rubber_tree_generation = "true",
|
||||||
enable_steel_override = "true",
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for k, v in pairs(defaults) do
|
for k, v in pairs(defaults) do
|
||||||
|
@ -50,6 +50,11 @@ minetest.register_craftitem(":technic:sulfur_lump", {
|
|||||||
|
|
||||||
minetest.register_alias("technic:wrought_iron_ingot", "default:steel_ingot")
|
minetest.register_alias("technic:wrought_iron_ingot", "default:steel_ingot")
|
||||||
|
|
||||||
|
minetest.override_item("default:steel_ingot", {
|
||||||
|
description = S("Wrought Iron Ingot"),
|
||||||
|
inventory_image = "technic_wrought_iron_ingot.png",
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_craftitem(":technic:cast_iron_ingot", {
|
minetest.register_craftitem(":technic:cast_iron_ingot", {
|
||||||
description = S("Cast Iron Ingot"),
|
description = S("Cast Iron Ingot"),
|
||||||
inventory_image = "technic_cast_iron_ingot.png",
|
inventory_image = "technic_cast_iron_ingot.png",
|
||||||
@ -161,34 +166,27 @@ local function for_each_registered_item(action)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if technic.config:get_bool("enable_steel_override") then
|
local steel_to_iron = {}
|
||||||
minetest.override_item("default:steel_ingot", {
|
for _, i in ipairs({
|
||||||
description = S("Wrought Iron Ingot"),
|
"default:axe_steel",
|
||||||
inventory_image = "technic_wrought_iron_ingot.png",
|
"default:pick_steel",
|
||||||
})
|
"default:shovel_steel",
|
||||||
|
"default:sword_steel",
|
||||||
local steel_to_iron = {}
|
"doors:door_steel",
|
||||||
for _, i in ipairs({
|
"farming:hoe_steel",
|
||||||
"default:axe_steel",
|
"glooptest:hammer_steel",
|
||||||
"default:pick_steel",
|
"glooptest:handsaw_steel",
|
||||||
"default:shovel_steel",
|
"glooptest:reinforced_crystal_glass",
|
||||||
"default:sword_steel",
|
"mesecons_doors:op_door_steel",
|
||||||
"doors:door_steel",
|
"mesecons_doors:sig_door_steel",
|
||||||
"farming:hoe_steel",
|
"vessels:steel_bottle",
|
||||||
"glooptest:hammer_steel",
|
}) do
|
||||||
"glooptest:handsaw_steel",
|
steel_to_iron[i] = true
|
||||||
"glooptest:reinforced_crystal_glass",
|
|
||||||
"mesecons_doors:op_door_steel",
|
|
||||||
"mesecons_doors:sig_door_steel",
|
|
||||||
"vessels:steel_bottle",
|
|
||||||
}) do
|
|
||||||
steel_to_iron[i] = true
|
|
||||||
end
|
|
||||||
|
|
||||||
for_each_registered_item(function(item_name)
|
|
||||||
local item_def = minetest.registered_items[item_name]
|
|
||||||
if steel_to_iron[item_name] and string.find(item_def.description, "Steel") then
|
|
||||||
minetest.override_item(item_name, { description = string.gsub(item_def.description, "Steel", S("Iron")) })
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
for_each_registered_item(function(item_name)
|
||||||
|
local item_def = minetest.registered_items[item_name]
|
||||||
|
if steel_to_iron[item_name] and string.find(item_def.description, "Steel") then
|
||||||
|
minetest.override_item(item_name, { description = string.gsub(item_def.description, "Steel", S("Iron")) })
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
@ -104,6 +104,11 @@ minetest.register_node(":technic:lead_block", {
|
|||||||
|
|
||||||
minetest.register_alias("technic:wrought_iron_block", "default:steelblock")
|
minetest.register_alias("technic:wrought_iron_block", "default:steelblock")
|
||||||
|
|
||||||
|
minetest.override_item("default:steelblock", {
|
||||||
|
description = S("Wrought Iron Block"),
|
||||||
|
tiles = { "technic_wrought_iron_block.png" },
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_node(":technic:cast_iron_block", {
|
minetest.register_node(":technic:cast_iron_block", {
|
||||||
description = S("Cast Iron Block"),
|
description = S("Cast Iron Block"),
|
||||||
tiles = { "technic_cast_iron_block.png" },
|
tiles = { "technic_cast_iron_block.png" },
|
||||||
@ -151,40 +156,33 @@ local function for_each_registered_node(action)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if technic.config:get_bool("enable_steel_override") then
|
for_each_registered_node(function(node_name, node_def)
|
||||||
minetest.override_item("default:steelblock", {
|
if node_name ~= "default:steelblock" and
|
||||||
description = S("Wrought Iron Block"),
|
node_name:find("steelblock", 1, true) and
|
||||||
tiles = { "technic_wrought_iron_block.png" },
|
node_def.description:find("Steel", 1, true) then
|
||||||
})
|
minetest.override_item(node_name, {
|
||||||
|
description = node_def.description:gsub("Steel", S("Wrought Iron")),
|
||||||
for_each_registered_node(function(node_name, node_def)
|
})
|
||||||
if node_name ~= "default:steelblock" and
|
end
|
||||||
node_name:find("steelblock", 1, true) and
|
local tiles = node_def.tiles or node_def.tile_images
|
||||||
node_def.description:find("Steel", 1, true) then
|
if tiles then
|
||||||
|
local new_tiles = {}
|
||||||
|
local do_override = false
|
||||||
|
if type(tiles) == "string" then
|
||||||
|
tiles = {tiles}
|
||||||
|
end
|
||||||
|
for i, t in ipairs(tiles) do
|
||||||
|
if type(t) == "string" and t == "default_steel_block.png" then
|
||||||
|
do_override = true
|
||||||
|
t = "technic_wrought_iron_block.png"
|
||||||
|
end
|
||||||
|
table.insert(new_tiles, t)
|
||||||
|
end
|
||||||
|
if do_override then
|
||||||
minetest.override_item(node_name, {
|
minetest.override_item(node_name, {
|
||||||
description = node_def.description:gsub("Steel", S("Wrought Iron")),
|
tiles = new_tiles
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
local tiles = node_def.tiles or node_def.tile_images
|
end
|
||||||
if tiles then
|
end)
|
||||||
local new_tiles = {}
|
|
||||||
local do_override = false
|
|
||||||
if type(tiles) == "string" then
|
|
||||||
tiles = {tiles}
|
|
||||||
end
|
|
||||||
for i, t in ipairs(tiles) do
|
|
||||||
if type(t) == "string" and t == "default_steel_block.png" then
|
|
||||||
do_override = true
|
|
||||||
t = "technic_wrought_iron_block.png"
|
|
||||||
end
|
|
||||||
table.insert(new_tiles, t)
|
|
||||||
end
|
|
||||||
if do_override then
|
|
||||||
minetest.override_item(node_name, {
|
|
||||||
tiles = new_tiles
|
|
||||||
})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
@ -1,2 +0,0 @@
|
|||||||
default
|
|
||||||
function_delayer
|
|
2
mods/titanium/mod.conf
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
name = titanium
|
||||||
|
depends = default,function_delayer
|
@ -27,6 +27,7 @@ end
|
|||||||
|
|
||||||
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
if mg_name ~= "v6" and mg_name ~= "singlenode" then
|
||||||
minetest.register_decoration({
|
minetest.register_decoration({
|
||||||
|
name = "willow:willow_tree",
|
||||||
deco_type = "schematic",
|
deco_type = "schematic",
|
||||||
place_on = {"default:dirt"},
|
place_on = {"default:dirt"},
|
||||||
sidelen = 16,
|
sidelen = 16,
|
||||||
|