blob: db3bc402521eb40e72b171b68229fdf5cae443f8 [file] [log] [blame]
/*
* Copyright 2009-2013 by The Regents of the University of California
* Licensed 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 from
*
* 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 edu.uci.ics.asterix.runtime.evaluators.common;
import java.io.DataOutput;
import java.io.IOException;
import edu.uci.ics.asterix.builders.IARecordBuilder;
import edu.uci.ics.asterix.builders.RecordBuilder;
import edu.uci.ics.asterix.common.exceptions.AsterixException;
import edu.uci.ics.asterix.om.types.ARecordType;
import edu.uci.ics.asterix.om.types.ATypeTag;
import edu.uci.ics.hyracks.algebricks.common.exceptions.AlgebricksException;
import edu.uci.ics.hyracks.algebricks.runtime.base.ICopyEvaluator;
import edu.uci.ics.hyracks.algebricks.runtime.base.ICopyEvaluatorFactory;
import edu.uci.ics.hyracks.data.std.api.IDataOutputProvider;
import edu.uci.ics.hyracks.data.std.util.ArrayBackedValueStorage;
import edu.uci.ics.hyracks.dataflow.common.data.accessors.IFrameTupleReference;
public class ClosedRecordConstructorEvalFactory implements ICopyEvaluatorFactory {
private static final long serialVersionUID = 1L;
private ICopyEvaluatorFactory[] args;
private ARecordType recType;
public ClosedRecordConstructorEvalFactory(ICopyEvaluatorFactory[] args, ARecordType recType) {
this.args = args;
this.recType = recType;
}
@Override
public ICopyEvaluator createEvaluator(final IDataOutputProvider output) throws AlgebricksException {
int n = args.length / 2;
ICopyEvaluator[] evalFields = new ICopyEvaluator[n];
ArrayBackedValueStorage fieldValueBuffer = new ArrayBackedValueStorage();
for (int i = 0; i < n; i++) {
evalFields[i] = args[2 * i + 1].createEvaluator(fieldValueBuffer);
}
DataOutput out = output.getDataOutput();
return new ClosedRecordConstructorEval(recType, evalFields, fieldValueBuffer, out);
}
public static class ClosedRecordConstructorEval implements ICopyEvaluator {
private ICopyEvaluator[] evalFields;
private DataOutput out;
private IARecordBuilder recBuilder = new RecordBuilder();
private ARecordType recType;
private ArrayBackedValueStorage fieldValueBuffer = new ArrayBackedValueStorage();
private final static byte SER_NULL_TYPE_TAG = ATypeTag.NULL.serialize();
private boolean first = true;
public ClosedRecordConstructorEval(ARecordType recType, ICopyEvaluator[] evalFields,
ArrayBackedValueStorage fieldValueBuffer, DataOutput out) {
this.evalFields = evalFields;
this.fieldValueBuffer = fieldValueBuffer;
this.out = out;
this.recType = recType;
}
@Override
public void evaluate(IFrameTupleReference tuple) throws AlgebricksException {
try {
if (first) {
first = false;
recBuilder.reset(this.recType);
}
recBuilder.init();
for (int i = 0; i < evalFields.length; i++) {
fieldValueBuffer.reset();
evalFields[i].evaluate(tuple);
if (fieldValueBuffer.getByteArray()[0] != SER_NULL_TYPE_TAG) {
recBuilder.addField(i, fieldValueBuffer);
}
}
recBuilder.write(out, true);
} catch (IOException | AsterixException e) {
throw new AlgebricksException(e);
}
}
}
}