diff options
author | root <root@mirzakhani.gpcf.eu> | 2018-06-10 22:10:34 +0200 |
---|---|---|
committer | root <root@mirzakhani.gpcf.eu> | 2018-06-10 22:10:34 +0200 |
commit | 482a3b4f340c3a307a292271a1291b065e92bee8 (patch) | |
tree | fa1853bbb28aac1fc9b47e0cb52a4d1c11d2d616 /extranodes | |
parent | e91de893b92bf57fc7f47f88eb4f654177908056 (diff) | |
parent | 9a5adfc41836bec4d171860f4870b422cd8b6bff (diff) |
Merge https://git.bananach.space/technic
Diffstat (limited to 'extranodes')
-rw-r--r-- | extranodes/antishroom.lua | 70 | ||||
-rw-r--r-- | extranodes/depends.txt | 1 | ||||
-rw-r--r-- | extranodes/init.lua | 10 | ||||
-rw-r--r-- | extranodes/textures/antishroom.png | bin | 0 -> 333 bytes | |||
-rw-r--r-- | extranodes/textures/antishroom_wield.png | bin | 0 -> 303 bytes |
5 files changed, 81 insertions, 0 deletions
diff --git a/extranodes/antishroom.lua b/extranodes/antishroom.lua new file mode 100644 index 0000000..e3259c1 --- /dev/null +++ b/extranodes/antishroom.lua @@ -0,0 +1,70 @@ +-- a tool to convert a mushroom biome into green forest with thick trees and flowers + +local S = rawget(_G, "intllib") and intllib.Getter() or function(s) return s end + +minetest.register_craftitem(":technic:antishroom",{ + description = "Mushroom biome converter", + inventory_image = "antishroom.png", + wield_image = "antishroom_wield.png", + on_use = function(itemstack, user, pointed_thing) + + if pointed_thing.type ~= "node" then + return itemstack + end + + local pos = pointed_thing.under + local target = minetest.get_node_or_nil(pos) + + if target and target.name == "ethereal:mushroom_dirt" then + + local start_pos = { + x = pos.x - 10, + z = pos.z - 10, + y = pos.y - 5 + } + + local end_pos = { + x = pos.x + 10, + z = pos.z + 10, + y = pos.y + 15 + } + + local rlist = { + ["ethereal:mushroom_dirt"] = "default:dirt_with_grass", + ["ethereal:mushroom_trunk"] = "default:tree", + ["ethereal:mushroom"] = "default:leaves", + ["ethereal:mushroom_pore"] = "default:apple" + } + + local mlist = {} + for t,r in pairs(rlist) do + table.insert(mlist, t) + end + + local found_mushroom_parts = minetest.find_nodes_in_area(start_pos, end_pos, mlist) + for _, f in ipairs(found_mushroom_parts) do + local node = minetest.get_node(f) + + if not minetest.is_protected(f, user:get_player_name()) then + + minetest.swap_node(f, { name = rlist[node.name] } ) + + if minetest.get_modpath("bonemeal") and node.name == "ethereal:mushroom_dirt" then + if math.random(1,5) > 4 then + bonemeal:on_use(f, 1, nil) + end + end + + end + + end + + itemstack:take_item() + return itemstack + else + return itemstack + end + + + end, +})
\ No newline at end of file diff --git a/extranodes/depends.txt b/extranodes/depends.txt index fa27879..ff994f8 100644 --- a/extranodes/depends.txt +++ b/extranodes/depends.txt @@ -7,3 +7,4 @@ concrete unifieddyes? intllib? moreblocks? +pkarcs? diff --git a/extranodes/init.lua b/extranodes/init.lua index 69cb820..edaa41a 100644 --- a/extranodes/init.lua +++ b/extranodes/init.lua @@ -11,6 +11,10 @@ dofile(path.."/extratubes.lua") dofile(path.."/extramesecons.lua") dofile(path.."/lox.lua") +if minetest.get_modpath("ethereal") and minetest.get_modpath("flowers") then + dofile(path.."/antishroom.lua") +end + if minetest.get_modpath("bakedclay") then -- bring back them sticks minetest.register_craft( { @@ -20,6 +24,12 @@ if minetest.get_modpath("bakedclay") then }) end +-- register procedurally-generated arcs +if minetest.get_modpath("pkarcs") then + pkarcs.register_node("technic:marble") + pkarcs.register_node("technic:granite") +end + if minetest.get_modpath("moreblocks") then -- register stairsplus/circular_saw nodes diff --git a/extranodes/textures/antishroom.png b/extranodes/textures/antishroom.png Binary files differnew file mode 100644 index 0000000..263ccc7 --- /dev/null +++ b/extranodes/textures/antishroom.png diff --git a/extranodes/textures/antishroom_wield.png b/extranodes/textures/antishroom_wield.png Binary files differnew file mode 100644 index 0000000..733f658 --- /dev/null +++ b/extranodes/textures/antishroom_wield.png |