com.javanut.pronghorn.util.field.BytesFieldConsumer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pronghorn-pipes Show documentation
Show all versions of pronghorn-pipes Show documentation
Ring buffer based queuing utility for applications that require high performance and/or a small
footprint. Well suited for embedded and stream based processing.
package com.javanut.pronghorn.util.field;
import com.javanut.pronghorn.pipe.Pipe;
import com.javanut.pronghorn.pipe.PipeConfig;
import com.javanut.pronghorn.pipe.RawDataSchema;
public class BytesFieldConsumer implements FieldConsumer {
private BytesFieldProcessor processor;
private byte[] backing;
private int position;
private int length;
private int mask;
private byte primaryRingSizeInBits = 7; //this ring is 2^7 eg 128
private byte byteRingSizeInBits = 16;
private Pipe pipe = new Pipe(new PipeConfig(RawDataSchema.instance, primaryRingSizeInBits, byteRingSizeInBits));
public BytesFieldConsumer(BytesFieldProcessor processor) {
this.processor = processor;
this.pipe.initBuffers();
Pipe.validateVarLength(pipe, 10);
}
public void store(long value) {
int size = Pipe.addMsgIdx(pipe, RawDataSchema.MSG_CHUNKEDSTREAM_1);
Pipe.addLongAsASCII(pipe, value);
Pipe.confirmLowLevelWrite(pipe, size);
Pipe.publishWrites(pipe);
extractBytes();
}
public void store(byte[] backing, int pos, int len, int mask) {
this.backing = backing;
this.position = pos;
this.length = len;
this.mask = mask;
}
public void store(byte e, long m) {
int size = Pipe.addMsgIdx(pipe, RawDataSchema.MSG_CHUNKEDSTREAM_1);
Pipe.addDecimalAsASCII(e, m, pipe);
Pipe.confirmLowLevelWrite(pipe, size);
Pipe.publishWrites(pipe);
extractBytes();
}
public void store(long numerator, long denominator) {
int size = Pipe.addMsgIdx(pipe, RawDataSchema.MSG_CHUNKEDSTREAM_1);
Pipe.addRationalAsASCII(pipe, numerator, denominator);
Pipe.confirmLowLevelWrite(pipe, size);
Pipe.publishWrites(pipe);
extractBytes();
}
private void extractBytes() {
Pipe.takeMsgIdx(pipe);
int meta = Pipe.takeByteArrayMetaData(pipe);
length = Pipe.takeByteArrayLength(pipe);
backing = Pipe.byteBackingArray(meta, pipe);
mask = Pipe.blobMask(pipe);
position = Pipe.bytePosition(meta, pipe, length);
Pipe.confirmLowLevelWrite(pipe);
Pipe.publishWrites(pipe);
}
public boolean run() {
return processor.process(backing, position, length, mask);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy