1 /**********************************************************************
2 * Copyright (c) 2005, 2014 IBM Corporation, Ericsson
3 * All rights reserved. This program and the accompanying materials
4 * are made available under the terms of the Eclipse Public License v1.0
5 * which accompanies this distribution, and is available at
6 * http://www.eclipse.org/legal/epl-v10.html
9 * IBM - Initial API and implementation
10 * Bernd Hufmann - Updated for TMF
11 **********************************************************************/
13 package org
.eclipse
.tracecompass
.tmf
.ui
.views
.uml2sd
.util
;
15 import java
.io
.Serializable
;
16 import java
.util
.Comparator
;
18 import org
.eclipse
.tracecompass
.tmf
.ui
.views
.uml2sd
.core
.AsyncMessage
;
19 import org
.eclipse
.tracecompass
.tmf
.ui
.views
.uml2sd
.core
.GraphNode
;
22 * Asynchronous message comparator Compare two AsyncMessages only taking into account the event occurrence when their
25 * Used to order the AsyncMessage list insuring that next node has one of his ends greater than the current node
31 public class SortAsyncMessageComparator
implements Comparator
<GraphNode
>, Serializable
{
33 // ------------------------------------------------------------------------
35 // ------------------------------------------------------------------------
39 private static final long serialVersionUID
= 1L;
41 // ------------------------------------------------------------------------
43 // ------------------------------------------------------------------------
46 public int compare(GraphNode arg0
, GraphNode arg1
) {
47 if (arg0
instanceof AsyncMessage
&& arg1
instanceof AsyncMessage
) {
48 AsyncMessage m1
= (AsyncMessage
) arg0
;
49 AsyncMessage m2
= (AsyncMessage
) arg1
;
51 // AsyncMessage has two ends which may have different event occurrences
52 // Search for the smaller event occurrence for each messages
53 if (m1
.getStartOccurrence() > m1
.getEndOccurrence()) {
54 m1Min
= m1
.getEndOccurrence();
56 m1Min
= m1
.getStartOccurrence();
58 if (m2
.getStartOccurrence() > m2
.getEndOccurrence()) {
59 m2Min
= m2
.getEndOccurrence();
61 m2Min
= m2
.getStartOccurrence();
65 // Search for the greater event occurrence for each messages
66 if (m1
.getStartOccurrence() > m1
.getEndOccurrence()) {
67 m1Max
= m1
.getStartOccurrence();
69 m1Max
= m1
.getEndOccurrence();
71 if (m2
.getStartOccurrence() > m2
.getEndOccurrence()) {
72 m2Max
= m2
.getStartOccurrence();
74 m2Max
= m2
.getEndOccurrence();
79 } else if ((m1Min
== m2Min
)) {
82 } else if (m1Max
> m2Max
) {