Package org.apache.crunch.types

Examples of org.apache.crunch.types.TupleDeepCopier


  public AvroTableType(AvroType<K> keyType, AvroType<V> valueType, Class<Pair<K, V>> pairClass) {
    super(pairClass, org.apache.avro.mapred.Pair.getPairSchema(keyType.getSchema(),
        valueType.getSchema()), new IndexedRecordToPair(keyType.getInputMapFn(),
        valueType.getInputMapFn()), new PairToAvroPair(keyType, valueType),
        new TupleDeepCopier(Pair.class, keyType, valueType), null, keyType, valueType);
    this.keyType = keyType;
    this.valueType = valueType;
  }
View Full Code Here


  public static final <V1, V2> AvroType<Pair<V1, V2>> pairs(PType<V1> p1, PType<V2> p2) {
    Schema schema = createTupleSchema(p1, p2);
    GenericRecordToTuple input = new GenericRecordToTuple(TupleFactory.PAIR, p1, p2);
    TupleToGenericRecord output = new TupleToGenericRecord(schema, p1, p2);
    return new AvroType(Pair.class, schema, input, output, new TupleDeepCopier(Pair.class, p1, p2), null, p1, p2);
  }
View Full Code Here

  }

  public static final <V1, V2, V3> AvroType<Tuple3<V1, V2, V3>> triples(PType<V1> p1, PType<V2> p2, PType<V3> p3) {
    Schema schema = createTupleSchema(p1, p2, p3);
    return new AvroType(Tuple3.class, schema, new GenericRecordToTuple(TupleFactory.TUPLE3, p1, p2, p3),
        new TupleToGenericRecord(schema, p1, p2, p3), new TupleDeepCopier(Tuple3.class, p1, p2, p3), null, p1, p2, p3);
  }
View Full Code Here

  public static final <V1, V2, V3, V4> AvroType<Tuple4<V1, V2, V3, V4>> quads(PType<V1> p1, PType<V2> p2, PType<V3> p3,
      PType<V4> p4) {
    Schema schema = createTupleSchema(p1, p2, p3, p4);
    return new AvroType(Tuple4.class, schema, new GenericRecordToTuple(TupleFactory.TUPLE4, p1, p2, p3, p4),
        new TupleToGenericRecord(schema, p1, p2, p3, p4), new TupleDeepCopier(Tuple4.class, p1, p2, p3, p4), null,
        p1, p2, p3, p4);
  }
View Full Code Here

  }

  public static final AvroType<TupleN> tuples(PType... ptypes) {
    Schema schema = createTupleSchema(ptypes);
    return new AvroType(TupleN.class, schema, new GenericRecordToTuple(TupleFactory.TUPLEN, ptypes),
        new TupleToGenericRecord(schema, ptypes), new TupleDeepCopier(TupleN.class, ptypes), null, ptypes);
  }
View Full Code Here

  public static final AvroType<TupleN> namedTuples(String tupleName, String[] fieldNames, PType[] ptypes) {
    Preconditions.checkArgument(fieldNames.length == ptypes.length,
        "Number of field names must match number of ptypes");
    Schema schema = createTupleSchema(tupleName, fieldNames, ptypes);
    return new AvroType(TupleN.class, schema, new GenericRecordToTuple(TupleFactory.TUPLEN, ptypes),
        new TupleToGenericRecord(schema, ptypes), new TupleDeepCopier(TupleN.class, ptypes), null, ptypes);
  }
View Full Code Here

    for (int i = 0; i < typeArgs.length; i++) {
      typeArgs[i] = ptypes[i].getTypeClass();
    }
    TupleFactory<T> factory = TupleFactory.create(clazz, typeArgs);
    return new AvroType<T>(clazz, schema, new GenericRecordToTuple(factory, ptypes), new TupleToGenericRecord(schema,
        ptypes), new TupleDeepCopier(clazz, ptypes), null, ptypes);
  }
View Full Code Here

  public AvroKeyValueTableType(AvroType<K> keyType, AvroType<V> valueType, Class<Pair<K, V>> pairClass) {
    super(pairClass, AvroKeyValue.getSchema(keyType.getSchema(), valueType.getSchema()),
        new AvroKeyValueRecordToPair(keyType.getInputMapFn(), valueType.getInputMapFn()),
        new PairToAvroKeyValueRecord(keyType, valueType),
        new TupleDeepCopier(Pair.class, keyType, valueType),
        null, keyType, valueType);
    this.keyType = keyType;
    this.valueType = valueType;
  }
View Full Code Here

  public AvroTableType(AvroType<K> keyType, AvroType<V> valueType, Class<Pair<K, V>> pairClass) {
    super(pairClass, org.apache.avro.mapred.Pair.getPairSchema(keyType.getSchema(),
            nullable(valueType.getSchema())),
        new IndexedRecordToPair(keyType.getInputMapFn(),
        valueType.getInputMapFn()), new PairToAvroPair(keyType, valueType),
        new TupleDeepCopier(Pair.class, keyType, valueType), null, keyType, valueType);
    this.keyType = keyType;
    this.valueType = valueType;
  }
View Full Code Here

  public static final <V1, V2> AvroType<Pair<V1, V2>> pairs(PType<V1> p1, PType<V2> p2) {
    Schema schema = createTupleSchema(p1, p2);
    GenericRecordToTuple input = new GenericRecordToTuple(TupleFactory.PAIR, p1, p2);
    TupleToGenericRecord output = new TupleToGenericRecord(schema, p1, p2);
    return new AvroType(Pair.class, schema, input, output, new TupleDeepCopier(Pair.class, p1, p2), p1, p2);
  }
View Full Code Here

TOP

Related Classes of org.apache.crunch.types.TupleDeepCopier

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.