Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (102)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (322)
Collections:
Other Resources:
What Is commons-io-2.11.jar
What Is commons-io-2.11.jar?
✍: FYIcenter.com
commons-io-2.11.jar is the JAR file for Commons IO 2.5,
which is a library of utilities to assist with developing IO functionality.
JAR File Size and Download Location:
JAR name: commons-io-2.11.0.jar Target JDK version: 8 Dependency: None File name: commons-io.jar, commons-io-2.11.0.jar File size: 327135 bytes Release date: 01-22-2020 Download: Apache Commons IO Website
Java source code files for commons-io-2.11.jar are:
⏎ org/apache/commons/io/filefilter/AndFileFilter.java
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.apache.commons.io.filefilter;
import java.io.File;
import java.io.Serializable;
import java.nio.file.FileVisitResult;
import java.nio.file.Path;
import java.nio.file.attribute.BasicFileAttributes;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
/**
* A {@link java.io.FileFilter} providing conditional AND logic across a list of
* file filters. This filter returns {@code true} if all filters in the
* list return {@code true}. Otherwise, it returns {@code false}.
* Checking of the file filter list stops when the first filter returns
* {@code false}.
*
* @since 1.0
* @see FileFilterUtils#and(IOFileFilter...)
*/
public class AndFileFilter
extends AbstractFileFilter
implements ConditionalFileFilter, Serializable {
private static final long serialVersionUID = 7215974688563965257L;
/** The list of file filters. */
private final List<IOFileFilter> fileFilters;
/**
* Constructs a new empty instance.
*
* @since 1.1
*/
public AndFileFilter() {
this(0);
}
/**
* Constructs a new instance with the given initial list.
*
* @param initialList the initial list.
*/
private AndFileFilter(final ArrayList<IOFileFilter> initialList) {
this.fileFilters = Objects.requireNonNull(initialList, "initialList");
}
/**
* Constructs a new instance with the given initial capacity.
*
* @param initialCapacity the initial capacity.
*/
private AndFileFilter(final int initialCapacity) {
this(new ArrayList<>(initialCapacity));
}
/**
* Constructs a new file filter that ANDs the result of other filters.
*
* @param filter1 the first filter, must second be null
* @param filter2 the first filter, must not be null
* @throws IllegalArgumentException if either filter is null
*/
public AndFileFilter(final IOFileFilter filter1, final IOFileFilter filter2) {
this(2);
addFileFilter(filter1);
addFileFilter(filter2);
}
/**
* Constructs a new instance for the give filters.
* @param fileFilters filters to OR.
*
* @since 2.9.0
*/
public AndFileFilter(final IOFileFilter... fileFilters) {
this(Objects.requireNonNull(fileFilters, "fileFilters").length);
addFileFilter(fileFilters);
}
/**
* Constructs a new instance of {@code AndFileFilter}
* with the specified list of filters.
*
* @param fileFilters a List of IOFileFilter instances, copied.
* @since 1.1
*/
public AndFileFilter(final List<IOFileFilter> fileFilters) {
this(new ArrayList<>(Objects.requireNonNull(fileFilters, "fileFilters")));
}
/**
* {@inheritDoc}
*/
@Override
public boolean accept(final File file) {
if (isEmpty()) {
return false;
}
for (final IOFileFilter fileFilter : fileFilters) {
if (!fileFilter.accept(file)) {
return false;
}
}
return true;
}
/**
* {@inheritDoc}
*/
@Override
public boolean accept(final File file, final String name) {
if (isEmpty()) {
return false;
}
for (final IOFileFilter fileFilter : fileFilters) {
if (!fileFilter.accept(file, name)) {
return false;
}
}
return true;
}
/**
* {@inheritDoc}
* @since 2.9.0
*/
@Override
public FileVisitResult accept(final Path file, final BasicFileAttributes attributes) {
if (isEmpty()) {
return FileVisitResult.TERMINATE;
}
for (final IOFileFilter fileFilter : fileFilters) {
if (fileFilter.accept(file, attributes) != FileVisitResult.CONTINUE) {
return FileVisitResult.TERMINATE;
}
}
return FileVisitResult.CONTINUE;
}
/**
* {@inheritDoc}
*/
@Override
public void addFileFilter(final IOFileFilter fileFilter) {
this.fileFilters.add(Objects.requireNonNull(fileFilter, "fileFilter"));
}
/**
* Adds the given file filters.
*
* @param fileFilters the filters to add.
* @since 2.9.0
*/
public void addFileFilter(final IOFileFilter... fileFilters) {
for (final IOFileFilter fileFilter : Objects.requireNonNull(fileFilters, "fileFilters")) {
addFileFilter(fileFilter);
}
}
/**
* {@inheritDoc}
*/
@Override
public List<IOFileFilter> getFileFilters() {
return Collections.unmodifiableList(this.fileFilters);
}
private boolean isEmpty() {
return this.fileFilters.isEmpty();
}
/**
* {@inheritDoc}
*/
@Override
public boolean removeFileFilter(final IOFileFilter ioFileFilter) {
return this.fileFilters.remove(ioFileFilter);
}
/**
* {@inheritDoc}
*/
@Override
public void setFileFilters(final List<IOFileFilter> fileFilters) {
this.fileFilters.clear();
this.fileFilters.addAll(fileFilters);
}
/**
* Provide a String representation of this file filter.
*
* @return a String representation
*/
@Override
public String toString() {
final StringBuilder buffer = new StringBuilder();
buffer.append(super.toString());
buffer.append("(");
for (int i = 0; i < fileFilters.size(); i++) {
if (i > 0) {
buffer.append(",");
}
buffer.append(fileFilters.get(i));
}
buffer.append(")");
return buffer.toString();
}
}
⏎ org/apache/commons/io/filefilter/AndFileFilter.java
Or download all of them as a single archive file:
File name: commons-io-2.11.0-sources.jar File size: 398939 bytes Release date: 2020-01-22 Download
⇒ Download and Install commons-io-2.6-bin.zip
⇐ What Is commons-io-2.11-bin.zip
2022-11-10, ≈124🔥, 2💬
Popular Posts:
How to download and install ojdbc7.jar for Oracle 12c R1? ojdbc8.jar for Oracle 12c R1 is a Java 7 a...
maven-embedder-3.8.6.jar is the JAR file for Apache Maven 3.8.6 Embedder module. Apache Maven is a s...
What Is HttpComponents httpclient-4.2.2.jar? HttpComponents httpclient-4.2.2.jar is the JAR file for...
kernel.jar is a component in iText Java library to provide low-level functionalities. iText Java lib...
What Is jsse.jar (JDK 6) Java Secure Socket Extension? jsse.jar, Java Secure Socket Extension, is Ja...