org.embulk.parser.seqfile.column.AbstractByteWritableColumn Maven / Gradle / Ivy
package org.embulk.parser.seqfile.column;
import org.embulk.parser.seqfile.SequenceFileParserPlugin.ColumnOptionTask;
import org.embulk.parser.seqfile.SequenceFileParserPlugin.PluginTask;
import org.embulk.spi.Column;
import org.embulk.spi.PageBuilder;
import org.embulk.spi.json.JsonLong;
import org.embulk.spi.type.BooleanType;
import org.embulk.spi.type.DoubleType;
import org.embulk.spi.type.JsonType;
import org.embulk.spi.type.LongType;
import org.embulk.spi.type.StringType;
import org.embulk.spi.type.TimestampType;
import org.embulk.spi.type.Type;
public abstract class AbstractByteWritableColumn extends WritableColumn {
@FunctionalInterface
private interface WriteConsumer {
public void write(PageBuilder pageBuilder, Byte value);
}
private final WriteConsumer writer;
public AbstractByteWritableColumn(PluginTask task, Column column, ColumnOptionTask option) {
super(task, column, option);
this.writer = getWriter(column);
}
protected WriteConsumer getWriter(Column column) {
Type type = column.getType();
if (type instanceof BooleanType) {
return this::writeBoolean;
} else if (type instanceof LongType) {
return this::writeLong;
} else if (type instanceof DoubleType) {
return this::writeDouble;
} else if (type instanceof StringType) {
return this::writeString;
} else if (type instanceof TimestampType) {
return this::writeTimestamp;
} else if (type instanceof JsonType) {
return this::writeJson;
} else {
throw new IllegalArgumentException("Column has an unexpected type: " + type);
}
}
protected void writeTo(PageBuilder pageBuilder, Byte value) {
writer.write(pageBuilder, value);
}
protected void writeBoolean(PageBuilder pageBuilder, Byte value) {
if (value == null) {
pageBuilder.setNull(column);
return;
}
pageBuilder.setBoolean(column, value != 0);
}
protected void writeLong(PageBuilder pageBuilder, Byte value) {
if (value == null) {
pageBuilder.setNull(column);
return;
}
pageBuilder.setLong(column, value);
}
protected void writeDouble(PageBuilder pageBuilder, Byte value) {
if (value == null) {
pageBuilder.setNull(column);
return;
}
pageBuilder.setDouble(column, value);
}
protected void writeString(PageBuilder pageBuilder, Byte value) {
if (value == null) {
pageBuilder.setNull(column);
return;
}
String v = Byte.toString(value);
pageBuilder.setString(column, v);
}
protected void writeTimestamp(PageBuilder pageBuilder, Byte value) {
throw new UnsupportedOperationException("byte->timestamp unsupported");
}
protected void writeJson(PageBuilder pageBuilder, Byte value) {
if (value == null) {
pageBuilder.setNull(column);
return;
}
JsonLong v = JsonLong.of(value);
pageBuilder.setJson(column, v);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy