forked from mtcontrib/witchcraft
		
	Tidy code and remove stack_max limit of Glass Bottle
This commit is contained in:
		
							
								
								
									
										57
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								init.lua
									
									
									
									
									
								
							| @@ -17,11 +17,6 @@ | |||||||
| -- You should have received a copy of the GNU General Public License | -- You should have received a copy of the GNU General Public License | ||||||
| -- along with this program.  If not, see <http://www.gnu.org/licenses/>. | -- along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| --changes so that bottles can't stack |  | ||||||
| minetest.override_item("vessels:glass_bottle", { |  | ||||||
| 	stack_max = 3, |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| local vessels_shelf_formspec = | local vessels_shelf_formspec = | ||||||
| 	"size[8,7;]".. | 	"size[8,7;]".. | ||||||
| 	default.gui_bg.. | 	default.gui_bg.. | ||||||
| @@ -543,14 +538,16 @@ minetest.register_node("witchcraft:pot", { | |||||||
| 			{-0.375, 0.3125, -0.375, -0.3125, 0.375, 0.375}, -- NodeBox20 | 			{-0.375, 0.3125, -0.375, -0.3125, 0.375, 0.375}, -- NodeBox20 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = function(pos, node, clicker, itemstack, _) | ||||||
| 		local wield_item = clicker:get_wielded_item():get_name() | 		local wield_item = itemstack:get_name() | ||||||
|  |  | ||||||
| 		if wield_item == "bucket:bucket_water" or | 		if wield_item == "bucket:bucket_water" or | ||||||
| 				wield_item == "bucket:bucket_river_water" then | 		wield_item == "bucket:bucket_river_water" then | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot_blue", param2=node.param2}) | 			minetest.set_node(pos, {name="witchcraft:pot_blue", param2=node.param2}) | ||||||
| 			item:replace("bucket:bucket_empty") | 			return ItemStack("bucket:bucket_empty") | ||||||
| 			elseif wield_item == "vessels:drinking_glass" then | 		elseif wield_item == "vessels:drinking_glass" then | ||||||
| 			item:replace("witchcraft:bottle_slime") | 			itemstack:set_count(itemstack:get_count() - 1) | ||||||
|  | 			minetest.env:add_item({x=pos.x, y=pos.y+1.5, z=pos.z}, "witchcraft:bottle_slime") | ||||||
| 		end | 		end | ||||||
| 	end, | 	end, | ||||||
| 	groups = {cracky=1, falling_node=1, oddly_breakable_by_hand=1} | 	groups = {cracky=1, falling_node=1, oddly_breakable_by_hand=1} | ||||||
| @@ -650,31 +647,35 @@ minetest.register_node("witchcraft:pot_"..color, { | |||||||
| 			{-0.4375, 0.375, -0.4375, 0.4375, 0.5, 0.4375}, -- NodeBox7 | 			{-0.4375, 0.375, -0.4375, 0.4375, 0.5, 0.4375}, -- NodeBox7 | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	on_rightclick = function(pos, node, clicker, item, _) | 	on_rightclick = function(pos, node, clicker, itemstack, _) | ||||||
| 		local wield_item = clicker:get_wielded_item():get_name() | 		local wield_item = itemstack:get_name() | ||||||
| 		if wield_item == "vessels:glass_bottle" and clicker:get_wielded_item():get_count() == 3 then |  | ||||||
| 			item:replace("witchcraft:potion_"..color) | 		if wield_item == "vessels:glass_bottle" then | ||||||
| 			minetest.env:add_item({x=pos.x, y=pos.y+1.5, z=pos.z}, "witchcraft:potion_"..color) | 			local wield_items_count = itemstack:get_count() | ||||||
| 			minetest.env:add_item({x=pos.x, y=pos.y+1.5, z=pos.z}, "witchcraft:potion_"..color) | 			local potions_count = (wield_items_count <= 3 and wield_items_count) or 3 | ||||||
|  | 			local wield_items_left = (wield_items_count - potions_count) | ||||||
|  |  | ||||||
|  | 			itemstack:set_count((wield_items_left < 0 and 0) or wield_items_left) | ||||||
|  | 			 | ||||||
|  | 			for i = 1, potions_count do | ||||||
|  | 				minetest.env:add_item({x=pos.x, y=pos.y+1.5, z=pos.z}, "witchcraft:potion_"..color) | ||||||
|  | 			end | ||||||
|  | 			 | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot", param2=node.param2}) | 			minetest.set_node(pos, {name="witchcraft:pot", param2=node.param2}) | ||||||
| 		elseif wield_item == "vessels:glass_bottle" and clicker:get_wielded_item():get_count() ~= 3 then | 		elseif wield_item == ingredient then | ||||||
| 			item:replace("witchcraft:potion_"..color) |  | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot", param2=node.param2}) |  | ||||||
| 		else |  | ||||||
| 		if wield_item == ingredient then |  | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot_"..newcolor, param2=node.param2}) | 			minetest.set_node(pos, {name="witchcraft:pot_"..newcolor, param2=node.param2}) | ||||||
| 			item:take_item() | 			itemstack:take_item() | ||||||
| 		elseif wield_item == ingredient2 then | 		elseif wield_item == ingredient2 then | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot_"..newcolor2, param2=node.param2}) | 			minetest.set_node(pos, {name="witchcraft:pot_"..newcolor2, param2=node.param2}) | ||||||
| 			item:take_item() | 			itemstack:take_item() | ||||||
| 		elseif wield_item == "bucket:bucket_water" then | 		elseif wield_item == "bucket:bucket_water" or | ||||||
|  | 		wield_item == "bucket:bucket_river_water" then | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot_blue", param2=node.param2}) | 			minetest.set_node(pos, {name="witchcraft:pot_blue", param2=node.param2}) | ||||||
| 			item:replace("bucket:bucket_empty") | 			return ItemStack("bucket:bucket_empty") | ||||||
| 		elseif wield_item == "witchcraft:potion_"..combine then | 		elseif wield_item == "witchcraft:potion_"..combine then | ||||||
| 			minetest.set_node(pos, {name="witchcraft:pot_"..cresult, param2=node.param2}) | 			minetest.set_node(pos, {name="witchcraft:pot_"..cresult, param2=node.param2}) | ||||||
| 			item:replace("vessels:glass_bottle") | 			itemstack:replace("vessels:glass_bottle") | ||||||
| 		end | 		end | ||||||
| 	end |  | ||||||
| 	end, | 	end, | ||||||
| 	groups = {cracky=1, falling_node=1, oddly_breakable_by_hand=1} | 	groups = {cracky=1, falling_node=1, oddly_breakable_by_hand=1} | ||||||
| }) | }) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user