From 6dcc74ae0e50d674bd0a5cdc9d2cebf962429059 Mon Sep 17 00:00:00 2001 From: DonBatman Date: Tue, 8 Sep 2015 11:10:04 -0700 Subject: [PATCH] First Upload --- depends.txt | 2 + hammer.lua | 115 +++++++++++++++++ init.lua | 11 ++ nodes.lua | 201 ++++++++++++++++++++++++++++++ textures/mymasonhammer_hammer.png | Bin 0 -> 475 bytes textures/mymasonhammer_parti.png | Bin 0 -> 431 bytes textures/mymasonhammer_tint.png | Bin 0 -> 150 bytes textures/mymasonhammer_tint2.png | Bin 0 -> 164 bytes 8 files changed, 329 insertions(+) create mode 100644 depends.txt create mode 100644 hammer.lua create mode 100644 init.lua create mode 100644 nodes.lua create mode 100644 textures/mymasonhammer_hammer.png create mode 100644 textures/mymasonhammer_parti.png create mode 100644 textures/mymasonhammer_tint.png create mode 100644 textures/mymasonhammer_tint2.png diff --git a/depends.txt b/depends.txt new file mode 100644 index 0000000..3296b1e --- /dev/null +++ b/depends.txt @@ -0,0 +1,2 @@ +default +stairs diff --git a/hammer.lua b/hammer.lua new file mode 100644 index 0000000..993876b --- /dev/null +++ b/hammer.lua @@ -0,0 +1,115 @@ +local USES = 200 +local mode = {} +local function parti(pos) + minetest.add_particlespawner(25, 0.3, + pos, pos, + {x=2, y=0.2, z=2}, {x=-2, y=2, z=-2}, + {x=0, y=-6, z=0}, {x=0, y=-10, z=0}, + 0.2, 1, + 0.2, 2, + true, "mymasonhammer_parti.png") +end + mode = "1" +minetest.register_tool( "mymasonhammer:hammer",{ + description = "Mason Hammer", + inventory_image = "mymasonhammer_hammer.png", + wield_image = "mymasonhammer_hammer.png", +on_use = function(itemstack, user, pointed_thing) + local pos = pointed_thing.under + local node = minetest.get_node(pos) + local default_material = { + {"default:cobble", "default_cobble", "Cobble","stairs:stair_cobble"}, + {"default:desert_cobble","default_desert_cobble", "Desert Cobble","stairs:stair_desert_cobble"}, + {"default:stone","default_stone", "Stone","stairs:stair_stone"}, + {"default:desert_stone","default_desert_stone", "Desert Stone","stairs:stair_desert_stone"}, + {"default:stonebrick","default_stone_brick", "Stone Brick","stairs:stair_stonebrick"}, + {"default:desert_stonebrick","default_desert_stone_brick", "Desert Stone Brick","stairs:stair_desert_stonebrick"}, + } + for i in ipairs (default_material) do + local item = default_material [i][1] + local mat = default_material [i][2] + local desc = default_material [i][3] + local stair = default_material [i][4] + if pointed_thing.type ~= "node" then + return + end + if minetest.is_protected(pos, user:get_player_name()) then + minetest.record_protection_violation(pos, user:get_player_name()) + return + end + if mode == "1" then + if node.name == item then + minetest.set_node(pos,{name = stair, param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + end + end + if mode == "2" then + if node.name == item then + minetest.set_node(pos,{name = "mymasonhammer:"..mat.."_ladder2", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + elseif node.name == "mymasonhammer:"..mat.."_ladder2" then + minetest.set_node(pos,{name = "mymasonhammer:"..mat.."_ladder3", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + elseif node.name == "mymasonhammer:"..mat.."_ladder3" then + minetest.set_node(pos,{name = "mymasonhammer:"..mat.."_ladder", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + elseif node.name == "mymasonhammer:"..mat.."_ladder" then + minetest.set_node(pos,{name = "air", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + end + end + if mode == "3" then + if node.name == item then + minetest.set_node(pos,{name = "mymasonhammer:"..mat.."_foot2", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + elseif node.name == "mymasonhammer:"..mat.."_foot2" then + minetest.set_node(pos,{name = "mymasonhammer:"..mat.."_foot3", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + elseif node.name == "mymasonhammer:"..mat.."_foot3" then + minetest.set_node(pos,{name = "mymasonhammer:"..mat.."_foot", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + elseif node.name == "mymasonhammer:"..mat.."_foot" then + minetest.set_node(pos,{name = "air", param2=minetest.dir_to_facedir(user:get_look_dir())}) + parti(pos) + end + end +end + if not minetest.setting_getbool("creative_mode") then + itemstack:add_wear(65535 / (USES - 1)) + end + return itemstack +end, +on_place = function(itemstack, user, pointed_thing) + local usr = user:get_player_name() + + if mode == "1" then + mode = "2" + minetest.chat_send_player(usr,"Ladder Hammer") + elseif mode == "2" then + mode = "3" + minetest.chat_send_player(usr,"Foot Hold Hammer") + elseif mode == "3" then + mode = "1" + minetest.chat_send_player(usr,"Stair Hammer") + end + if not minetest.setting_getbool("creative_mode") then + itemstack:add_wear(65535 / (USES - 1)) + end + return itemstack + end +}) +minetest.register_craft({ + output = "mymasonhammer:hammer", + recipe = { + {"default:steel_ingot", "default:steel_ingot", "default:steel_ingot"}, + {"default:steel_ingot", "wool:blue", "default:steel_ingot"}, + {"", "wool:blue", ""}, + }, +}) + +minetest.register_craft({ + output = "mymasonhammer:hammer", + recipe = { + {"mymasonhammer:hammer", "default:steel_ingot"}, + }, +}) diff --git a/init.lua b/init.lua new file mode 100644 index 0000000..ba6672c --- /dev/null +++ b/init.lua @@ -0,0 +1,11 @@ +mycorners = {} +dofile(minetest.get_modpath("mymasonhammer").."/hammer.lua") +dofile(minetest.get_modpath("mymasonhammer").."/nodes.lua") + + + + + + + + diff --git a/nodes.lua b/nodes.lua new file mode 100644 index 0000000..9a3aad5 --- /dev/null +++ b/nodes.lua @@ -0,0 +1,201 @@ + +local default_material = { + {"default:cobble", "default_cobble", "Cobble", {cracky = 3, not_in_creative_inventory=1}}, + {"default:stone","default_stone", "Stone", {cracky = 3, not_in_creative_inventory=1}}, + {"default:desert_stone","default_desert_stone", "Desert Stone", {cracky = 3, not_in_creative_inventory=1}}, + {"default:desert_cobble","default_desert_cobble", "Desert Cobble", {cracky = 3, not_in_creative_inventory=1}}, + } +for i in ipairs (default_material) do +local item = default_material [i][1] +local mat = default_material [i][2] +local desc = default_material [i][3] +local gro = default_material [i][4] +minetest.register_node("mymasonhammer:"..mat.."_ladder", { + description = desc.." Ladder Block", + drawtype = "nodebox", + tiles = { + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png^mymasonhammer_tint.png", + }, + paramtype = "light", + paramtype2 = "facedir", + walkable = true, + climbable = true, + drop = item, + groups = gro, + node_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.4375, 0.5, 0.5, 0.5}, + {-0.5, -0.5, 0.3175, -0.3125, 0.5, 0.5}, + {0.3125, -0.5, 0.3175, 0.5, 0.5, 0.5}, + {-0.5, -0.4375, 0.3175, 0.5, -0.3125, 0.5}, + {-0.5, 0.3125, 0.3175, 0.5, 0.4375, 0.5}, + {-0.5, -0.1875, 0.3175, 0.5, -0.0625, 0.5}, + {-0.5, 0.0625, 0.3175, 0.5, 0.1875, 0.5}, + } + }, + selection_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.3175, 0.5, 0.5, 0.5}, + } + }, +}) +minetest.register_node("mymasonhammer:"..mat.."_ladder2", { + description = desc.." Ladder Block", + drawtype = "nodebox", + tiles = { + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + }, + paramtype = "light", + paramtype2 = "facedir", + walkable = true, + climbable = true, + drop = item, + groups = gro, + node_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, -0.3175, 0.5, 0.5, 0.5}, + } + }, + selection_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, -0.3175, 0.5, 0.5, 0.5}, + } + }, +}) +minetest.register_node("mymasonhammer:"..mat.."_ladder3", { + description = desc.." Ladder Block", + drawtype = "nodebox", + tiles = { + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + }, + paramtype = "light", + paramtype2 = "facedir", + walkable = true, + climbable = true, + drop = item, + groups = gro, + node_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.3175, 0.5, 0.5, 0.5}, + } + }, + selection_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.3175, 0.5, 0.5, 0.5}, + } + }, +}) +minetest.register_node("mymasonhammer:"..mat.."_foot", { + description = desc.." Foot Hold Block", + drawtype = "nodebox", + tiles = { + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png^mymasonhammer_tint2.png", + }, + paramtype = "light", + paramtype2 = "facedir", + walkable = true, + climbable = true, + drop = item, + groups = gro, + node_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.4375, 0.5, 0.5, 0.5}, + {-0.375, -0.3755, 0.3175, -0.125, -0.125, 0.5}, + {0.125, 0.1875, 0.3175, 0.375, 0.375, 0.5}, + } + }, + selection_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.4375, 0.5, 0.5, 0.5}, + } + }, +}) +minetest.register_node("mymasonhammer:"..mat.."_foot2", { + description = desc.." Foot Hold Block", + drawtype = "nodebox", + tiles = { + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + }, + paramtype = "light", + paramtype2 = "facedir", + walkable = true, + climbable = true, + drop = item, + groups = gro, + node_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, -0.3175, 0.5, 0.5, 0.5}, + } + }, + selection_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, -0.3175, 0.5, 0.5, 0.5}, + } + }, +}) +minetest.register_node("mymasonhammer:"..mat.."_foot3", { + description = desc.." Foot Hold Block", + drawtype = "nodebox", + tiles = { + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + mat..".png", + }, + paramtype = "light", + paramtype2 = "facedir", + walkable = true, + climbable = true, + drop = item, + groups = gro, + node_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.3175, 0.5, 0.5, 0.5}, + } + }, + selection_box = { + type = "fixed", + fixed = { + {-0.5, -0.5, 0.3175, 0.5, 0.5, 0.5}, + } + }, +}) +end diff --git a/textures/mymasonhammer_hammer.png b/textures/mymasonhammer_hammer.png new file mode 100644 index 0000000000000000000000000000000000000000..dfbb746a8f11915401d2ef03e0a7195253548612 GIT binary patch literal 475 zcmV<10VMv3P)@z$skp9kz1gE4WRy*HEP@*doX|T&M}Kb*epu0~mH~ zL!BT}nr$4xfs=)j-x0(4;Jo=Xi^T#F;n)4WGF&Dv3IL?4Do&>pUz8Skt^fjHjNv;f z@?5QI|MDA`pR1Ju{C#=3slAP0(=;W<*cToiA2G%dLg0C|0^s-46W)9F`#nXTzlSj% zkFnNbttG~Yh@h&dDrH$Jz-F^CS(b4)9B#%C5#gGHsuDt=EX)4VcDp4_(+@dFk|c-- zZQCLubX|vY4uJLgj`jKufZcBQ@jhp>S$}AnhRI}t_x{rK=R)|$r)#qF`5XY}9BtcT zt);GOj>qGmRobemh%sV}Ax%?42u!C_mdhotuLBJFXkEwyoX_V^q1`}KRYs!`B0^o) zIOhg8_fhV;4pl`&2qB=VBuO&Nz*>79ihi6d%Z3>=P19%K&A@xl)gSq<{sFsKjZ@oN R&J+Lu002ovPDHLkV1nNP%A)`P literal 0 HcmV?d00001 diff --git a/textures/mymasonhammer_parti.png b/textures/mymasonhammer_parti.png new file mode 100644 index 0000000000000000000000000000000000000000..9e8df3909cb666f6ac0fba7bca304230ed1af109 GIT binary patch literal 431 zcmV;g0Z{&lP)#^_EKR%XMH>qeow9t?2~;Yp%=X$-XlENy4dH$h)$B zRFkXoCk61}4*^);d`s;~H8Ck-swHC-20%noV|%%n$>oj3@)xTn`AlP<@?YVJ1pGnT Z@h1_AmVWe!GoSzf002ovPDHLkV1lvIz-Ise literal 0 HcmV?d00001 diff --git a/textures/mymasonhammer_tint.png b/textures/mymasonhammer_tint.png new file mode 100644 index 0000000000000000000000000000000000000000..5b250e1ea384300d097ca09b42e4b62000798d0b GIT binary patch literal 150 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP~CkMBwDpSSwD?lM-PZ!4!i_^&|4y<2!jx@TpIWkLV oeq|CqJb`_2qJb1!2q!bcWGhyl!#VTnfyx;?UHx3vIVCg!0OwXEJ^%m! literal 0 HcmV?d00001 diff --git a/textures/mymasonhammer_tint2.png b/textures/mymasonhammer_tint2.png new file mode 100644 index 0000000000000000000000000000000000000000..38704174d897a87b7ea54825c86e785ff7507a23 GIT binary patch literal 164 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP~CkKzQ@Vx7j{eVJ-o-U3d7N?U_5)w9~FJLe*4B&|H z2&fk5&G#1-56EG7+`#_Gz@VWuz=pq0pQpKmf#I(Z)BWXt)Xo4kGkCiCxvX