diff options
author | TenPlus1 <kinsellaja@yahoo.com> | 2016-05-17 21:40:05 +0100 |
---|---|---|
committer | TenPlus1 <kinsellaja@yahoo.com> | 2016-05-17 21:40:05 +0100 |
commit | b1f0ded17316dcaf729c3dc2d7d21aed70c2b7ca (patch) | |
tree | adc72eb32963a67a19863bc8e3060cb4b7df1d1b /onion.lua | |
parent | c47c840f2aaf35c9ea284be191798cb3a566b175 (diff) |
Ethereal NG 1.20 release for minetest 0.4.14
Diffstat (limited to 'onion.lua')
-rw-r--r-- | onion.lua | 110 |
1 files changed, 47 insertions, 63 deletions
@@ -1,116 +1,100 @@ --- Wild Onion Plant
+
+-- wild onion
minetest.register_craftitem("ethereal:wild_onion_plant", {
description = "Wild Onion",
- groups = {not_in_creative_inventory=1},
inventory_image = "wild_onion.png",
wield_image = "wild_onion.png",
- on_use = minetest.item_eat(2),
on_place = function(itemstack, placer, pointed_thing)
return farming.place_seed(itemstack, placer, pointed_thing, "ethereal:wild_onion_1")
- end
+ end,
+ on_use = minetest.item_eat(2),
})
-- Define Onion growth stages
-local onion_def = {
+local crop_def = {
drawtype = "plantlike",
tiles = {"ethereal_wild_onion_1.png"},
paramtype = "light",
sunlight_propagates = true,
walkable = false,
buildable_to = true,
- drop = {
- items = {
- {items = {"ethereal:wild_onion_plant"}, rarity = 1},
- }
- },
+ drop = "",
selection_box = {
type = "fixed",
fixed = {-0.5, -0.5, -0.5, 0.5, -5/16, 0.5}
},
groups = {
snappy = 3, flammable = 2, plant = 1, attached_node = 1,
- onion = 1, growing = 1, not_in_creative_inventory = 1
+ growing = 1, not_in_creative_inventory = 1
},
sounds = default.node_sound_leaves_defaults(),
}
-minetest.register_node("ethereal:onion_1", table.copy(onion_def))
-onion_def.tiles[1] = "ethereal_wild_onion_2.png"
-onion_def.groups.onion = 2
-minetest.register_node("ethereal:onion_2", table.copy(onion_def))
+--stage 1
+minetest.register_node("ethereal:onion_1", table.copy(crop_def))
-onion_def.tiles[1] = "ethereal_wild_onion_3.png"
-onion_def.groups.onion = 3
-onion_def.drop.items[2] = {
- items = {"ethereal:wild_onion_plant 2"}, rarity = 3
-}
-minetest.register_node("ethereal:onion_3", table.copy(onion_def))
+--stage 2
+crop_def.tiles = {"ethereal_wild_onion_2.png"}
+minetest.register_node("ethereal:onion_2", table.copy(crop_def))
+
+--stage 3
+crop_def.tiles = {"ethereal_wild_onion_3.png"}
+minetest.register_node("ethereal:onion_3", table.copy(crop_def))
-onion_def.tiles[1] = "ethereal_wild_onion_4.png"
-onion_def.groups.onion = 4
-onion_def.drop.items[2] = {
- items = {"ethereal:wild_onion_plant 3"}, rarity = 3
+--stage 4
+crop_def.tiles = {"ethereal_wild_onion_4.png"}
+crop_def.drop = {
+ items = {
+ {items = {"ethereal:wild_onion_plant"}, rarity = 1},
+ {items = {"ethereal:wild_onion_plant 2"}, rarity = 3},
+ }
}
-minetest.register_node("ethereal:onion_4", table.copy(onion_def))
+minetest.register_node("ethereal:onion_4", table.copy(crop_def))
-onion_def.tiles[1] = "ethereal_wild_onion_5.png"
-onion_def.groups.onion = 5
-onion_def.groups.growing = nil
-onion_def.drop.items = {
- {items = {"ethereal:wild_onion_plant 2"}, rarity = 1},
- {items = {"ethereal:wild_onion_plant 3"}, rarity = 2},
+--stage 5
+crop_def.tiles = {"ethereal_wild_onion_5.png"}
+crop_def.groups.growing = 0
+crop_def.drop = {
+ items = {
+ {items = {"ethereal:wild_onion_plant 2"}, rarity = 1},
+ {items = {"ethereal:wild_onion_plant 3"}, rarity = 2},
+ }
}
-minetest.register_node("ethereal:onion_5", table.copy(onion_def))
+minetest.register_node("ethereal:onion_5", table.copy(crop_def))
--- Abm for growing Wild Onion
-if farming.mod ~= "redo" then
+-- growing routine if farming redo isn't present
+if not farming or not farming.mod or farming.mod ~= "redo" then
minetest.register_abm({
- nodenames = {"group:onion"},
+ nodenames = {"ethereal:onion_1", "ethereal:onion_2", "ethereal:onion_3", "ethereal:onion_4"},
neighbors = {"farming:soil_wet"},
- interval = 50,
- chance = 3,
+ interval = 9,
+ chance = 20,
catch_up = false,
action = function(pos, node)
- -- return if already full grown
- if minetest.get_item_group(node.name, "growing") < 1 then
- return
- end
-
- -- check if on wet soil
+ -- are we on wet soil?
pos.y = pos.y - 1
if minetest.get_item_group(minetest.get_node(pos).name, "soil") < 3 then
return
end
pos.y = pos.y + 1
- -- check light
+ -- do we have enough light?
local light = minetest.get_node_light(pos)
+
if not light
or light < 13 then
return
end
- -- grow
- node.name = "ethereal:onion_"..minetest.get_item_group(node.name, "onion") + 1
+ -- grow to next stage
+ local num = node.name:split("_")[2]
+
+ node.name = "ethereal:onion_" .. tonumber(num + 1)
+
minetest.swap_node(pos, node)
end
})
-end
-
-
--- Legacy
-
-minetest.register_alias("ethereal:wild_onion_craftingitem", "ethereal:wild_onion_plant")
-
-for i = 1, 5 do
- minetest.register_alias("ethereal:wild_onion_"..i, "ethereal:onion_"..i)
-end
-
--- Temporary compatibility lines for Xanadu server
-minetest.register_alias("ethereal:onion_7", "ethereal:onion_4")
-minetest.register_alias("ethereal:onion_8", "ethereal:onion_5")
-minetest.register_alias("ethereal:wild_onion_7", "ethereal:onion_4")
-minetest.register_alias("ethereal:wild_onion_8", "ethereal:onion_5")
+end -- END IF
|