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

org.eclipse.collections.impl.tuple.PairImpl Maven / Gradle / Ivy

There is a newer version: 12.0.0.M3
Show newest version
/*
 * Copyright (c) 2015 Goldman Sachs.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Eclipse Distribution License v. 1.0 which accompany this distribution.
 * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
 * and the Eclipse Distribution License is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 */

package org.eclipse.collections.impl.tuple;

import java.util.Map;

import org.eclipse.collections.api.tuple.Pair;
import org.eclipse.collections.impl.block.factory.Comparators;

/**
 * A PairImpl is a container that holds two related objects.  It is the equivalent of an Association in Smalltalk, or an
 * implementation of Map.Entry in the JDK.
 */
class PairImpl
        implements Pair
{
    private static final long serialVersionUID = 1L;

    private final T1 one;
    private final T2 two;

    PairImpl(T1 newOne, T2 newTwo)
    {
        this.one = newOne;
        this.two = newTwo;
    }

    public T1 getOne()
    {
        return this.one;
    }

    public T2 getTwo()
    {
        return this.two;
    }

    public void put(Map map)
    {
        map.put(this.one, this.two);
    }

    public PairImpl swap()
    {
        return new PairImpl(this.two, this.one);
    }

    @Override
    public boolean equals(Object o)
    {
        if (this == o)
        {
            return true;
        }
        if (!(o instanceof Pair))
        {
            return false;
        }

        Pair that = (Pair) o;

        return Comparators.nullSafeEquals(this.one, that.getOne())
                && Comparators.nullSafeEquals(this.two, that.getTwo());
    }

    @Override
    public int hashCode()
    {
        int result = this.one == null ? 0 : this.one.hashCode();
        result = 29 * result + (this.two == null ? 0 : this.two.hashCode());
        return result;
    }

    @Override
    public String toString()
    {
        return this.one + ":" + this.two;
    }

    public Map.Entry toEntry()
    {
        return ImmutableEntry.of(this.one, this.two);
    }

    public int compareTo(Pair other)
    {
        int i = ((Comparable) this.one).compareTo(other.getOne());
        if (i != 0)
        {
            return i;
        }
        return ((Comparable) this.two).compareTo(other.getTwo());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy