Added 'protector_msg' setting for player messages
This commit is contained in:
		
					parent
					
						
							
								e7117e4c3d
							
						
					
				
			
			
				commit
				
					
						0702fad2db
					
				
			
		
					 4 changed files with 38 additions and 8 deletions
				
			
		|  | @ -59,7 +59,7 @@ Change log: | ||||||
| - 2.9 - Added MineClone2 recipes for protection block but no official support as yet | - 2.9 - Added MineClone2 recipes for protection block but no official support as yet | ||||||
| - 3.0 - Added PlayerFactions support, 'protector_hud_interval' setting and listing in advanced settings for mod values. | - 3.0 - Added PlayerFactions support, 'protector_hud_interval' setting and listing in advanced settings for mod values. | ||||||
| - 3.1 - Ability to hide protection blocks using /protector_hide and /protector_show , italian local added (thanks Hamlet) | - 3.1 - Ability to hide protection blocks using /protector_hide and /protector_show , italian local added (thanks Hamlet) | ||||||
| - 3.2 - Defaults to Minetest translation if found, otherwise intllib fallback if loaded, locale files updated for both. | - 3.2 - Defaults to Minetest translation if found, otherwise intllib fallback if loaded, locale files updated for both.  Added 'protector_msg' setting for player text. | ||||||
| 
 | 
 | ||||||
| Lucky Blocks: 10 | Lucky Blocks: 10 | ||||||
| 
 | 
 | ||||||
|  | @ -127,6 +127,12 @@ protector_flip = true | ||||||
| protector_show_interval | protector_show_interval | ||||||
| - Number of seconds the protection field is visible, defaults to 5 seconds. | - Number of seconds the protection field is visible, defaults to 5 seconds. | ||||||
| 
 | 
 | ||||||
|  | protector_recipe = true | ||||||
|  | - When true allows players to craft protection blocks | ||||||
|  | 
 | ||||||
|  | protector_msg = true | ||||||
|  | - When true shows protection messages in players chat when trying to interact in someone else's area | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| Protector Tool | Protector Tool | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										29
									
								
								init.lua
									
										
									
									
									
								
							
							
						
						
									
										29
									
								
								init.lua
									
										
									
									
									
								
							|  | @ -32,6 +32,7 @@ local protector_spawn = tonumber(minetest.settings:get("protector_spawn") | ||||||
| 	or minetest.settings:get("protector_pvp_spawn")) or 0 | 	or minetest.settings:get("protector_pvp_spawn")) or 0 | ||||||
| local protector_show = tonumber(minetest.settings:get("protector_show_interval")) or 5 | local protector_show = tonumber(minetest.settings:get("protector_show_interval")) or 5 | ||||||
| local protector_recipe = minetest.settings:get_bool("protector_recipe") ~= false | local protector_recipe = minetest.settings:get_bool("protector_recipe") ~= false | ||||||
|  | local protector_msg = minetest.settings:get_bool("protector_msg") ~= false | ||||||
| 
 | 
 | ||||||
| -- get static spawn position | -- get static spawn position | ||||||
| local statspawn = minetest.string_to_pos(minetest.settings:get("static_spawnpoint")) | local statspawn = minetest.string_to_pos(minetest.settings:get("static_spawnpoint")) | ||||||
|  | @ -211,6 +212,18 @@ local inside_spawn = function(pos, radius) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | -- show protection message if enabled | ||||||
|  | local show_msg = function(player, msg) | ||||||
|  | 
 | ||||||
|  | 	-- if messages disabled or no player name provided | ||||||
|  | 	if protector_msg == false or not player or player == "" then | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  | 
 | ||||||
|  | 	minetest.chat_send_player(player, msg) | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| -- Infolevel: | -- Infolevel: | ||||||
| -- 0 for no info | -- 0 for no info | ||||||
| -- 1 for "This area is owned by <owner> !" if you can't dig | -- 1 for "This area is owned by <owner> !" if you can't dig | ||||||
|  | @ -235,7 +248,7 @@ protector.can_dig = function(r, pos, digger, onlyowner, infolevel) | ||||||
| 	-- is spawn area protected ? | 	-- is spawn area protected ? | ||||||
| 	if inside_spawn(pos, protector_spawn) then | 	if inside_spawn(pos, protector_spawn) then | ||||||
| 
 | 
 | ||||||
| 		minetest.chat_send_player(digger, | 		show_msg(digger, | ||||||
| 			S("Spawn @1 has been protected up to a @2 block radius.", | 			S("Spawn @1 has been protected up to a @2 block radius.", | ||||||
| 				minetest.pos_to_string(statspawn), protector_spawn)) | 				minetest.pos_to_string(statspawn), protector_spawn)) | ||||||
| 
 | 
 | ||||||
|  | @ -262,7 +275,7 @@ protector.can_dig = function(r, pos, digger, onlyowner, infolevel) | ||||||
| 			-- and you aren't on the member list | 			-- and you aren't on the member list | ||||||
| 			if onlyowner or not is_member(meta, digger) then | 			if onlyowner or not is_member(meta, digger) then | ||||||
| 
 | 
 | ||||||
| 				minetest.chat_send_player(digger, | 				show_msg(digger, | ||||||
| 					S("This area is owned by @1", owner) .. "!") | 					S("This area is owned by @1", owner) .. "!") | ||||||
| 
 | 
 | ||||||
| 				return false | 				return false | ||||||
|  | @ -429,8 +442,9 @@ minetest.register_node("protector:protect", { | ||||||
| 		local meta = minetest.get_meta(pos) | 		local meta = minetest.get_meta(pos) | ||||||
| 
 | 
 | ||||||
| 		meta:set_string("owner", placer:get_player_name() or "") | 		meta:set_string("owner", placer:get_player_name() or "") | ||||||
| 		meta:set_string("infotext", S("Protection (owned by @1)", meta:get_string("owner"))) |  | ||||||
| 		meta:set_string("members", "") | 		meta:set_string("members", "") | ||||||
|  | 		meta:set_string("infotext", | ||||||
|  | 				S("Protection (owned by @1)", meta:get_string("owner"))) | ||||||
| 	end, | 	end, | ||||||
| 
 | 
 | ||||||
| 	on_use = function(itemstack, user, pointed_thing) | 	on_use = function(itemstack, user, pointed_thing) | ||||||
|  | @ -439,7 +453,8 @@ minetest.register_node("protector:protect", { | ||||||
| 			return | 			return | ||||||
| 		end | 		end | ||||||
| 
 | 
 | ||||||
| 		protector.can_dig(protector_radius, pointed_thing.under, user:get_player_name(), false, 2) | 		protector.can_dig(protector_radius, pointed_thing.under, | ||||||
|  | 				user:get_player_name(), false, 2) | ||||||
| 	end, | 	end, | ||||||
| 
 | 
 | ||||||
| 	on_rightclick = function(pos, node, clicker, itemstack) | 	on_rightclick = function(pos, node, clicker, itemstack) | ||||||
|  | @ -533,8 +548,9 @@ minetest.register_node("protector:protect2", { | ||||||
| 		local meta = minetest.get_meta(pos) | 		local meta = minetest.get_meta(pos) | ||||||
| 
 | 
 | ||||||
| 		meta:set_string("owner", placer:get_player_name() or "") | 		meta:set_string("owner", placer:get_player_name() or "") | ||||||
| 		meta:set_string("infotext", S("Protection (owned by @1)", meta:get_string("owner"))) |  | ||||||
| 		meta:set_string("members", "") | 		meta:set_string("members", "") | ||||||
|  | 		meta:set_string("infotext", | ||||||
|  | 				S("Protection (owned by @1)", meta:get_string("owner"))) | ||||||
| 	end, | 	end, | ||||||
| 
 | 
 | ||||||
| 	on_use = function(itemstack, user, pointed_thing) | 	on_use = function(itemstack, user, pointed_thing) | ||||||
|  | @ -543,7 +559,8 @@ minetest.register_node("protector:protect2", { | ||||||
| 			return | 			return | ||||||
| 		end | 		end | ||||||
| 
 | 
 | ||||||
| 		protector.can_dig(protector_radius, pointed_thing.under, user:get_player_name(), false, 2) | 		protector.can_dig(protector_radius, pointed_thing.under, | ||||||
|  | 				user:get_player_name(), false, 2) | ||||||
| 	end, | 	end, | ||||||
| 
 | 
 | ||||||
| 	on_rightclick = function(pos, node, clicker, itemstack) | 	on_rightclick = function(pos, node, clicker, itemstack) | ||||||
|  |  | ||||||
|  | @ -27,3 +27,6 @@ protector_hud_interval (Protector HUD Interval) int 5 | ||||||
| 
 | 
 | ||||||
| #    Enables craft recipe for protection block | #    Enables craft recipe for protection block | ||||||
| protector_recipe (Enable Protector recipe) bool true | protector_recipe (Enable Protector recipe) bool true | ||||||
|  | 
 | ||||||
|  | #    Enables protection messages in player chat | ||||||
|  | protector_msg (Enable Protector Messages) bool true | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								tool.lua
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								tool.lua
									
										
									
									
									
								
							|  | @ -67,7 +67,8 @@ minetest.register_craftitem("protector:tool", { | ||||||
| 		-- does a protector already exist ? | 		-- does a protector already exist ? | ||||||
| 		if #minetest.find_nodes_in_area( | 		if #minetest.find_nodes_in_area( | ||||||
| 			vector.subtract(pos, 1), vector.add(pos, 1), | 			vector.subtract(pos, 1), vector.add(pos, 1), | ||||||
| 			{"protector:protect", "protector:protect2", "protector:protect_hidden"}) > 0 then | 			{"protector:protect", "protector:protect2", | ||||||
|  | 					"protector:protect_hidden"}) > 0 then | ||||||
| 
 | 
 | ||||||
| 			minetest.chat_send_player(name, S("Protector already in place!")) | 			minetest.chat_send_player(name, S("Protector already in place!")) | ||||||
| 
 | 
 | ||||||
|  | @ -91,11 +92,13 @@ minetest.register_craftitem("protector:tool", { | ||||||
| 		if inv:contains_item("main", "protector:protect") then | 		if inv:contains_item("main", "protector:protect") then | ||||||
| 
 | 
 | ||||||
| 			inv:remove_item("main", "protector:protect") | 			inv:remove_item("main", "protector:protect") | ||||||
|  | 
 | ||||||
| 			nod = "protector:protect" | 			nod = "protector:protect" | ||||||
| 
 | 
 | ||||||
| 		elseif inv:contains_item("main", "protector:protect2") then | 		elseif inv:contains_item("main", "protector:protect2") then | ||||||
| 
 | 
 | ||||||
| 			inv:remove_item("main", "protector:protect2") | 			inv:remove_item("main", "protector:protect2") | ||||||
|  | 
 | ||||||
| 			nod = "protector:protect2" | 			nod = "protector:protect2" | ||||||
| 		end | 		end | ||||||
| 
 | 
 | ||||||
|  | @ -142,6 +145,7 @@ minetest.register_craftitem("protector:tool", { | ||||||
| 
 | 
 | ||||||
| -- tool recipe | -- tool recipe | ||||||
| local df = "default:steel_ingot" | local df = "default:steel_ingot" | ||||||
|  | 
 | ||||||
| if not minetest.registered_items[df] then | if not minetest.registered_items[df] then | ||||||
| 	df = "mcl_core:iron_ingot" | 	df = "mcl_core:iron_ingot" | ||||||
| end | end | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tenplus1
				tenplus1