blob: 48d82364b7d5025a9e43b4b95fd0c3004d151333 [file] [log] [blame]
package edu.uci.ics.asterix.dataflow.data.nontagged.printers;
import java.io.DataOutput;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.PrintStream;
import edu.uci.ics.asterix.dataflow.data.nontagged.serde.AInt64SerializerDeserializer;
import edu.uci.ics.hyracks.algebricks.common.exceptions.AlgebricksException;
import edu.uci.ics.hyracks.algebricks.data.IPrinter;
import edu.uci.ics.hyracks.algebricks.data.utils.WriteValueTools;
import edu.uci.ics.hyracks.dataflow.common.comm.io.ByteArrayAccessibleOutputStream;
public class AInt64Printer implements IPrinter {
private static final long serialVersionUID = 1L;
private static final String SUFFIX_STRING = "i64";
private static byte[] _suffix;
private static int _suffix_count;
static {
ByteArrayAccessibleOutputStream interm = new ByteArrayAccessibleOutputStream();
DataOutput dout = new DataOutputStream(interm);
try {
dout.writeUTF(SUFFIX_STRING);
} catch (IOException e) {
e.printStackTrace();
}
_suffix = interm.getByteArray();
_suffix_count = interm.size();
}
public static final AInt64Printer INSTANCE = new AInt64Printer();
@Override
public void init() {
}
@Override
public void print(byte[] b, int s, int l, PrintStream ps) throws AlgebricksException {
long d = AInt64SerializerDeserializer.getLong(b, s + 1);
try {
WriteValueTools.writeLong(d, ps);
WriteValueTools.writeUTF8StringNoQuotes(_suffix, 0, _suffix_count, ps);
} catch (IOException e) {
throw new AlgebricksException(e);
}
}
}