a component is not injected as wip to an assembly buffer if the mould is already created

parent 63a8aa57
...@@ -11,8 +11,8 @@ class InsertWIP(plugin.InputPreparationPlugin): ...@@ -11,8 +11,8 @@ class InsertWIP(plugin.InputPreparationPlugin):
def preprocess(self, data): def preprocess(self, data):
""" updates the Work in Process of each station according to the BOM """ updates the Work in Process of each station according to the BOM
""" """
wip = data["input"]["BOM"].get("WIP", {}) WIP = data["input"]["BOM"].get("WIP", {})
for partID, work in wip.iteritems(): for partID, work in WIP.iteritems():
stationID = work.get("station", None) stationID = work.get("station", None)
if not stationID: if not stationID:
break break
...@@ -20,6 +20,24 @@ class InsertWIP(plugin.InputPreparationPlugin): ...@@ -20,6 +20,24 @@ class InsertWIP(plugin.InputPreparationPlugin):
if not node: if not node:
break break
wip = node.get("wip", []) wip = node.get("wip", [])
endOfRoute = False # flag to signal that the part should not be injected as WIP
mouldCreated = False # flag to signal that the mould of the same order is created
# if the part lies in an assembly buffer
if data['graph']['node'][stationID]['_class'] == 'Dream.MouldAssemblyBuffer':
# find the order it belongs to
for order in data['input']['BOM']['productionOrders']:
for component in order.get('componentsList', []):
if component.get('id',None) == partID:
# if the part is of class OrderComponent (and NOT Mould)
if component.get('_class', None) == 'Dream.OrderComponent':
endOfRoute = True
# find the Mould component of the order and see it is already in the WIP
if component.get('_class', None) == 'Dream.Mould':
if component.get('id', None) in WIP.keys():
mouldCreated = True
# if the part reached the end of its route (an assembly buffer) and the mould is already created
if endOfRoute and mouldCreated:
continue
wip.append({ wip.append({
"id": partID, "id": partID,
"sequence": work.get("sequence", None), "sequence": work.get("sequence", None),
...@@ -42,4 +60,4 @@ class InsertWIP(plugin.InputPreparationPlugin): ...@@ -42,4 +60,4 @@ class InsertWIP(plugin.InputPreparationPlugin):
return data return data
if __name__ == '__main__': if __name__ == '__main__':
pass pass
\ No newline at end of file
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment