org.apache.crunch.Tuple4 Maven / Gradle / Ivy
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.crunch;
import java.util.Collection;
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.crunch.types.PType;
import org.apache.crunch.types.PTypeFamily;
/**
* A convenience class for four-element {@link Tuple}s.
*/
public class Tuple4 implements Tuple {
public static class Collect extends Tuple4<
Collection,
Collection,
Collection,
Collection> {
public static PType> derived(PType first,
PType second, PType third, PType fourth) {
PTypeFamily tf = first.getFamily();
PType, Collection, Collection, Collection>> pt =
tf.quads(
tf.collections(first),
tf.collections(second),
tf.collections(third),
tf.collections(fourth));
Object clazz = Tuple4.Collect.class;
return tf.derived((Class>) clazz,
new MapFn, Collection, Collection, Collection>,
Collect>() {
@Override
public Collect map(
Tuple4, Collection, Collection, Collection> in) {
return new Collect(in.first(), in.second(), in.third(), in.fourth());
}
},
new MapFn, Tuple4, Collection, Collection, Collection>>() {
@Override
public Tuple4, Collection, Collection, Collection> map(
Collect input) {
return input;
}
}, pt);
}
public Collect(Collection first, Collection second, Collection third, Collection fourth) {
super(first, second, third, fourth);
}
}
private final V1 first;
private final V2 second;
private final V3 third;
private final V4 fourth;
public static Tuple4 of(A a, B b, C c, D d) {
return new Tuple4(a, b, c, d);
}
public Tuple4(V1 first, V2 second, V3 third, V4 fourth) {
this.first = first;
this.second = second;
this.third = third;
this.fourth = fourth;
}
public V1 first() {
return first;
}
public V2 second() {
return second;
}
public V3 third() {
return third;
}
public V4 fourth() {
return fourth;
}
public Object get(int index) {
switch (index) {
case 0:
return first;
case 1:
return second;
case 2:
return third;
case 3:
return fourth;
default:
throw new ArrayIndexOutOfBoundsException();
}
}
public int size() {
return 4;
}
@Override
public int hashCode() {
HashCodeBuilder hcb = new HashCodeBuilder();
return hcb.append(first).append(second).append(third).append(fourth).toHashCode();
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Tuple4, ?, ?, ?> other = (Tuple4, ?, ?, ?>) obj;
return (first == other.first || (first != null && first.equals(other.first)))
&& (second == other.second || (second != null && second.equals(other.second)))
&& (third == other.third || (third != null && third.equals(other.third)))
&& (fourth == other.fourth || (fourth != null && fourth.equals(other.fourth)));
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder("Tuple4[");
sb.append(first).append(",").append(second).append(",").append(third);
return sb.append(",").append(fourth).append("]").toString();
}
}