store radius and max_shares in global
This commit is contained in:
		
					parent
					
						
							
								74fac5ff9a
							
						
					
				
			
			
				commit
				
					
						e4ea32efa3
					
				
			
		
					 4 changed files with 37 additions and 51 deletions
				
			
		|  | @ -106,14 +106,10 @@ minetest.register_abm({ | |||
| 	end | ||||
| }) | ||||
| 
 | ||||
| -- get protection radius (max 30) | ||||
| 
 | ||||
| local r = tonumber(minetest.settings:get("protector_radius")) or 5 | ||||
| 
 | ||||
| if r > 30 then r = 30 end | ||||
| 
 | ||||
| -- show protection areas of nearby protectors owned by you (thanks agaran) | ||||
| 
 | ||||
| local r = protector.radius | ||||
| 
 | ||||
| minetest.register_chatcommand("protector_show_area", { | ||||
| 	params = "", | ||||
| 	description = S("Show protected areas of your nearby protectors"), | ||||
|  |  | |||
							
								
								
									
										9
									
								
								hud.lua
									
										
									
									
									
								
							
							
						
						
									
										9
									
								
								hud.lua
									
										
									
									
									
								
							|  | @ -2,11 +2,7 @@ | |||
| -- translation and protector radius | ||||
| 
 | ||||
| local S = minetest.get_translator("protector") | ||||
| local radius = (tonumber(minetest.settings:get("protector_radius")) or 5) | ||||
| 
 | ||||
| -- radius limiter (minetest cannot handle node volume of more than 4096000) | ||||
| 
 | ||||
| if radius > 30 then radius = 30 end | ||||
| local radius = protector.radius | ||||
| 
 | ||||
| -- hud settings | ||||
| 
 | ||||
|  | @ -19,9 +15,10 @@ if hud_interval > 0 then | |||
| 
 | ||||
| minetest.register_globalstep(function(dtime) | ||||
| 
 | ||||
| 	-- every 5 seconds | ||||
| 	hud_timer = hud_timer + dtime | ||||
| 
 | ||||
| 	if hud_timer < hud_interval then return end | ||||
| 
 | ||||
| 	hud_timer = 0 | ||||
| 
 | ||||
| 	for _, player in pairs(minetest.get_connected_players()) do | ||||
|  |  | |||
							
								
								
									
										44
									
								
								init.lua
									
										
									
									
									
								
							
							
						
						
									
										44
									
								
								init.lua
									
										
									
									
									
								
							|  | @ -25,7 +25,21 @@ local S = minetest.get_translator("protector") | |||
| 
 | ||||
| -- global table | ||||
| 
 | ||||
| protector = {mod = "redo"} | ||||
| protector = { | ||||
| 	mod = "redo", | ||||
| 	max_shares = 12, | ||||
| 	radius = tonumber(minetest.settings:get("protector_radius")) or 5 | ||||
| } | ||||
| 
 | ||||
| -- radius limiter (minetest cannot handle node volume of more than 4096000) | ||||
| 
 | ||||
| if protector.radius > 30 then protector.radius = 30 end | ||||
| 
 | ||||
| -- playerfactions check | ||||
| 
 | ||||
| local factions_available = minetest.global_exists("factions") | ||||
| 
 | ||||
| if factions_available then protector.max_shares = 8 end | ||||
| 
 | ||||
| -- localize math | ||||
| 
 | ||||
|  | @ -33,9 +47,6 @@ local math_floor, math_pi = math.floor, math.pi | |||
| 
 | ||||
| -- settings | ||||
| 
 | ||||
| local factions_available = minetest.global_exists("factions") | ||||
| local protector_max_share_count = 12 | ||||
| local protector_radius = tonumber(minetest.settings:get("protector_radius")) or 5 | ||||
| local protector_flip = minetest.settings:get_bool("protector_flip") or false | ||||
| local protector_hurt = tonumber(minetest.settings:get("protector_hurt")) or 0 | ||||
| local protector_spawn = tonumber(minetest.settings:get("protector_spawn") | ||||
|  | @ -44,10 +55,6 @@ local protector_show = tonumber(minetest.settings:get("protector_show_interval") | |||
| local protector_recipe = minetest.settings:get_bool("protector_recipe") ~= false | ||||
| local protector_msg = minetest.settings:get_bool("protector_msg") ~= false | ||||
| 
 | ||||
| -- radius limiter (minetest cannot handle node volume of more than 4096000) | ||||
| 
 | ||||
| if protector_radius > 30 then protector_radius = 30 end | ||||
| 
 | ||||
| -- get static spawn position | ||||
| 
 | ||||
| local statspawn = minetest.string_to_pos(minetest.settings:get("static_spawnpoint")) | ||||
|  | @ -126,7 +133,7 @@ local function add_member(meta, name) | |||
| 
 | ||||
| 	local list = get_member_list(meta) | ||||
| 
 | ||||
| 	if #list >= protector_max_share_count then return end | ||||
| 	if #list >= protector.max_shares then return end | ||||
| 
 | ||||
| 	table.insert(list, name) | ||||
| 
 | ||||
|  | @ -163,7 +170,6 @@ local function protector_formspec(meta) | |||
| 		.. "field_close_on_enter[protector_add_member;false]" | ||||
| 
 | ||||
| 	local members = get_member_list(meta) | ||||
| 	local npp = protector_max_share_count -- max users added to protector list | ||||
| 	local i = 0 | ||||
| 	local checkbox_faction = false | ||||
| 
 | ||||
|  | @ -192,13 +198,11 @@ local function protector_formspec(meta) | |||
| 			.. F(S("Allow faction access")) | ||||
| 			.. ";" .. (meta:get_int("faction_members") == 1 and | ||||
| 					"true" or "false") .. "]" | ||||
| 
 | ||||
| 		if npp > 8 then npp = 8 end | ||||
| 	end | ||||
| 
 | ||||
| 	for n = 1, #members do | ||||
| 
 | ||||
| 		if i < npp then | ||||
| 		if i < protector.max_shares then | ||||
| 
 | ||||
| 			-- show username | ||||
| 			formspec = formspec .. "button[" .. (i % 4 * 2) | ||||
|  | @ -214,7 +218,7 @@ local function protector_formspec(meta) | |||
| 		i = i + 1 | ||||
| 	end | ||||
| 
 | ||||
| 	if i < npp then | ||||
| 	if i < protector.max_shares then | ||||
| 
 | ||||
| 		-- user name entry field | ||||
| 		formspec = formspec .. "field[" .. (i % 4 * 2 + 1 / 3) .. "," | ||||
|  | @ -392,7 +396,7 @@ function minetest.is_protected(pos, digger) | |||
| 	digger = digger or "" -- nil check | ||||
| 
 | ||||
| 	-- is area protected against digger? | ||||
| 	if not protector.can_dig(protector_radius, pos, digger, false, 1) then | ||||
| 	if not protector.can_dig(protector.radius, pos, digger, false, 1) then | ||||
| 		return true | ||||
| 	end | ||||
| 
 | ||||
|  | @ -410,7 +414,7 @@ local function check_overlap(itemstack, placer, pointed_thing) | |||
| 	local name = placer:get_player_name() | ||||
| 
 | ||||
| 	-- make sure protector doesn't overlap onto protected spawn area | ||||
| 	if inside_spawn(pos, protector_spawn + protector_radius) then | ||||
| 	if inside_spawn(pos, protector_spawn + protector.radius) then | ||||
| 
 | ||||
| 		minetest.chat_send_player(name, | ||||
| 				S("Spawn @1 has been protected up to a @2 block radius.", | ||||
|  | @ -420,7 +424,7 @@ local function check_overlap(itemstack, placer, pointed_thing) | |||
| 	end | ||||
| 
 | ||||
| 	-- make sure protector doesn't overlap any other player's area | ||||
| 	if not protector.can_dig(protector_radius * 2, pos, name, true, 3) then | ||||
| 	if not protector.can_dig(protector.radius * 2, pos, name, true, 3) then | ||||
| 
 | ||||
| 		minetest.chat_send_player(name, | ||||
| 				S("Overlaps into above players protected area")) | ||||
|  | @ -493,7 +497,7 @@ minetest.register_node("protector:protect", { | |||
| 
 | ||||
| 		if pointed_thing.type ~= "node" then return end | ||||
| 
 | ||||
| 		protector.can_dig(protector_radius, pointed_thing.under, | ||||
| 		protector.can_dig(protector.radius, pointed_thing.under, | ||||
| 				user:get_player_name(), false, 2) | ||||
| 	end, | ||||
| 
 | ||||
|  | @ -591,7 +595,7 @@ minetest.register_node("protector:protect2", { | |||
| 
 | ||||
| 		if pointed_thing.type ~= "node" then return end | ||||
| 
 | ||||
| 		protector.can_dig(protector_radius, pointed_thing.under, | ||||
| 		protector.can_dig(protector.radius, pointed_thing.under, | ||||
| 				user:get_player_name(), false, 2) | ||||
| 	end, | ||||
| 
 | ||||
|  | @ -726,7 +730,7 @@ minetest.register_entity("protector:display", { | |||
| -- Display-zone node, Do NOT place the display as a node, | ||||
| -- it is made to be used as an entity (see above) | ||||
| 
 | ||||
| local x = protector_radius | ||||
| local x = protector.radius | ||||
| 
 | ||||
| minetest.register_node("protector:display_node", { | ||||
| 	tiles = {"protector_display.png"}, | ||||
|  |  | |||
							
								
								
									
										27
									
								
								tool.lua
									
										
									
									
									
								
							
							
						
						
									
										27
									
								
								tool.lua
									
										
									
									
									
								
							|  | @ -5,11 +5,7 @@ local S = minetest.get_translator("protector") | |||
| 
 | ||||
| -- get protection radius | ||||
| 
 | ||||
| local r = tonumber(minetest.settings:get("protector_radius")) or 5 | ||||
| 
 | ||||
| -- radius limiter (minetest cannot handle node volume of more than 4096000) | ||||
| 
 | ||||
| if r > 30 then r = 30 end | ||||
| local r = protector.radius | ||||
| 
 | ||||
| -- protector placement tool | ||||
| 
 | ||||
|  | @ -43,18 +39,12 @@ minetest.register_craftitem("protector:tool", { | |||
| 		local pit =  user:get_look_vertical() | ||||
| 
 | ||||
| 		-- set placement coords | ||||
| 		if pit > 1.2 then | ||||
| 			vec.y = -gap -- up | ||||
| 		elseif pit < -1.2 then | ||||
| 			vec.y = gap -- down | ||||
| 		elseif dir == 0 then | ||||
| 			vec.z = gap -- north | ||||
| 		elseif dir == 1 then | ||||
| 			vec.x = gap -- east | ||||
| 		elseif dir == 2 then | ||||
| 			vec.z = -gap -- south | ||||
| 		elseif dir == 3 then | ||||
| 			vec.x = -gap -- west | ||||
| 		if pit > 1.2 then      vec.y = -gap -- up | ||||
| 		elseif pit < -1.2 then vec.y = gap -- down | ||||
| 		elseif dir == 0 then   vec.z = gap -- north | ||||
| 		elseif dir == 1 then   vec.x = gap -- east | ||||
| 		elseif dir == 2 then   vec.z = -gap -- south | ||||
| 		elseif dir == 3 then   vec.x = -gap -- west | ||||
| 		end | ||||
| 
 | ||||
| 		-- new position | ||||
|  | @ -151,8 +141,7 @@ minetest.register_craftitem("protector:tool", { | |||
| 		end | ||||
| 
 | ||||
| 		minetest.chat_send_player(name, | ||||
| 				S("Protector placed at") .. | ||||
| 				" " ..  minetest.pos_to_string(pos)) | ||||
| 				S("Protector placed at") .. " " ..  minetest.pos_to_string(pos)) | ||||
| 	end | ||||
| }) | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 tenplus1
				tenplus1