mirror of
https://github.com/Wyrrrd/Gun_Turret_Alerts.git
synced 2026-07-01 20:51:08 +02:00
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 2b91680aa2 | |||
| 861dd1fa7d | |||
| b6df0ba763 | |||
| e99c0e0505 | |||
| 3c86e315f4 |
@@ -1,4 +1,19 @@
|
|||||||
---------------------------------------------------------------------------------------------------
|
---------------------------------------------------------------------------------------------------
|
||||||
|
Version: 2.0.5
|
||||||
|
Date: 2024-11-09
|
||||||
|
Bugfixes:
|
||||||
|
- Really fix the crash on surface deletion
|
||||||
|
---------------------------------------------------------------------------------------------------
|
||||||
|
Version: 2.0.4
|
||||||
|
Date: 2024-11-09
|
||||||
|
Bugfixes:
|
||||||
|
- Fix another crash on surface deletion
|
||||||
|
---------------------------------------------------------------------------------------------------
|
||||||
|
Version: 2.0.3
|
||||||
|
Date: 2024-11-08
|
||||||
|
Bugfixes:
|
||||||
|
- Fixed crash on invalid entity
|
||||||
|
---------------------------------------------------------------------------------------------------
|
||||||
Version: 2.0.2
|
Version: 2.0.2
|
||||||
Date: 2024-11-08
|
Date: 2024-11-08
|
||||||
Changes:
|
Changes:
|
||||||
|
|||||||
+11
-11
@@ -90,15 +90,17 @@ local function add_force_to_list(event)
|
|||||||
local player, force
|
local player, force
|
||||||
if event.player_index then
|
if event.player_index then
|
||||||
player = game.get_player(event.player_index)
|
player = game.get_player(event.player_index)
|
||||||
|
if player and player.valid then
|
||||||
force = player.force
|
force = player.force
|
||||||
|
end
|
||||||
elseif event.force then
|
elseif event.force then
|
||||||
force = event.force
|
force = event.force
|
||||||
if force.connected_players then
|
if force.valid and force.connected_players then
|
||||||
player = force.connected_players[1]
|
player = force.connected_players[1]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if player and force and not storage.ammo_entities[player.surface.name.."_"..force.name] then
|
if player and player.valid and force and force.valid and not storage.ammo_entities[player.surface.name.."_"..force.name] then
|
||||||
for _,surface in pairs(game.surfaces) do
|
for _,surface in pairs(game.surfaces) do
|
||||||
storage.ammo_entities[surface.name.."_"..force.name] = surface.find_entities_filtered{type = {"ammo-turret","car","artillery-turret","artillery-wagon","spider-vehicle"}, force = force, to_be_deconstructed = false}
|
storage.ammo_entities[surface.name.."_"..force.name] = surface.find_entities_filtered{type = {"ammo-turret","car","artillery-turret","artillery-wagon","spider-vehicle"}, force = force, to_be_deconstructed = false}
|
||||||
end
|
end
|
||||||
@@ -132,13 +134,13 @@ end
|
|||||||
|
|
||||||
local function remove_surface_from_list(event)
|
local function remove_surface_from_list(event)
|
||||||
--Whenever a surface is renamed or deleted, move/remove all entities in/from the global table.
|
--Whenever a surface is renamed or deleted, move/remove all entities in/from the global table.
|
||||||
for force,_ in pairs(game.forces) do
|
for _,force in pairs(game.forces) do
|
||||||
local index
|
local index
|
||||||
if event.new_name then
|
if event.new_name then
|
||||||
storage.ammo_entities[new_name.."_"..force.name] = table.deepcopy(storage.ammo_entities[old_name.."_"..force.name])
|
storage.ammo_entities[event.new_name.."_"..force.name] = table.deepcopy(storage.ammo_entities[event.old_name.."_"..force.name])
|
||||||
index = old_name.."_"..force.name
|
index = event.old_name.."_"..force.name
|
||||||
elseif event.surface_index then
|
elseif event.surface_index then
|
||||||
index = game.surfaces[surface_index].name.."_"..force.name
|
index = game.surfaces[event.surface_index].name.."_"..force.name
|
||||||
end
|
end
|
||||||
|
|
||||||
if index then
|
if index then
|
||||||
@@ -170,7 +172,7 @@ local function generate_alerts()
|
|||||||
local ammo_entities = storage.ammo_entities[player.surface.name.."_"..player.force.name]
|
local ammo_entities = storage.ammo_entities[player.surface.name.."_"..player.force.name]
|
||||||
|
|
||||||
if ammo_entities then
|
if ammo_entities then
|
||||||
for _,entity in pairs(ammo_entities) do
|
for index,entity in pairs(ammo_entities) do
|
||||||
if entity.valid then
|
if entity.valid then
|
||||||
if entity.force == player.force then
|
if entity.force == player.force then
|
||||||
|
|
||||||
@@ -213,9 +215,7 @@ local function generate_alerts()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
local param = {}
|
ammo_entities[index] = nil
|
||||||
param.entity = entity
|
|
||||||
remove_entity_from_list(param)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -236,7 +236,7 @@ script.on_event(defines.events.on_force_created, add_force_to_list)
|
|||||||
script.on_event(defines.events.on_forces_merged, remove_force_from_list)
|
script.on_event(defines.events.on_forces_merged, remove_force_from_list)
|
||||||
|
|
||||||
script.on_event(defines.events.on_surface_renamed, remove_surface_from_list)
|
script.on_event(defines.events.on_surface_renamed, remove_surface_from_list)
|
||||||
script.on_event(defines.events.on_surface_deleted, remove_surface_from_list)
|
script.on_event(defines.events.on_pre_surface_deleted, remove_surface_from_list)
|
||||||
|
|
||||||
script.on_event(defines.events.on_built_entity, add_entity_to_list, {{filter="type", type = "ammo-turret"},{filter="type", type = "car"},{filter="type", type = "spider-vehicle"},{filter="type", type = "artillery-turret"},{filter="type", type = "artillery-wagon"}})
|
script.on_event(defines.events.on_built_entity, add_entity_to_list, {{filter="type", type = "ammo-turret"},{filter="type", type = "car"},{filter="type", type = "spider-vehicle"},{filter="type", type = "artillery-turret"},{filter="type", type = "artillery-wagon"}})
|
||||||
script.on_event(defines.events.on_robot_built_entity, add_entity_to_list, {{filter="type", type = "ammo-turret"},{filter="type", type = "car"},{filter="type", type = "spider-vehicle"},{filter="type", type = "artillery-turret"},{filter="type", type = "artillery-wagon"}})
|
script.on_event(defines.events.on_robot_built_entity, add_entity_to_list, {{filter="type", type = "ammo-turret"},{filter="type", type = "car"},{filter="type", type = "spider-vehicle"},{filter="type", type = "artillery-turret"},{filter="type", type = "artillery-wagon"}})
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "Gun_Turret_Alerts",
|
"name": "Gun_Turret_Alerts",
|
||||||
"version": "2.0.2",
|
"version": "2.0.5",
|
||||||
"title": "Ammo Alerts",
|
"title": "Ammo Alerts",
|
||||||
"author": "Wyrrrd",
|
"author": "Wyrrrd",
|
||||||
"factorio_version": "2.0",
|
"factorio_version": "2.0",
|
||||||
|
|||||||
@@ -24,3 +24,8 @@ message-low=__1__ hat wenig Munition
|
|||||||
[virtual-signal-name]
|
[virtual-signal-name]
|
||||||
ammo-icon-red=Hat keine Munition
|
ammo-icon-red=Hat keine Munition
|
||||||
ammo-icon-yellow=Hat wenig Munition
|
ammo-icon-yellow=Hat wenig Munition
|
||||||
|
|
||||||
|
[mod-name]
|
||||||
|
|
||||||
|
[mod-description]
|
||||||
|
|
||||||
|
|||||||
@@ -24,3 +24,8 @@ message-low=__1__ peu de munitions
|
|||||||
[virtual-signal-name]
|
[virtual-signal-name]
|
||||||
ammo-icon-red=Signal d'absence de munition
|
ammo-icon-red=Signal d'absence de munition
|
||||||
ammo-icon-yellow=Signal de manque de munitions
|
ammo-icon-yellow=Signal de manque de munitions
|
||||||
|
|
||||||
|
[mod-name]
|
||||||
|
|
||||||
|
[mod-description]
|
||||||
|
|
||||||
|
|||||||
@@ -24,3 +24,8 @@ message-low=__1__ мало боєприпасів
|
|||||||
[virtual-signal-name]
|
[virtual-signal-name]
|
||||||
ammo-icon-red=Сигнал про закінчення набоїв
|
ammo-icon-red=Сигнал про закінчення набоїв
|
||||||
ammo-icon-yellow=Сигнал про низький рівень набоїв
|
ammo-icon-yellow=Сигнал про низький рівень набоїв
|
||||||
|
|
||||||
|
[mod-name]
|
||||||
|
|
||||||
|
[mod-description]
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user