Tweaked code to work better for violation drops
This commit is contained in:
		
					parent
					
						
							
								0679ada27d
							
						
					
				
			
			
				commit
				
					
						f1b5448049
					
				
			
		
					 3 changed files with 21 additions and 20 deletions
				
			
		|  | @ -47,7 +47,7 @@ minetest.register_abm({ | ||||||
| 
 | 
 | ||||||
| 		local names = protector.removal_names:split(" ") | 		local names = protector.removal_names:split(" ") | ||||||
| 
 | 
 | ||||||
| 		for _, n in ipairs(names) do | 		for _, n in pairs(names) do | ||||||
| 
 | 
 | ||||||
| 			if n == owner then | 			if n == owner then | ||||||
| 				minetest.set_node(pos, {name = "air"}) | 				minetest.set_node(pos, {name = "air"}) | ||||||
|  |  | ||||||
|  | @ -290,7 +290,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields) | ||||||
| 		if fields.toup then | 		if fields.toup then | ||||||
| 
 | 
 | ||||||
| 			-- copy contents of players inventory to chest | 			-- copy contents of players inventory to chest | ||||||
| 			for i, v in ipairs (player_inv:get_list("main") or {}) do | 			for i, v in pairs (player_inv:get_list("main") or {}) do | ||||||
| 
 | 
 | ||||||
| 				if chest_inv | 				if chest_inv | ||||||
| 				and chest_inv:room_for_item('main', v) then | 				and chest_inv:room_for_item('main', v) then | ||||||
|  | @ -309,7 +309,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields) | ||||||
| 		elseif fields.todn then | 		elseif fields.todn then | ||||||
| 
 | 
 | ||||||
| 			-- copy contents of chest to players inventory | 			-- copy contents of chest to players inventory | ||||||
| 			for i, v in ipairs (chest_inv:get_list('main') or {}) do | 			for i, v in pairs (chest_inv:get_list('main') or {}) do | ||||||
| 
 | 
 | ||||||
| 				if player_inv:room_for_item("main", v) then | 				if player_inv:room_for_item("main", v) then | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										35
									
								
								init.lua
									
										
									
									
									
								
							
							
						
						
									
										35
									
								
								init.lua
									
										
									
									
									
								
							|  | @ -45,7 +45,7 @@ protector.del_member = function(meta, name) | ||||||
| 
 | 
 | ||||||
| 	local list = protector.get_member_list(meta) | 	local list = protector.get_member_list(meta) | ||||||
| 
 | 
 | ||||||
| 	for i, n in ipairs(list) do | 	for i, n in pairs(list) do | ||||||
| 
 | 
 | ||||||
| 		if n == name then | 		if n == name then | ||||||
| 			table.remove(list, i) | 			table.remove(list, i) | ||||||
|  | @ -71,7 +71,7 @@ protector.generate_formspec = function(meta) | ||||||
| 	local npp = 12 -- max users added onto protector list | 	local npp = 12 -- max users added onto protector list | ||||||
| 	local i = 0 | 	local i = 0 | ||||||
| 
 | 
 | ||||||
| 	for _, member in ipairs(members) do | 	for _, member in pairs(members) do | ||||||
| 
 | 
 | ||||||
| 		if i < npp then | 		if i < npp then | ||||||
| 
 | 
 | ||||||
|  | @ -136,7 +136,7 @@ protector.can_dig = function(r, pos, digger, onlyowner, infolevel) | ||||||
| 
 | 
 | ||||||
| 	local meta, owner, members | 	local meta, owner, members | ||||||
| 
 | 
 | ||||||
| 	for _, pos in ipairs(positions) do | 	for _, pos in pairs(positions) do | ||||||
| 
 | 
 | ||||||
| 		meta = minetest.get_meta(pos) | 		meta = minetest.get_meta(pos) | ||||||
| 		owner = meta:get_string("owner") | 		owner = meta:get_string("owner") | ||||||
|  | @ -214,29 +214,30 @@ function minetest.is_protected(pos, digger) | ||||||
| 
 | 
 | ||||||
| 		local player = minetest.get_player_by_name(digger) | 		local player = minetest.get_player_by_name(digger) | ||||||
| 
 | 
 | ||||||
|  | 		-- hurt player if protection violated | ||||||
| 		if protector.hurt > 0 | 		if protector.hurt > 0 | ||||||
| 		and player then | 		and player then | ||||||
| 			player:set_hp(player:get_hp() - protector.hurt) | 			player:set_hp(player:get_hp() - protector.hurt) | ||||||
| 		end | 		end | ||||||
| 
 | 
 | ||||||
|  | 		-- drop tool/item if protection violated | ||||||
| 		if protector.drop == true | 		if protector.drop == true | ||||||
| 		and player then | 		and player then | ||||||
| 			-- drop tool/item if protection violated |  | ||||||
| 			local tool = player:get_wielded_item() |  | ||||||
| 			--local wear = tool:get_wear() |  | ||||||
| 			local num = player:get_wield_index() |  | ||||||
| 			local player_inv = player:get_inventory() |  | ||||||
| 			local inv = player_inv:get_stack("main", num) |  | ||||||
| 			local sta = inv:take_item(inv:get_count()) |  | ||||||
| 			local obj = minetest.add_item(player:getpos(), sta) |  | ||||||
| 
 | 
 | ||||||
| 			if obj then | 			local holding = player:get_wielded_item() | ||||||
| 				obj:setvelocity({x = 0, y = 5, z = 0}) | 
 | ||||||
| 				player:set_wielded_item(nil) | 			if holding:to_string() ~= "" then | ||||||
| 				minetest.after(0.2, function() | 
 | ||||||
| 					player_inv:set_stack("main", num, nil) | 				local sta = holding:take_item(holding:get_count()) | ||||||
| 				end) | 				local obj = minetest.add_item(player:getpos(), sta) | ||||||
|  | 
 | ||||||
|  | 				if obj then | ||||||
|  | 					obj:setvelocity({x = 0, y = 5, z = 0}) | ||||||
|  | 					player:set_wielded_item(holding) | ||||||
|  | 				end | ||||||
|  | 
 | ||||||
| 			end | 			end | ||||||
|  | 
 | ||||||
| 		end | 		end | ||||||
| 
 | 
 | ||||||
| 		return true | 		return true | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 TenPlus1
				TenPlus1