Project

General

Profile

Download (1.95 KB) Statistics
| Branch: | Tag: | Revision:
1
/**
2
* Copyright (C) 2007 EDIT
3
* European Distributed Institute of Taxonomy
4
* http://www.e-taxonomy.eu
5
*
6
* The contents of this file are subject to the Mozilla Public License Version 1.1
7
* See LICENSE.TXT at the top of this package for the full license terms.
8
*/
9
package eu.etaxonomy.cdm.model.name;
10

    
11
import java.io.Serializable;
12
import java.util.ArrayList;
13
import java.util.Collections;
14
import java.util.Comparator;
15
import java.util.List;
16
import java.util.Set;
17

    
18
import eu.etaxonomy.cdm.model.taxon.HomotypicGroupTaxonComparator;
19
import eu.etaxonomy.cdm.model.taxon.TaxonBase;
20
import eu.etaxonomy.cdm.model.taxon.TaxonComparator;
21

    
22
public class HomotypicalGroupComparator implements
23
		Comparator<HomotypicalGroup>, Serializable {
24
    private static final long serialVersionUID = -676465815899137107L;
25

    
26
    @Override
27
	public int compare(HomotypicalGroup group1, HomotypicalGroup group2) {
28
		TaxonBase<?> firstTypified1 = null;
29
		TaxonBase<?> firstTypified2 = null;
30
		TaxonComparator taxComparator = new HomotypicGroupTaxonComparator(null);
31
		Set<TaxonNameBase> typifiedNames1 = group1.getTypifiedNames();
32
		List<TaxonBase> taxonBasesOfTypifiedNames = new ArrayList<TaxonBase>();
33
		for (TaxonNameBase<?,?> typifiedName:typifiedNames1){
34
			if (!typifiedName.getTaxonBases().isEmpty()){
35
				taxonBasesOfTypifiedNames.add(typifiedName.getTaxonBases().iterator().next());
36
			}
37
		}
38
		Collections.sort(taxonBasesOfTypifiedNames, taxComparator);
39
		firstTypified1 = taxonBasesOfTypifiedNames.get(0);
40

    
41
		Set<TaxonNameBase> typifiedNames2 = group2.getTypifiedNames();
42
		taxonBasesOfTypifiedNames = new ArrayList<TaxonBase>();
43
		for (TaxonNameBase<?,?> typifiedName:typifiedNames2){
44
			if (!typifiedName.getTaxonBases().isEmpty()){
45
				taxonBasesOfTypifiedNames.add(typifiedName.getTaxonBases().iterator().next());
46
			}
47
		}
48
		Collections.sort(taxonBasesOfTypifiedNames, taxComparator);
49
		firstTypified2 = taxonBasesOfTypifiedNames.get(0);
50
		return taxComparator.compare(firstTypified1, firstTypified2);
51
	}
52

    
53
}
(5-5/28)