summaryrefslogtreecommitdiffstats
path: root/aspectj-attic/testing-src/org/aspectj/testing/compare/GenericTreeNodeListOrdererI.java
blob: 7f5e2bd07f5efdad41d3a48ef2cb415b41debda3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/* *******************************************************************
 * Copyright (c) 1999-2001 Xerox Corporation, 
 *               2002 Palo Alto Research Center, Incorporated (PARC).
 * All rights reserved. 
 * This program and the accompanying materials are made available 
 * under the terms of the Common Public License v1.0 
 * which accompanies this distribution and is available at 
 * http://www.eclipse.org/legal/cpl-v10.html 
 *  
 * Contributors: 
 *     Xerox/PARC     initial implementation 
 * ******************************************************************/

package org.aspectj.testing.compare;

import java.util.List;

/**
 * Puts two lists of GenericTreeNode children
 * in traversal order for comparison purposes.
 * Given two lists, produce two lists which
 * should be the comparison order of the two.
 * In the case of set comparison, this will 
 * impose an ordering on the produced lists 
 * such that the equal elements are pairs.
 * In the case of list comparison, it may
 * impose an ordering if the comparator itself
 * does not. 
 * All Lists must contain only GenericTreeNode.
 */
public interface GenericTreeNodeListOrdererI {
    /**
     * Produce lists representing the proper transformation of 
     * the children for a given visitor.  
     * To use the existing lists, return them in a new array.
     * You may return null for one or both Lists. 
     * @param lhs the List representing the left-hand-side
     *            which contains only GenericTreeNode
     * @param rhs the List representing the right-hand-side
     *            which contains only GenericTreeNode
     * @return two lists List[] (0 => lhs, 1 => rhs)
     */
    public List[] produceLists(List lhs, List rhs);
}