private void transferMerge(List<Edit<?>> editList, Map<Object, Object> oldNewMapping, Dataflow nestedDataflow, Merge merge) throws EditException { editList.add(edits.getRemoveMergeEdit(currentDataflow, merge)); Merge newMerge = edits.createMerge(nestedDataflow); edits.getAddMergeEdit(nestedDataflow, newMerge).doEdit(); oldNewMapping.put(merge, newMerge); for (MergeInputPort mip : merge.getInputPorts()) { MergeInputPort newMip = edits.createMergeInputPort(newMerge, mip.getName(), mip.getDepth()); edits.getAddMergeInputPortEdit(newMerge, newMip).doEdit(); oldNewMapping.put(mip, newMip); } oldNewMapping.put(merge.getOutputPort(), newMerge.getOutputPort()); }
@Override public void refreshView() { mergeView = new JPanel(); mergeView.setLayout(new BoxLayout(mergeView, BoxLayout.PAGE_AXIS)); mergeView.setBorder(new EmptyBorder(5, 5, 5, 5)); mergeView.add(new JLabel("Merge: " + merge.getLocalName())); mergeView.add(Box.createRigidArea(new Dimension(0,5))); mergeView.add(new JLabel("Inputs: ")); for (MergeInputPort mergeInputPort : merge.getInputPorts()) { mergeView.add(new JLabel(mergeInputPort.getName())); } mergeView.add(Box.createRigidArea(new Dimension(0,5))); mergeView.add(new JLabel("Outputs: ")); mergeView.add(new JLabel(merge.getOutputPort().getName())); } }
public MergeConfigurationView(Merge merge){ super((Frame)null, "Merge Configuration", true); this.merge = merge; // Ordered list of merge's input ports inputPortsList = new ArrayList<MergeInputPort>(merge.getInputPorts()); // Generate labels for the input ports (label displays a link from a workflow entity // towards the merge's input port) labelListModel = new DefaultListModel(); String maxLabel = "Order of incoming links (entity.port -> merge):"+"Push"; for (MergeInputPort mergeInputPort : inputPortsList){ EventForwardingOutputPort sourcePort = mergeInputPort.getIncomingLink().getSource(); // Get the name TokenProcessingEntity (Processor or another Merge or Dataflow) and // its port that contains the source EventForwardingOutputPort Dataflow workflow = FileManager.getInstance().getCurrentDataflow(); TokenProcessingEntity entity = Tools.getTokenProcessingEntityWithEventForwardingOutputPort(sourcePort, workflow); if (entity != null){ String link = entity.getLocalName() + "." + sourcePort.getName() + " -> " + merge.getLocalName(); if (link.length() > maxLabel.length()) maxLabel = link; labelListModel.addElement(link); } } initComponents(); }
@Override public String getViewTitle() { return "Merge " + merge.getLocalName(); }
public ReorderMergeInputPortsEdit(Merge merge, List<? extends MergeInputPort> reorderedInputPortList) { super(merge); this.reorderedInputPortList = reorderedInputPortList; this.previousInputPortList = merge.getInputPorts(); }
merge, getUniqueMergeInputPortName(merge, incomingLink .getSource().getName() + "To" + merge.getLocalName() + "_input", counter++), incomingLink.getSink() .getDepth()); editList.add(edits.getAddMergeInputPortEdit(merge, .getSource(), mergeInputPort); editList.add(edits.getConnectDatalinkEdit(datalink)); datalink = edits.createDatalink(merge.getOutputPort(), incomingLink.getSink()); editList.add(edits.getConnectDatalinkEdit(datalink)); + "To" + merge.getLocalName() + "_input", counter), sink.getDepth()); editList.add(edits.getAddMergeInputPortEdit(merge, mergeInputPort)); Datalink datalink = edits.createDatalink(source, mergeInputPort);
Merge merge = (Merge) dataflowObject; if (sourceObject != null) { Set<? extends Datalink> outgoingLinks = merge.getOutputPort().getOutgoingLinks(); if (outgoingLinks.size() == 1) { Datalink datalink = outgoingLinks.iterator().next();
/** * Creates a MergeImpl instance. Merge names are generated as 'Merge0', * 'Merge1', 'Merge2', etc. The next merge to be added always gets the name * as the previous merge in the list with its index incremented by one. If a * merge is deleted, that is not taken into account when generating merges' * names. */ public Merge createMerge(Dataflow dataflow) { String mergeName; // Get all merges for a workflow List<? extends Merge> merges = (List<? extends Merge>) dataflow .getMerges(); if (merges.isEmpty()) { mergeName = "Merge0"; // the first merge to be added to the list } else { String lastMergeName = merges.get(merges.size() - 1).getLocalName(); // Get the index of the last Merge int lastMergeIndex = Integer.parseInt(lastMergeName.substring(5)); mergeName = "Merge" + String.valueOf((lastMergeIndex + 1)); } return new MergeImpl(mergeName); }
public static String getUniqueMergeInputPortName(Merge merge, String name, int count) { String uniqueName = name + count; for (MergeInputPort mergeInputPort : merge.getInputPorts()) { if (mergeInputPort.getName().equals(uniqueName)) { return getUniqueMergeInputPortName(merge, name, ++count); } } return uniqueName; }
merge, getUniqueMergeInputPortName(merge, incomingLink .getSource().getName() + "To" + merge.getLocalName() + "_input", counter++), incomingLink.getSink().getDepth()); editList.add(edits.getAddMergeInputPortEdit(merge, .getSource(), mergeInputPort); editList.add(edits.getConnectDatalinkEdit(datalink)); datalink = edits.createDatalink(merge.getOutputPort(), incomingLink.getSink()); editList.add(edits.getConnectDatalinkEdit(datalink)); + merge.getLocalName() + "_input", counter), sink .getDepth()); editList.add(edits.getAddMergeInputPortEdit(merge, mergeInputPort));
if (merge.getOutputPort().equals(port)) { return merge;
public void actionPerformed(ActionEvent e) { try { List<? extends MergeInputPort> inputPorts = merge.getInputPorts(); EventForwardingOutputPort outputPort = merge.getOutputPort(); List<Edit<?>> editList = new ArrayList<Edit<?>>(); for (MergeInputPort inputPort : inputPorts) { Datalink datalink = inputPort.getIncomingLink(); if (datalink != null) { editList.add(Tools.getDisconnectDatalinkAndRemovePortsEdit(datalink)); } } for (Datalink datalink : outputPort.getOutgoingLinks()) { editList.add(Tools.getDisconnectDatalinkAndRemovePortsEdit(datalink)); } if (editList.isEmpty()) { editManager.doDataflowEdit(dataflow, edits.getRemoveMergeEdit(dataflow, merge)); } else { editList.add(edits.getRemoveMergeEdit(dataflow, merge)); editManager.doDataflowEdit(dataflow, new CompoundEdit(editList)); } dataflowSelectionModel.removeSelection(merge); } catch (EditException e1) { logger.debug("Delete merge failed", e1); } }
for (MergeInputPort mergeInputPort : merge.getInputPorts()){ EventForwardingOutputPort sourcePort = mergeInputPort.getIncomingLink().getSource(); if (entity != null){ html += "<tr><td>"+ (counter++) + ".</td><td>" + entity.getLocalName() + "." + sourcePort.getName() + " -> " + merge.getLocalName() + "</td></tr>"; Object[] links = merge.getOutputPort().getOutgoingLinks().toArray(); html += "<tr><td>1.</td><td>" + merge.getLocalName() + " -> " + entity.getLocalName() + "." + targetPort.getName() + "</td></tr>";
/** * Creates a MergeImpl instance. Merge names are generated as 'Merge0', * 'Merge1', 'Merge2', etc. The next merge to be added always gets the name * as the previous merge in the list with its index incremented by one. If a * merge is deleted, that is not taken into account when generating merges' * names. */ public Merge createMerge(Dataflow dataflow) { String mergeName; // Get all merges for a workflow List<? extends Merge> merges = (List<? extends Merge>) dataflow .getMerges(); if (merges.isEmpty()) { mergeName = "Merge0"; // the first merge to be added to the list } else { String lastMergeName = merges.get(merges.size() - 1).getLocalName(); // Get the index of the last Merge int lastMergeIndex = Integer.parseInt(lastMergeName.substring(5)); mergeName = "Merge" + String.valueOf((lastMergeIndex + 1)); } return new MergeImpl(mergeName); }
public static String getUniqueMergeInputPortName(Merge merge, String name, int count) { String uniqueName = name + count; for (MergeInputPort mergeInputPort : merge.getInputPorts()) { if (mergeInputPort.getName().equals(uniqueName)) { return getUniqueMergeInputPortName(merge, name, ++count); } } return uniqueName; }
Merge m = ((MergeInputPortImpl) link.getSink()).getMerge(); effectiveLink = (Datalink) m .getOutputPort().getOutgoingLinks().toArray()[0]; dataLinkSinkType = determineDatalinkType(effectiveLink.getSink());
@Test public void undo() throws Exception { Edit<Merge> theEdit = new ConnectMergedDatalinkEdit(merge,sourcePort,sinkPort); theEdit.doEdit(); theEdit.undo(); assertEquals(0,merge.getInputPorts().size()); assertEquals(0,merge.getOutputPort().getOutgoingLinks().size()); assertEquals(0,sourcePort.getOutgoingLinks().size()); assertNull(sinkPort.getIncomingLink()); }
private GraphNode generateMergeNode(Merge merge, String prefix, int depth) { GraphNode node = createGraphNode(); node.setId(prefix + merge.getLocalName()); node.setLabel(""); node.setShape(getPortStyle().mergeShape()); for (MergeInputPort inputPort : merge.getInputPorts()) { GraphNode portNode = createGraphNode(); portNode.setId("i" + inputPort.getName()); OutputPort outputPort = merge.getOutputPort(); GraphNode portNode = createGraphNode(); portNode.setId("o" + outputPort.getName());
/** * Adds a processor on the DataFlow. * * @param processor * the ProcessorImpl to be added to the Dataflow * @return * @throws NamingException * if a processor already exists with the same local name */ protected synchronized void addMerge(MergeImpl merge) throws NamingException { for (Merge existingMerge : merges.toArray(new Merge[] {})) { if (existingMerge.getLocalName().equals(merge.getLocalName())) throw new NamingException( "There already is a merge operation named:" + merge.getLocalName()); } merges.add(merge); }
for (MergeInputPort mip : merge.getInputPorts()) { for (Datalink dl : d.getLinks()) { if (dl.getSink().equals(mip)) {