You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@commons.apache.org by "Henri Yandell (JIRA)" <ji...@apache.org> on 2011/02/01 17:32:29 UTC

[jira] Updated: (LANG-675) Add Triplet class (similar to Pair)

     [ https://issues.apache.org/jira/browse/LANG-675?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Henri Yandell updated LANG-675:
-------------------------------

    Affects Version/s:     (was: 3.0)
        Fix Version/s: 3.1

> Add Triplet class (similar to Pair)
> -----------------------------------
>
>                 Key: LANG-675
>                 URL: https://issues.apache.org/jira/browse/LANG-675
>             Project: Commons Lang
>          Issue Type: New Feature
>          Components: lang.*
>            Reporter: Axel Fontaine
>             Fix For: 3.1
>
>
> Similar to Pair, a Triplet is a common need.
> Here is an adaptation of the commons-lang Pair that also takes a middle argument:
> import java.io.Serializable;
> import org.apache.commons.lang.ObjectUtils;
> import org.apache.commons.lang.builder.HashCodeBuilder;
> /**
>  * Similar to Pair, using 3 instead of 2 Objects.
>  * 
>  * @param <L>
>  *            The "left" object of the triplet.
>  * @param <M>
>  *            The "middle" object of the triplet.
>  * @param <R>
>  *            The "right" object of the triplet.
>  */
> public final class Triplet<L, M, R> implements Serializable {
>     /** Serialization version */
>     private static final long serialVersionUID = -8359217847916721612L;
>     /**
>      * Static fluent creation method for a Pair<L, R>: <code>Pair.of(left, right)</code>
>      * 
>      * @param <L>
>      *            The "left" object of the triplet.
>      * @param <M>
>      *            The "middle" object of the triplet.
>      * @param <R>
>      *            The "right" object of the triplet.
>      * 
>      * @param left
>      *            The "left" object of the triplet.
>      * @param middle
>      *            The "middle" object of the triplet.
>      * @param right
>      *            The "right" object of the triplet.
>      * 
>      * @return The newly created triplet.
>      */
>     public static <L, M, R> Triplet<L, M, R> of(final L left, final M middle, final R right) {
>         return new Triplet<L, M, R>(left, middle, right);
>     }
>     /** Left object */
>     public final L left;
>     /** Middle object */
>     public final M middle;
>     /** Right object */
>     public final R right;
>     /**
>      * Create a new Triplet instance
>      * 
>      * @param left
>      *            the left object
>      * @param middle
>      *            The "middle" object of the triplet.
>      * @param right
>      *            the right object
>      */
>     public Triplet(final L left, final M middle, final R right) {
>         this.left = left;
>         this.middle = middle;
>         this.right = right;
>     }
>     /**
>      * {@inheritDoc}
>      * 
>      * @see java.lang.Object#equals(java.lang.Object)
>      */
>     @Override
>     public boolean equals(final Object obj) {
>         if (obj == this) {
>             return true;
>         }
>         if (obj instanceof Triplet<?, ?, ?> == false) {
>             return false;
>         }
>         final Triplet<?, ?, ?> other = (Triplet<?, ?, ?>) obj;
>         return ObjectUtils.equals(this.left, other.left) && ObjectUtils.equals(this.middle, other.middle)
>                 && ObjectUtils.equals(this.right, other.right);
>     }
>     /**
>      * {@inheritDoc}
>      * 
>      * @see java.lang.Object#hashCode()
>      */
>     @Override
>     public int hashCode() {
>         return new HashCodeBuilder().append(this.left).append(this.middle).append(this.right).toHashCode();
>     }
>     /**
>      * Returns a String representation of the Pair in the form: (L,R)
>      * 
>      * {@inheritDoc}
>      * 
>      * @see java.lang.Object#toString()
>      */
>     @Override
>     public String toString() {
>         return new StringBuilder().append("(").append(this.left).append(",").append(this.middle).append(",")
>                 .append(this.right).append(")").toString();
>     }
> Feel free to use it if you wish to include it.

-- 
This message is automatically generated by JIRA.
-
For more information on JIRA, see: http://www.atlassian.com/software/jira