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?