Skip to main content

This CGIT instance is deprecated, and repositories have been moved to Gitlab or Github. See the repository descriptions for specific locations.

summaryrefslogtreecommitdiffstats
blob: d8bc24338c75798eb9367b3c3a5afdd7eb3de9ba (plain) (blame)
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/********************************************************************************
 * Copyright (c) 2002, 2006 IBM Corporation. All rights reserved.
 * This program and the accompanying materials are made available under the terms
 * of the Eclipse Public License v1.0 which accompanies this distribution, and is 
 * available at http://www.eclipse.org/legal/epl-v10.html
 * 
 * Initial Contributors:
 * The following IBM employees contributed to the Remote System Explorer
 * component that contains this file: David McKnight, Kushal Munir, 
 * Michael Berger, David Dykstal, Phil Coulthard, Don Yantzi, Eric Simpson, 
 * Emily Bruner, Mazen Faraj, Adrian Storisteanu, Li Ding, and Kent Hawley.
 * 
 * Contributors:
 * {Name} (company) - description of contribution.
 ********************************************************************************/

package org.eclipse.dstore.core.util;

import java.util.ArrayList;

import org.eclipse.dstore.core.model.DataElement;

/**
 * Utility class used for sorting a list of DataElements based on 
 * their depth attributes.
 */
public class Sorter
{

	/**
	 * Sort a list of DataElements based on their depth attributes
	 * @param list a list of DataElements
	 * @return a sorted list of DataElements
	 */
	public static ArrayList sort(ArrayList list)
	{
		ArrayList sortedList = new ArrayList(list.size());
		while (list.size() > 0)
		{
			DataElement first = findFirst(list);
			sortedList.add(first);
		}

		return sortedList;
	}

	/**
	 * Find the DataElement with the highest depth in the list
	 * @param list a list of DataElements
	 * @return the DataElement with the highest depth
	 */
	private static DataElement findFirst(ArrayList list)
	{
		DataElement result = null;
		for (int i = 0; i < list.size(); i++)
		{
			DataElement item = (DataElement) list.get(i);
			if (item != null)
			{
				int depth = item.depth();
				if ((result == null) || (depth > result.depth()))
				{
					result = item;
				}
			}
		}

		list.remove(result);
		return result;
	}
}

Back to the top