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

com.github.dm.jrt.function.BiConsumerWrapper Maven / Gradle / Ivy

There is a newer version: 5.9.0
Show newest version
/*
 * 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 com.github.dm.jrt.function;

import com.github.dm.jrt.util.Reflection;

import org.jetbrains.annotations.NotNull;

import java.util.ArrayList;
import java.util.List;

/**
 * Class wrapping a bi-consumer instance.
 * 

* Created by davide-maestroni on 10/11/2015. * * @param the first input data type. * @param the second input data type. */ public class BiConsumerWrapper implements BiConsumer { private final List> mConsumers; /** * Constructor. * * @param consumers the list of wrapped consumers. */ BiConsumerWrapper(@NotNull final List> consumers) { if (consumers.isEmpty()) { throw new IllegalArgumentException("the list of consumers must not be empty"); } mConsumers = consumers; } @SuppressWarnings("unchecked") public void accept(final IN1 in1, final IN2 in2) { for (final BiConsumer consumer : mConsumers) { ((BiConsumer) consumer).accept(in1, in2); } } /** * Returns a composed bi-consumer wrapper that performs, in sequence, this operation followed * by the after operation. * * @param after the operation to perform after this operation. * @return the composed bi-consumer. */ @NotNull public BiConsumerWrapper andThen( @NotNull final BiConsumer after) { final Class consumerClass = after.getClass(); final List> consumers = mConsumers; final ArrayList> newConsumers = new ArrayList>(consumers.size() + 1); newConsumers.addAll(consumers); if (consumerClass == BiConsumerWrapper.class) { newConsumers.addAll(((BiConsumerWrapper) after).mConsumers); } else { newConsumers.add(after); } return new BiConsumerWrapper(newConsumers); } /** * Checks if the bi-consumers wrapped by this instance have a static context. * * @return whether the bi-consumers have a static context. */ public boolean hasStaticContext() { for (final BiConsumer consumer : mConsumers) { if (!Reflection.hasStaticContext(consumer.getClass())) { return false; } } return true; } @Override public int hashCode() { int result = 0; for (final BiConsumer consumer : mConsumers) { result = 31 * result + consumer.getClass().hashCode(); } return result; } @Override public boolean equals(final Object o) { if (this == o) { return true; } if ((o == null) || (getClass() != o.getClass())) { return false; } final BiConsumerWrapper that = (BiConsumerWrapper) o; final List> thisConsumers = mConsumers; final List> thatConsumers = that.mConsumers; final int size = thisConsumers.size(); if (size != thatConsumers.size()) { return false; } for (int i = 0; i < size; ++i) { if (thisConsumers.get(i).getClass() != thatConsumers.get(i).getClass()) { return false; } } return true; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy