All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.cp.elements.io.FileComparatorFactory Maven / Gradle / Ivy

Go to download

Java Simplified. Extensions and Useful Constructs for the Java Platform. Codeprimate Elements (a.k.a. cp-elements) is a Java library and micro-framework used to simplify the development of software applications written in Java. Elements packages several APIs into one library in order to address various application concerns and aspects of software design and development collectively and conveniently. Elements is a highly simple, yet robust and proven library built on solid OO principles, software design patterns and best practices to effectively solve common and reoccurring problems in software development.

There is a newer version: 2.0.0-M1
Show newest version
/*
 * Copyright 2016 Author or Authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.cp.elements.io;

import java.io.File;
import java.util.Comparator;

/**
 * The FileComparatorFactory class is a factory returning different {@link File} {@link Comparator} implementations
 * based on various {@link File} properties and attributes.
 *
 * @author John J. Blum
 * @see java.io.File
 * @see java.util.Comparator
 * @since 1.0.0
 */
public abstract class FileComparatorFactory {

  /**
   * Returns a {@link Comparator} used to compare two different {@link File}s for order based on their extension.
   *
   * @return a {@link Comparator} used to compare {@link File}s for order by their extension.
   * @see org.cp.elements.io.FileUtils#getExtension(File)
   * @see java.lang.Comparable#compareTo(Object)
   * @see java.util.Comparator
   * @see java.io.File
   */
  public static Comparator fileExtensionComparator() {
    return Comparator.comparing(FileUtils::getExtension);
  }

  /**
   * Returns a {@link Comparator} used to compare two different {@link File}s for order based on their last modified
   * timestamp.
   *
   * @return a {@link Comparator} used to compare {@link File}s for order by their last modified timestamp.
   * @see java.io.File#lastModified()
   * @see java.lang.Comparable#compareTo(Object)
   * @see java.util.Comparator
   */
  public static Comparator fileLastModifiedComparator() {
    return (fileOne, fileTwo) -> Long.valueOf(fileOne.lastModified()).compareTo(fileTwo.lastModified());
  }

  /**
   * Returns a {@link Comparator} used to compare two different {@link File}s for order based on their name.
   *
   * @return a {@link Comparator} used to compare {@link File}s for order by their name.
   * @see java.io.File#getName()
   * @see java.lang.Comparable#compareTo(Object)
   * @see java.util.Comparator
   */
  public static Comparator fileNameComparator() {
    return Comparator.comparing(File::getName);
  }

  /**
   * Returns a {@link Comparator} used to compare two different {@link File}s for order based on their
   * file system location (absolute path).
   *
   * @return a {@link Comparator} used to compare {@link File}s for order by their file system location (absolute path).
   * @see java.io.File#getAbsolutePath()
   * @see java.lang.Comparable#compareTo(Object)
   * @see java.util.Comparator
   */
  public static Comparator filePathComparator() {
    return Comparator.comparing(File::getAbsolutePath);
  }

  /**
   * Returns a {@link Comparator} used to compare two different {@link File}s for order based on their size.
   *
   * @return a {@link Comparator} used to compare {@link File}s for order by their size.
   * @see java.io.File#length()
   * @see java.lang.Comparable#compareTo(Object)
   * @see java.util.Comparator
   */
  public static Comparator fileSizeComparator() {
    return (fileOne, fileTwo) -> Long.valueOf(fileOne.length()).compareTo(fileTwo.length());
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy