forked from mtcontrib/factions
		
	
							
								
								
									
										20
									
								
								factions.lua
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								factions.lua
									
									
									
									
									
								
							| @@ -419,6 +419,14 @@ function factions.Faction.stop_attack(self, parcelpos) | |||||||
|     end |     end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | function factions.Faction.parcel_is_attacked_by(self, parcelpos, faction) | ||||||
|  |     if self.attacked_parcels[parcelpos] then | ||||||
|  |         return self.attacked_parcels[parcelpos][faction.name] | ||||||
|  |     else | ||||||
|  |         return false | ||||||
|  |     end | ||||||
|  | end | ||||||
|  |  | ||||||
| -------------------------- | -------------------------- | ||||||
| -- callbacks for events -- | -- callbacks for events -- | ||||||
| function factions.Faction.on_create(self)  --! @brief called when the faction is added to the global faction list | function factions.Faction.on_create(self)  --! @brief called when the faction is added to the global faction list | ||||||
| @@ -775,20 +783,16 @@ minetest.is_protected = function(pos, player) | |||||||
|         return not player_faction:has_permission(player, "claim") and player_faction.power > 0. and not parcel_faction.is_admin |         return not player_faction:has_permission(player, "claim") and player_faction.power > 0. and not parcel_faction.is_admin | ||||||
|     end |     end | ||||||
|     -- no faction |     -- no faction | ||||||
|     if not parcel_faction then |     if not parcel_faction or not player_faction then | ||||||
|         return default_is_protected(pos, player) |         return default_is_protected(pos, player) | ||||||
|  |     elseif not player_faction then | ||||||
|  |         return true | ||||||
|     else |     else | ||||||
|         if not not player_faction then  |         if not not player_faction then  | ||||||
|         if parcel_faction.name == player_faction.name then |         if parcel_faction.name == player_faction.name then | ||||||
|             return not parcel_faction:has_permission(player, "build") |             return not parcel_faction:has_permission(player, "build") | ||||||
|         elseif parcel_faction.attacked_parcels[parcelpos] then -- chunk is being attacked |  | ||||||
|             if parcel_faction.attacked_parcels[parcelpos][player_faction] then -- attacked by the player's faction |  | ||||||
|                 return false |  | ||||||
|         else |         else | ||||||
|                 return true |             return not parcel_faction:parcel_is_attacked_by(parcelpos, player_faction) | ||||||
|             end |  | ||||||
|         else |  | ||||||
|             return true |  | ||||||
|         end |         end | ||||||
|         end |         end | ||||||
|     end |     end | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user