2017-10-04 3 views
0

J'essaie de comprendre comment construire personnalisé Comparator. J'ai trouvé un question similaire mais je suis toujours coincé. Je veux trier les fichiers en utilisant quelques ArrayList s, par exemple:Groovy Personnalisé Comparateur

mes fichiers:

def files = ['author/foo.pkb', 'author/foo.pks', 
'version/test1.pks', 'version/test1.pkb', 'Somethink/foo.sql'] 

Ma liste de commande:

def my_order = ['version', 'author', 'somethink'] // 1 value 
def my_extension_order ['.pks', '.pkb'] 

Et je veux construire somethink comme ça:

def my_index = { x -> 
     return my_order.findIndexOf { x.contains(it) } 
    } 
def my_extension_order = { y -> 
     return my_extension_order.findIndexOf { y.contains(it) } 
    } 

files.sort { a, b -> my_index(a) <=> my_index(b) ?: a <=> b && // sort files and extension 

Dans la sortie je veux avoir trié les fichiers par my_order et inclure my_extension_order. Il devrait ressembler à ça:

def = ['version/test1.pks', 'version/test1.pkb', 'author/foo.pks', 'author/foo.pkb', 
'Somethink/foo.sql'] 

Résumant dans file.sort Je veux trier mes fichiers par 2 ArrayList s pour obtenir une sortie cohérente. Alors, comment construire un comparateur pour le faire?

Répondre

1

Cela fera:

def my_index = { x -> my_order.findIndexOf { x.contains(it) } } 
def my_extension_index = { y -> my_extension_order.findIndexOf { y.contains(it) } } 
files.sort { a, b -> my_index(a) <=> my_index(b) ?: (my_extension_index(a) <=> my_extension_index(b) ?: a <=> b) }