mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-07 15:07:28 -06:00
Make sure stacks will have non-empty definitionChanges in project loading
CURA-4107 In old Cura, there is no definitionChanges container, so loading a project file from an old version will result in stacks with empty defnitionChanges. This will cause an unnecessary auto-slice problem when we switch between the extruder tabs for the first time. This action will trigger a piece code in MachineAction which creates a definitionChanges container for the active stack if it is empty. This eventually triggers a propertyChanged signal and results in an unncessary auto-slicing.
This commit is contained in:
parent
3ebaacfa11
commit
da8b55cf62
1 changed files with 8 additions and 0 deletions
|
@ -17,6 +17,7 @@ from .WorkspaceDialog import WorkspaceDialog
|
||||||
|
|
||||||
import xml.etree.ElementTree as ET
|
import xml.etree.ElementTree as ET
|
||||||
|
|
||||||
|
from cura.Settings.CuraStackBuilder import CuraStackBuilder
|
||||||
from cura.Settings.ExtruderManager import ExtruderManager
|
from cura.Settings.ExtruderManager import ExtruderManager
|
||||||
from cura.Settings.ExtruderStack import ExtruderStack
|
from cura.Settings.ExtruderStack import ExtruderStack
|
||||||
from cura.Settings.GlobalStack import GlobalStack
|
from cura.Settings.GlobalStack import GlobalStack
|
||||||
|
@ -665,6 +666,9 @@ class ThreeMFWorkspaceReader(WorkspaceReader):
|
||||||
Logger.log("e", "Resolve strategy of %s for machine is not supported",
|
Logger.log("e", "Resolve strategy of %s for machine is not supported",
|
||||||
self._resolve_strategies["machine"])
|
self._resolve_strategies["machine"])
|
||||||
|
|
||||||
|
# Create a new definition_changes container if it was empty
|
||||||
|
if stack.definitionChanges == self._container_registry.getEmptyInstanceContainer():
|
||||||
|
stack.setDefinitionChanges(CuraStackBuilder.createDefinitionChangesContainer(stack, stack._id + "_settings"))
|
||||||
global_stack = stack
|
global_stack = stack
|
||||||
Job.yieldThread()
|
Job.yieldThread()
|
||||||
except:
|
except:
|
||||||
|
@ -722,6 +726,10 @@ class ThreeMFWorkspaceReader(WorkspaceReader):
|
||||||
else:
|
else:
|
||||||
Logger.log("w", "Unknown resolve strategy: %s", self._resolve_strategies["machine"])
|
Logger.log("w", "Unknown resolve strategy: %s", self._resolve_strategies["machine"])
|
||||||
|
|
||||||
|
# Create a new definition_changes container if it was empty
|
||||||
|
if stack.definitionChanges == self._container_registry.getEmptyInstanceContainer():
|
||||||
|
stack.setDefinitionChanges(CuraStackBuilder.createDefinitionChangesContainer(stack, stack._id + "_settings"))
|
||||||
|
|
||||||
extruder_stacks.append(stack)
|
extruder_stacks.append(stack)
|
||||||
except:
|
except:
|
||||||
Logger.logException("w", "We failed to serialize the stack. Trying to clean up.")
|
Logger.logException("w", "We failed to serialize the stack. Trying to clean up.")
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue