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

org.jtrim2.taskgraph.TaskNodeKey Maven / Gradle / Ivy

package org.jtrim2.taskgraph;

import java.util.Objects;


/**
 * Defines the key uniquely identifying a particular task node.
 *
 * 

Thread safety

* This class is immutable (with the assumption that the {@link #getFactoryArg() factory argument} * is also immutable, and as such, its methods can be safely accessed from multiple concurrent threads. * *

Synchronization transparency

* The methods of this class are synchronization transparent. * * @param the return type of the function of the associated task node * @param the type of the argument passed to the task node factory when requested for * the node to be created * * @see TaskGraphBuilder * @see TaskFactoryKey */ public final class TaskNodeKey { private final TaskFactoryKey factoryKey; private final I factoryArg; /** * Creates a new {@code TaskNodeKey} with the given factory key and argument. * * @param factoryKey the key identifying the task factory creating the node. * This argument cannot be {@code null}. * @param factoryArg the argument passed to the task factory creating the node. * This argument can be {@code null}, if the task factory accepts {@code null} arguments. */ public TaskNodeKey(TaskFactoryKey factoryKey, I factoryArg) { Objects.requireNonNull(factoryKey, "factoryKey"); this.factoryKey = factoryKey; this.factoryArg = factoryArg; } /** * Returns the key identifying the task factory creating the node. * * @return the key identifying the task factory creating the node. This method * never returns {@code null}. */ public TaskFactoryKey getFactoryKey() { return factoryKey; } /** * Returns the argument passed to the task factory creating the node. * * @return the argument passed to the task factory creating the node. * This method may return {@code null}, if {@code null} was specified in the constructor. */ public I getFactoryArg() { return factoryArg; } /** * Returns a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskFactoryKey#getKey() custom factory key} replaced. * * @param newKey the new custom key of the returned task node key. This argument can be * {@code null}. * @return a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskFactoryKey#getKey() custom factory key} replaced. This method * never returns {@code null}. */ public TaskNodeKey withFactoryCustomKey(Object newKey) { return new TaskNodeKey<>(factoryKey.withKey(newKey), factoryArg); } /** * Returns a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskFactoryKey#getResultType() result type} replaced. * * @param the result type of the returned task node key * @param newResultType the result type of the returned task node key. This argument * cannot be {@code null}. * @return a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskFactoryKey#getResultType() result type} replaced. * This method never returns {@code null}. */ public TaskNodeKey withResultType(Class newResultType) { return new TaskNodeKey<>(factoryKey.withResultType(newResultType), factoryArg); } /** * Returns a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskNodeKey#getFactoryKey() factory key} replaced. * * @param the result type of the returned task factory node key * @param newKey the factory key of the returned task node key. This argument can be * {@code null}. * @return a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskNodeKey#getFactoryKey() factory key} replaced. This method * never returns {@code null}. */ public TaskNodeKey withFactoryKey(TaskFactoryKey newKey) { return new TaskNodeKey<>(newKey, factoryArg); } /** * Returns a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskNodeKey#getFactoryArg() factory argument} replaced. * * @param newArg the factory argument of the returned {@code TaskNodeKey}. This argument * can be {@code null}, if the task factory accepts {@code null} arguments. * @return a {@code TaskNodeKey} with the same properties as this {@code TaskNodeKey} * but with its {@link TaskNodeKey#getFactoryArg() factory argument} replaced. This method * never returns {@code null}. */ public TaskNodeKey withFactoryArg(I newArg) { return new TaskNodeKey<>(factoryKey, newArg); } /** * {@inheritDoc } */ @Override public int hashCode() { int hash = 3; hash = 67 * hash + Objects.hashCode(factoryKey); hash = 67 * hash + Objects.hashCode(factoryArg); return hash; } /** * Returns {@code true} if the passed object is a {@code TaskNodeKey} * and identifies the same task node as this {@code TaskNodeKey}. * * @param obj the other object to which this {@code TaskNodeKey} is compared to. * This argument can be {@code null}, in which case the return value is {@code false}. * @return {@code true} if the passed object is a {@code TaskNodeKey} * and identifies the same task node as this {@code TaskNodeKey}, * {@code false} otherwise */ @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; final TaskNodeKey other = (TaskNodeKey) obj; return Objects.equals(this.factoryKey, other.factoryKey) && Objects.equals(this.factoryArg, other.factoryArg); } /** * Returns the string representation of this {@code TaskNodeKey} in no particular * format. *

* This method is intended to be used for debugging only. * * @return the string representation of this object in no particular format. * This method never returns {@code null}. */ @Override public String toString() { return "TaskNodeKey{" + "factoryKey=" + factoryKey + ", factoryArg=" + factoryArg + '}'; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy