Class PathFileComparator

  • All Implemented Interfaces:
    Serializable, Comparator<File>

    public class PathFileComparator
    extends Object
    implements Serializable
    Compare the path of two files for order (see File.getPath()).

    This comparator can be used to sort lists or arrays of files by their path either in a case-sensitive, case-insensitive or system dependent case sensitive way. A number of singleton instances are provided for the various case sensitivity options (using IOCase) and the reverse of those options.

    Example of a case-sensitive file path sort using the PATH_COMPARATOR singleton instance:

           List<File> list = ...
           ((AbstractFileComparator) PathFileComparator.PATH_COMPARATOR).sort(list);
     

    Example of a reverse case-insensitive file path sort using the PATH_INSENSITIVE_REVERSE singleton instance:

           File[] array = ...
           ((AbstractFileComparator) PathFileComparator.PATH_INSENSITIVE_REVERSE).sort(array);
     

    Since:
    1.4
    See Also:
    Serialized Form
    • Constructor Detail

      • PathFileComparator

        public PathFileComparator()
        Construct a case sensitive file path comparator instance.
      • PathFileComparator

        public PathFileComparator​(IOCase caseSensitivity)
        Construct a file path comparator instance with the specified case-sensitivity.
        Parameters:
        caseSensitivity - how to handle case sensitivity, null means case-sensitive
    • Method Detail

      • compare

        public int compare​(File file1,
                           File file2)
        Compare the paths of two files the specified case sensitivity.
        Specified by:
        compare in interface Comparator<File>
        Parameters:
        file1 - The first file to compare
        file2 - The second file to compare
        Returns:
        a negative value if the first file's path is less than the second, zero if the paths are the same and a positive value if the first files path is greater than the second file.
      • toString

        public String toString()
        String representation of this file comparator.
        Returns:
        String representation of this file comparator
      • sort

        public File[] sort​(File... files)
        Sort an array of files.

        This method uses Arrays.sort(Object[], Comparator) and returns the original array.

        Parameters:
        files - The files to sort, may be null
        Returns:
        The sorted array
        Since:
        2.0