package edu.washington.escience.myria.column;
import java.nio.ByteBuffer;
import javax.annotation.Nonnull;
import com.google.common.base.Preconditions;
import edu.washington.escience.myria.Type;
public class BlobColumn extends Column<ByteBuffer> {
/** Required for Java serialization. */
private static final long serialVersionUID = 1;
/** Internal representation of the column data. */
private final ByteBuffer[] data;
/** The number of existing rows in this column. */
private final int position;
/**
* Blob column for binary data.
* @param data in form of byteBuffer
* @param numData
*/
public BlobColumn(final ByteBuffer[] data, final int numData) {
this.data = data;
position = numData;
}
@Override
public ByteBuffer getBlob(final int row) {
Preconditions.checkElementIndex(row, position);
return data[row];
}
@Override
public @Nonnull ByteBuffer getObject(final int row) {
return data[row];
}
@Override
public Type getType() {
return Type.BLOB_TYPE;
}
@Override
public int size() {
return position;
}
}