]> source.dussan.org Git - archiva.git/blob
de3b9c84c2e76ff93a112ee1204849a3eb60d753
[archiva.git] /
1 package org.apache.archiva.proxy;
2
3 /*
4  * Licensed to the Apache Software Foundation (ASF) under one
5  * or more contributor license agreements.  See the NOTICE file
6  * distributed with this work for additional information
7  * regarding copyright ownership.  The ASF licenses this file
8  * to you under the Apache License, Version 2.0 (the
9  * "License"); you may not use this file except in compliance
10  * with the License.  You may obtain a copy of the License at
11  *
12  *  http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing,
15  * software distributed under the License is distributed on an
16  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17  * KIND, either express or implied.  See the License for the
18  * specific language governing permissions and limitations
19  * under the License.
20  */
21
22 import org.apache.archiva.proxy.model.ProxyConnector;
23
24 import java.util.Comparator;
25
26 /**
27  * ProxyConnectorOrderComparator 
28  *
29  *
30  */
31 public class ProxyConnectorOrderComparator
32     implements Comparator<ProxyConnector>
33 {
34     private static ProxyConnectorOrderComparator INSTANCE = new ProxyConnectorOrderComparator();
35
36     public static ProxyConnectorOrderComparator getInstance()
37     {
38         return INSTANCE;
39     }
40
41     public int compare( ProxyConnector o1, ProxyConnector o2 )
42     {
43         if ( o1 == null && o2 == null )
44         {
45             return 0;
46         }
47
48         // Ensure null goes to end of list.
49         if ( o1 == null && o2 != null )
50         {
51             return 1;
52         }
53
54         if ( o1 != null && o2 == null )
55         {
56             return -1;
57         }
58
59         // Ensure 0 (unordered) goes to end of list.
60         if ( o1.getOrder() == 0 && o2.getOrder() != 0 )
61         {
62             return 1;
63         }
64
65         if ( o1.getOrder() != 0 && o2.getOrder() == 0 )
66         {
67             return -1;
68         }
69
70         return o1.getOrder() - o2.getOrder();
71     }
72 }