/******************************************************************************* * Copyright (c) 2007, 2010 Association for Decentralized Information Management * in Industry THTH ry. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * VTT Technical Research Centre of Finland - initial API and implementation *******************************************************************************/ package org.simantics.utils.datastructures; /** * A generic Quad (4-tuple) structure for containing four object instances of * chosen types. * * @param type of first element * @param type of second element * @param type of third element * @param type of fourth element */ public final class Quad { public final T1 first; public final T2 second; public final T3 third; public final T4 fourth; private final int hash; public static Quad make(T1 t1, T2 t2, T3 t3, T4 t4) { return new Quad(t1, t2, t3, t4); } public Quad(T1 first, T2 second, T3 third, T4 fourth) { this.first = first; this.second = second; this.third = third; this.fourth = fourth; this.hash = makeHash(); } @Override public boolean equals(Object obj) { if (obj == null) return false; if (!(obj.getClass().equals(this.getClass()))) return false; Quad other = (Quad) obj; if (other.first != first && (other.first == null || !other.first.equals(first))) return false; if (other.second != second && (other.second == null || !other.second.equals(second))) return false; if (other.third != third && (other.third == null || !other.third.equals(third))) return false; if (other.fourth != fourth && (other.fourth == null || !other.fourth.equals(fourth))) return false; return true; } @Override public int hashCode() { return hash; } @Override public String toString() { return "<"+first+", "+second+", "+third+", "+fourth+">"; } private int makeHash() { return (first == null ? 0 : first.hashCode()) + (second == null ? 0 : second.hashCode())*31 + (third == null ? 0 : third.hashCode())*41+ (fourth == null ? 0 : fourth.hashCode())*71; } }