mirror of
				https://github.com/mt-mods/hangglider.git
				synced 2025-10-25 06:15:30 +02:00 
			
		
		
		
	add area FLAK for priv and xp protected areas
This commit is contained in:
		| @@ -7,5 +7,7 @@ read_globals = { | ||||
| 	"vector", "ItemStack", | ||||
|  | ||||
| 	"player_monoids", | ||||
| 	"priv_protector", | ||||
| 	"unifieddyes", | ||||
| 	"xp_redo", | ||||
| } | ||||
|   | ||||
							
								
								
									
										66
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										66
									
								
								init.lua
									
									
									
									
									
								
							| @@ -1,6 +1,14 @@ | ||||
|  | ||||
| local has_player_monoids = minetest.get_modpath("player_monoids") | ||||
| local has_areas = minetest.get_modpath("areas") | ||||
| local has_priv_protector = minetest.get_modpath("priv_protector") | ||||
| 	and minetest.global_exists("priv_protector") | ||||
| 	and priv_protector.get_area_priv | ||||
| -- older versions of priv_protector and xp_redo don't have | ||||
| -- the global and/or the functions yet | ||||
| local has_xp_redo = minetest.get_modpath("xp_redo") | ||||
| 	and minetest.global_exists("xp_redo") | ||||
| 	and xp_redo.get_area_xp_limits and xp_redo.get_xp | ||||
|  | ||||
| local enable_hud_overlay = minetest.settings:get_bool("hangglider.enable_hud_overlay", true) | ||||
| local enable_flak = has_areas and minetest.settings:get_bool("hangglider.enable_flak", true) | ||||
| @@ -73,22 +81,59 @@ local function remove_physics_overrides(player) | ||||
| 	end | ||||
| end | ||||
|  | ||||
| local function can_fly(pos, name) | ||||
| local function can_fly(pos, name, player_xp, player_privs) | ||||
| 	if not enable_flak then | ||||
| 		return true | ||||
| 	end | ||||
| 	local flak = false | ||||
|  | ||||
| 	local flak, open = false, false | ||||
| 	local priv_excemption, xp_limit = false, false | ||||
| 	local xp_area, priv_area | ||||
| 	local owners = {} | ||||
| 	for _, area in pairs(areas:getAreasAtPos(pos)) do | ||||
| 	for id, area in pairs(areas:getAreasAtPos(pos)) do | ||||
| 		-- open areas are friendly airspace(?) | ||||
| 		if area.open then | ||||
| 			open = true | ||||
| 		end | ||||
| 		if player_privs then | ||||
| 			priv_area = priv_protector.get_area_priv(id) | ||||
| 			if player_privs[priv_area] then | ||||
| 				priv_excemption = true | ||||
| 			end | ||||
| 		end | ||||
| 		if player_xp then | ||||
| 			xp_area = xp_redo.get_area_xp_limits(id) | ||||
| 			if xp_area then | ||||
| 				if (xp_area.min and player_xp < xp_area.min) | ||||
| 					or (xp_area.max and player_xp > xp_area.max) | ||||
| 				then | ||||
| 					xp_limit = true | ||||
| 				end | ||||
| 			end | ||||
| 		end | ||||
| 		if area.flak then | ||||
| 			flak = true | ||||
| 		end | ||||
| 		owners[area.owner] = true | ||||
| 	end | ||||
| 	if flak and not owners[name] then | ||||
| 		return false | ||||
| 	end | ||||
| 	-- none of the areas has FLAK set -> friendly | ||||
| 	-- any of the overlapping areas is open -> friendly | ||||
| 	-- owners of overlapping areas -> safe | ||||
| 	if not flak or open or owners[name] then | ||||
| 		return true | ||||
| 	end | ||||
|  | ||||
| 	-- privilaged players -> safe | ||||
| 	if player_privs and priv_excemption then | ||||
| 		return true | ||||
| 	end | ||||
|  | ||||
| 	-- xp limits -> unfriendly | ||||
| 	if player_xp and not xp_limit then | ||||
| 		return true | ||||
| 	end | ||||
|  | ||||
| 	return false | ||||
| end | ||||
|  | ||||
| local function safe_node_below(pos) | ||||
| @@ -142,7 +187,7 @@ local function hangglider_step(self, dtime) | ||||
| 					}) | ||||
| 				end | ||||
| 			end | ||||
| 			if not can_fly(pos, name) then | ||||
| 			if not can_fly(pos, name, self.xp, self.privs) then | ||||
| 				if not self.flak_timer then | ||||
| 					self.flak_timer = 0 | ||||
| 					shoot_flak_sound(pos) | ||||
| @@ -189,6 +234,13 @@ local function hangglider_use(stack, player) | ||||
| 			end | ||||
| 			set_hud_overlay(player, name, "hangglider_overlay.png") | ||||
| 			set_physics_overrides(player, {jump = 0, gravity = 0.25}) | ||||
| 			local luaentity = entity:get_luaentity() | ||||
| 			if has_xp_redo then | ||||
| 				luaentity.xp = xp_redo.get_xp(name) | ||||
| 			end | ||||
| 			if has_priv_protector then | ||||
| 				luaentity.privs = minetest.get_player_privs(name) | ||||
| 			end | ||||
| 			hanggliding_players[name] = true | ||||
| 			if hangglider_uses > 0 then | ||||
| 				stack:add_wear(65535 / hangglider_uses) | ||||
|   | ||||
							
								
								
									
										2
									
								
								mod.conf
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								mod.conf
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| name = hangglider | ||||
| description = Adds a functional hang glider for exploring | ||||
| depends = default, wool, dye | ||||
| optional_depends = areas, player_monoids, unifieddyes | ||||
| optional_depends = areas, player_monoids, priv_protector, unifieddyes, xp_redo | ||||
| min_minetest_version = 5.0 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user