Restore mass-removed t3 modules properly

This commit is contained in:
DarkPhoenix
2019-04-30 01:23:52 +03:00
parent f8c2604fb2
commit ba21ebe058
3 changed files with 29 additions and 11 deletions

View File

@@ -924,8 +924,10 @@ class Fit(object):
recalc. Figure out a way to keep track of any changes to slot layout and call this automatically
"""
if self.ship is None:
return
return {}
# Look for any dummies of that type to remove
posToRemove = {}
for slotType in (FittingSlot.LOW.value, FittingSlot.MED.value, FittingSlot.HIGH.value, FittingSlot.RIG.value, FittingSlot.SUBSYSTEM.value, FittingSlot.SERVICE.value):
amount = self.getSlotsFree(slotType, True)
if amount > 0:
@@ -933,16 +935,17 @@ class Fit(object):
self.modules.append(Module.buildEmpty(slotType))
if amount < 0:
# Look for any dummies of that type to remove
toRemove = []
for mod in self.modules:
if mod.isEmpty and mod.slot == slotType:
toRemove.append(mod)
pos = self.modules.index(mod)
posToRemove[pos] = slotType
amount += 1
if amount == 0:
break
for mod in toRemove:
self.modules.remove(mod)
for pos in sorted(posToRemove, reverse=True):
mod = self.modules[pos]
self.modules.remove(mod)
return posToRemove
def unfill(self):
for i in range(len(self.modules) - 1, -1, -1):

View File

@@ -2,6 +2,7 @@ import wx
from logbook import Logger
import eos.db
from eos.const import FittingSlot
from gui.fitCommands.helpers import ModuleInfo, restoreCheckedStates
from service.fit import Fit
@@ -16,6 +17,7 @@ class CalcRemoveLocalModulesCommand(wx.Command):
self.fitID = fitID
self.positions = positions
self.commit = commit
self.savedSubInfos = None
self.savedModInfos = None
self.savedStateCheckChanges = None
@@ -24,14 +26,18 @@ class CalcRemoveLocalModulesCommand(wx.Command):
sFit = Fit.getInstance()
fit = sFit.getFit(self.fitID)
self.savedSubInfos = {}
self.savedModInfos = {}
for position in self.positions:
mod = fit.modules[position]
if not mod.isEmpty:
self.savedModInfos[position] = ModuleInfo.fromModule(mod)
if mod.slot == FittingSlot.SUBSYSTEM:
self.savedSubInfos[position] = ModuleInfo.fromModule(mod)
else:
self.savedModInfos[position] = ModuleInfo.fromModule(mod)
fit.modules.free(position)
if len(self.savedModInfos) == 0:
if len(self.savedSubInfos) == 0 and len(self.savedModInfos) == 0:
return False
# Need to flush because checkStates sometimes relies on module->fit
@@ -48,14 +54,22 @@ class CalcRemoveLocalModulesCommand(wx.Command):
pyfalog.debug('Undoing removal of local modules {} on fit {}'.format(self.savedModInfos, self.fitID))
results = []
from .localReplace import CalcReplaceLocalModuleCommand
# Restore subsystems 1st
if len(self.savedSubInfos) > 0:
for position, modInfo in self.savedSubInfos.items():
cmd = CalcReplaceLocalModuleCommand(
fitID=self.fitID, position=position, newModInfo=modInfo, commit=False)
results.append(cmd.Do())
sFit = Fit.getInstance()
fit = sFit.getFit(self.fitID)
sFit.recalc(fit)
for position, modInfo in self.savedModInfos.items():
# Do not commit in any case to not worsen performance, we will commit later anyway
cmd = CalcReplaceLocalModuleCommand(
fitID=self.fitID, position=position, newModInfo=modInfo, commit=False)
results.append(cmd.Do())
if not any(results):
return False
restoreCheckedStates(Fit.getInstance().getFit(self.fitID), self.savedStateCheckChanges)
restoreCheckedStates(fit, self.savedStateCheckChanges)
if self.commit:
eos.db.commit()
return True

View File

@@ -480,5 +480,6 @@ class Fit(FitDeprecated):
fit.clear()
fit.calculateModifiedAttributes()
fit.fill()
removedDummies = fit.fill()
pyfalog.info("=" * 10 + "recalc time: " + str(time() - start_time) + "=" * 10)
return removedDummies