# Copyright (c) 2018 Ultimaker B.V. # Cura is released under the terms of the LGPLv3 or higher. from typing import List, Optional from PyQt5.Qt import QObject, pyqtSlot from cura.Machines.ContainerNode import ContainerNode # # A ContainerGroup represents a group of containers that must be applied to each ContainerStack when it's used. # Some concrete examples are Quality and QualityChanges: when we select quality type "normal", this quality type # must be applied to all stacks in a machine, although each stack can have different containers. Use an Ultimaker 3 # as an example, suppose we choose quality type "normal", the actual InstanceConstainers on each stack may look # as below: # GlobalStack ExtruderStack 1 ExtruderStack 2 # quality container: um3_global_normal um3_aa04_pla_normal um3_aa04_abs_normal # # This ContainerGroup is mainly used in quality and quality_changes to group the containers that can be applied to # a machine, so when a quality/custom quality is selected, the container can be directly applied to each stack instead # of looking them up again. # class ContainerGroup(QObject): def __init__(self, name: str, parent = None): super().__init__(parent) self.name = name self.node_for_global = None # type: Optional[ContainerNode] self.nodes_for_extruders = dict() @pyqtSlot(result = str) def getName(self) -> str: return self.name def getAllKeys(self) -> set: result = set() for node in [self.node_for_global] + list(self.nodes_for_extruders.values()): if node is None: continue for key in node.getContainer().getAllKeys(): result.add(key) return result def getAllNodes(self) -> List[ContainerNode]: result = [] if self.node_for_global is not None: result.append(self.node_for_global) for extruder_node in self.nodes_for_extruders.values(): result.append(extruder_node) return result