bring up to date

This commit is contained in:
David Renshaw 2014-10-06 21:43:50 -04:00
parent 7adaa91435
commit 25a537c323
12 changed files with 207 additions and 192 deletions

View file

@ -620,7 +620,7 @@ private:
" assert which() == ", scope, "Which.", upperCase, ":\n",
spaces(indent), " \"Must check which() before get()ing a union member.\";\n"),
kj::str(
spaces(indent), " _builder.setShortField(", discrimOffset, ", (short)",
spaces(indent), " _setShortField(", discrimOffset, ", (short)",
scope, "Which.", upperCase, ".ordinal());\n"),
kj::strTree(spaces(indent), "public final boolean is", titleCase, "() {\n",
spaces(indent), " return which() == ", scope, "Which.", upperCase,";\n",
@ -657,7 +657,7 @@ private:
kj::StringTree makeEnumGetter(EnumSchema schema, kj::String member, uint offset, kj::String defaultMaskParam, int indent) {
auto enumerants = schema.getEnumerants();
return kj::strTree(
spaces(indent), "switch(", member, ".getShortField(", offset, defaultMaskParam, ")) {\n",
spaces(indent), "switch(_getShortField(", offset, defaultMaskParam, ")) {\n",
KJ_MAP(e, enumerants) {
return kj::strTree(spaces(indent+1), "case ", e.getOrdinal(), " : return ",
javaFullName(schema), ".",
@ -738,14 +738,16 @@ private:
kj::strTree(
kj::mv(unionDiscrim.readerIsDecl),
spaces(indent), " public ", titleCase, ".Reader get", titleCase, "() {\n",
spaces(indent), " return new ", scope, titleCase, ".Reader(_reader);\n",
spaces(indent), " return new ", scope, titleCase,
".Reader(segment, data, pointers, dataSize, pointerCount, bit0Offset, nestingLimit);\n",
spaces(indent), " }\n",
"\n"),
kj::strTree(
kj::mv(unionDiscrim.builderIsDecl),
spaces(indent), " public final ", titleCase, ".Builder get", titleCase, "() {\n",
spaces(indent), " return new ", scope, titleCase, ".Builder(_builder);\n",
spaces(indent), " return new ", scope, titleCase,
".Builder(segment, data, pointers, dataSize, pointerCount, bit0Offset);\n",
spaces(indent), " }\n",
spaces(indent), " public final ", titleCase, ".Builder init", titleCase, "() {\n",
unionDiscrim.set,
@ -756,16 +758,17 @@ private:
case Section::DATA:
return kj::strTree(
spaces(indent),
" _builder.set", toTitleCase(maskType(slot.whichType)),
" _set", toTitleCase(maskType(slot.whichType)),
"Field(", slot.offset, ",", maskZeroLiteral(slot.whichType),
");\n");
case Section::POINTERS:
return kj::strTree(
spaces(indent), " _builder.getPointerField(", slot.offset, ").clear();\n");
spaces(indent), " _getPointerField(", slot.offset, ").clear();\n");
}
KJ_UNREACHABLE;
},
" return new ", scope, titleCase, ".Builder(_builder);\n",
" return new ", scope, titleCase,
".Builder(segment, data, pointers, dataSize, pointerCount, bit0Offset);\n",
spaces(indent), " }\n",
"\n")
};
@ -896,7 +899,7 @@ private:
kj::str("_reader"), offset, kj::str(defaultMaskParam), indent + 2) :
(typeBody.which() == schema::Type::VOID ?
kj::strTree(spaces(indent), " return org.capnproto.Void.VOID;\n") :
kj::strTree(spaces(indent), " return _reader.get",toTitleCase(type),"Field(", offset, defaultMaskParam, ");\n"))),
kj::strTree(spaces(indent), " return _get",toTitleCase(type),"Field(", offset, defaultMaskParam, ");\n"))),
spaces(indent), " }\n",
"\n"),
@ -909,16 +912,16 @@ private:
kj::str("_builder"), offset, kj::str(defaultMaskParam), indent + 2) :
(typeBody.which() == schema::Type::VOID ?
kj::strTree(spaces(indent), " return org.capnproto.Void.VOID;\n") :
kj::strTree(spaces(indent), " return _builder.get",toTitleCase(type),"Field(", offset, defaultMaskParam, ");\n"))),
kj::strTree(spaces(indent), " return _get",toTitleCase(type),"Field(", offset, defaultMaskParam, ");\n"))),
spaces(indent), " }\n",
spaces(indent), " public final void set", titleCase, "(", type, " value) {\n",
unionDiscrim.set,
(typeBody.which() == schema::Type::ENUM ?
kj::strTree(spaces(indent), " _builder.setShortField(", offset, ", (short)value.ordinal());\n") :
kj::strTree(spaces(indent), " _setShortField(", offset, ", (short)value.ordinal());\n") :
(typeBody.which() == schema::Type::VOID ?
kj::strTree() :
kj::strTree(spaces(indent), " _builder.set",
kj::strTree(spaces(indent), " _set",
toTitleCase(type), "Field(", offset, ", value", defaultMaskParam, ");\n"))),
spaces(indent), " }\n",
"\n")
@ -932,31 +935,31 @@ private:
kj::mv(unionDiscrim.readerIsDecl),
spaces(indent), " public boolean has", titleCase, "() {\n",
unionDiscrim.has,
spaces(indent), " return !_reader.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public org.capnproto.AnyPointer.Reader get", titleCase, "() {\n",
unionDiscrim.check,
spaces(indent), " return new org.capnproto.AnyPointer.Reader(_reader.getPointerField(",
spaces(indent), " return new org.capnproto.AnyPointer.Reader(_getPointerField(",
offset,"));\n",
spaces(indent), " }\n"),
kj::strTree(
kj::mv(unionDiscrim.builderIsDecl),
spaces(indent), " public final boolean has", titleCase, "() {\n",
spaces(indent), " return !_builder.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public org.capnproto.AnyPointer.Builder get", titleCase, "() {\n",
unionDiscrim.check,
spaces(indent), " return new org.capnproto.AnyPointer.Builder(_builder.getPointerField(",
spaces(indent), " return new org.capnproto.AnyPointer.Builder(_getPointerField(",
offset, "));\n",
spaces(indent), " }\n",
spaces(indent), " public org.capnproto.AnyPointer.Builder init", titleCase, "() {\n",
unionDiscrim.set,
spaces(indent), " org.capnproto.AnyPointer.Builder result =\n",
spaces(indent), " new org.capnproto.AnyPointer.Builder(_builder.getPointerField(",
spaces(indent), " new org.capnproto.AnyPointer.Builder(_getPointerField(",
offset, "));\n",
spaces(indent), " result.clear();\n",
spaces(indent), " return result;\n",
@ -973,32 +976,32 @@ private:
kj::strTree(
kj::mv(unionDiscrim.readerIsDecl),
spaces(indent), " public boolean has", titleCase, "() {\n",
spaces(indent), " return !_reader.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public ", type, ".Reader get", titleCase, "() {\n",
unionDiscrim.check,
spaces(indent), " return ", type,
".factory.fromStructReader(_reader.getPointerField(", offset,").getStruct(", defaultParams, "));\n",
spaces(indent), " return ",
"_getPointerField(", offset,").getStruct(", type, ".factory,", defaultParams, ");\n",
spaces(indent), " }\n", "\n"),
kj::strTree(
kj::mv(unionDiscrim.builderIsDecl),
spaces(indent), " public final ", type, ".Builder get", titleCase, "() {\n",
unionDiscrim.check,
spaces(indent), " return ", type,
".factory.fromStructBuilder(_builder.getPointerField(", offset, ").getStruct(",
type, ".STRUCT_SIZE,", defaultParams, "));\n",
spaces(indent), " return ",
"_getPointerField(", offset, ").getStruct(",
type, ".factory,", defaultParams,");\n",
spaces(indent), " }\n",
spaces(indent), " public final void set", titleCase, "(", type, ".Reader value) {\n",
unionDiscrim.set,
spaces(indent), " _builder.getPointerField(", offset, ").setStruct(value._reader);\n",
spaces(indent), " _getPointerField(", offset, ").setStruct(value);\n",
spaces(indent), " }\n",
spaces(indent), " public final ", type, ".Builder init", titleCase, "() {\n",
unionDiscrim.set,
spaces(indent), " return ",
type, ".factory.fromStructBuilder(_builder.getPointerField(", offset, ").initStruct(",
type, ".STRUCT_SIZE", "));\n",
"_getPointerField(", offset, ").initStruct(",
type, ".factory", ");\n",
spaces(indent), " }\n"),
};
@ -1016,12 +1019,12 @@ private:
kj::mv(unionDiscrim.readerIsDecl),
spaces(indent), " public boolean has", titleCase, "() {\n",
unionDiscrim.has,
spaces(indent), " return !_reader.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public ", type, ".Reader",
" get", titleCase, "() {\n",
spaces(indent), " return _reader.getPointerField(",
spaces(indent), " return _getPointerField(",
offset, ").get", blobKind, "(", defaultParams, ");\n",
spaces(indent), " }\n", "\n"),
@ -1029,24 +1032,24 @@ private:
kj::mv(unionDiscrim.builderIsDecl),
spaces(indent), " public final boolean has", titleCase, "() {\n",
unionDiscrim.has,
spaces(indent), " return !_builder.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public final ", type, ".Builder get", titleCase, "() {\n",
spaces(indent), " return _builder.getPointerField(",
spaces(indent), " return _getPointerField(",
offset, ").get", blobKind, "(", defaultParams, ");\n",
spaces(indent), " }\n",
spaces(indent), " public final void set", titleCase, "(", type, ".Reader value) {\n",
unionDiscrim.set,
spaces(indent), " _builder.getPointerField(", offset, ").set", blobKind, "(value);\n",
spaces(indent), " _getPointerField(", offset, ").set", blobKind, "(value);\n",
spaces(indent), " }\n",
spaces(indent), " public final void set", titleCase, "(", setterInputType, " value) {\n",
unionDiscrim.set,
spaces(indent), " _builder.getPointerField(", offset, ").set", blobKind, "( new",
spaces(indent), " _getPointerField(", offset, ").set", blobKind, "( new",
type, ".Reader(value));\n",
spaces(indent), " }\n",
spaces(indent), " public final ", type, ".Builder init", titleCase, "(int size) {\n",
spaces(indent), " return _builder.getPointerField(", offset, ").init", blobKind, "(size);\n",
spaces(indent), " return _getPointerField(", offset, ").init", blobKind, "(size);\n",
spaces(indent), " }\n"),
};
} else if (kind == FieldKind::LIST) {
@ -1063,12 +1066,12 @@ private:
kj::strTree(
kj::mv(unionDiscrim.readerIsDecl),
spaces(indent), " public final boolean has", titleCase, "() {\n",
spaces(indent), " return !_reader.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public final ", readerClass,
" get", titleCase, "() {\n",
spaces(indent), " return (", listFactory, ").fromPointerReader(_reader.getPointerField(", offset, "),",
spaces(indent), " return (", listFactory, ").fromPointerReader(_getPointerField(", offset, "),",
defaultParams, ");\n",
spaces(indent), " }\n",
"\n"),
@ -1076,22 +1079,22 @@ private:
kj::strTree(
kj::mv(unionDiscrim.builderIsDecl),
spaces(indent), " public final boolean has", titleCase, "() {\n",
spaces(indent), " return !_builder.getPointerField(", offset, ").isNull();\n",
spaces(indent), " return !_getPointerField(", offset, ").isNull();\n",
spaces(indent), " }\n",
spaces(indent), " public final ", builderClass,
" get", titleCase, "() {\n",
spaces(indent), " return (", listFactory, ").fromPointerBuilder(_builder.getPointerField(", offset, "),",
spaces(indent), " return (", listFactory, ").fromPointerBuilder(_getPointerField(", offset, "),",
defaultParams, ");\n",
spaces(indent), " }\n",
spaces(indent), " public final void set", titleCase, "(", readerClass, " value) {\n",
spaces(indent), " _builder.getPointerField(", offset, ").setList(value.reader);\n",
spaces(indent), " _getPointerField(", offset, ").setList(value.reader);\n",
spaces(indent), " }\n",
spaces(indent), " public final ", builderClass,
" init", titleCase, "(int size) {\n",
spaces(indent), " return (", listFactory, ").initFromPointerBuilder(_builder.getPointerField(", offset, "), size);\n",
spaces(indent), " return (", listFactory, ").initFromPointerBuilder(_getPointerField(", offset, "), size);\n",
spaces(indent), " }\n"),
};
} else {
@ -1107,14 +1110,14 @@ private:
kj::StringTree inlineMethodDefs;
};
kj::StringTree makeWhich(StructSchema schema, kj::String member, int indent) {
kj::StringTree makeWhich(StructSchema schema, int indent) {
if (schema.getProto().getStruct().getDiscriminantCount() == 0) {
return kj::strTree();
} else {
auto fields = schema.getUnionFields();
return kj::strTree(
spaces(indent), "public Which which() {\n",
spaces(indent+1), "switch(", member, ".getShortField(",
spaces(indent+1), "switch(_getShortField(",
schema.getProto().getStruct().getDiscriminantOffset(), ")) {\n",
KJ_MAP(f, fields) {
return kj::strTree(spaces(indent+2), "case ", f.getProto().getDiscriminantValue(), " : return ",
@ -1133,12 +1136,14 @@ private:
StructSchema schema, kj::Array<kj::StringTree>&& methodDecls,
int indent) {
return kj::strTree(
spaces(indent), "public static final class Reader {\n",
spaces(indent), " public Reader(org.capnproto.StructReader base){ this._reader = base; }\n",
spaces(indent), "public static final class Reader extends org.capnproto.StructReader {\n",
spaces(indent), " public Reader(org.capnproto.SegmentReader segment, int data, int pointers,",
"int dataSize, short pointerCount, byte bit0Offset, int nestingLimit){\n",
spaces(indent), " super(segment, data, pointers, dataSize, pointerCount, bit0Offset, nestingLimit);\n",
spaces(indent), " }\n",
"\n",
makeWhich(schema, kj::str("_reader"), indent+1),
makeWhich(schema, indent+1),
kj::mv(methodDecls),
spaces(indent), " public org.capnproto.StructReader _reader;\n",
spaces(indent), "}\n"
"\n");
}
@ -1147,12 +1152,15 @@ private:
StructSchema schema, kj::Array<kj::StringTree>&& methodDecls,
int indent) {
return kj::strTree(
spaces(indent), "public static final class Builder {\n",
spaces(indent), " public Builder(org.capnproto.StructBuilder base){ this._builder = base; }\n",
spaces(indent), " public org.capnproto.StructBuilder _builder;\n",
makeWhich(schema, kj::str("_builder"), indent+1),
spaces(indent), "public static final class Builder extends org.capnproto.StructBuilder {\n",
spaces(indent), " public Builder(org.capnproto.SegmentBuilder segment, int data, int pointers,",
"int dataSize, short pointerCount, byte bit0Offset){\n",
spaces(indent), " super(segment, data, pointers, dataSize, pointerCount, bit0Offset);\n",
spaces(indent), " }\n",
makeWhich(schema, indent+1),
spaces(indent), " public final Reader asReader() {\n",
spaces(indent), " return new Reader(this._builder.asReader());\n",
spaces(indent), " return new Reader(segment, data, pointers, dataSize, pointerCount, bit0Offset, 0x7fffffff);\n",
//spaces(indent), " return new Reader(this._builder.asReader());\n",
spaces(indent), " }\n",
kj::mv(methodDecls),
spaces(indent), "}\n",
@ -1181,17 +1189,20 @@ private:
spaces(indent), " public static class Factory implements org.capnproto.StructFactory<Builder, Reader> {\n",
spaces(indent),
" public final Reader fromStructReader(org.capnproto.StructReader reader) {\n",
spaces(indent), " return new Reader(reader);\n",
" public final Reader fromStructReader(org.capnproto.SegmentReader segment, int data,",
"int pointers, int dataSize, short pointerCount, byte bit0Offset, int nestingLimit) {\n",
spaces(indent), " return new Reader(segment,data,pointers,dataSize,pointerCount,bit0Offset,nestingLimit);\n",
spaces(indent), " }\n",
spaces(indent), " public final Builder fromStructBuilder(org.capnproto.StructBuilder builder) {\n",
spaces(indent), " return new Builder(builder);\n",
spaces(indent), " public final Builder fromStructBuilder(org.capnproto.SegmentBuilder segment, int data,",
"int pointers, int dataSize, short pointerCount, byte bit0Offset) {\n",
spaces(indent), " return new Builder(segment, data, pointers, dataSize, pointerCount, bit0Offset);\n",
spaces(indent), " }\n",
spaces(indent), " public final org.capnproto.StructSize structSize() {\n",
spaces(indent), " return ", fullName, ".STRUCT_SIZE;\n",
spaces(indent), " }\n",
spaces(indent), " public final Reader asReader(Builder builder) {\n",
spaces(indent), " return new Reader(builder._builder.asReader());\n",
spaces(indent), " throw new Error();\n",
// spaces(indent), " return new Reader(builder._builder.asReader());\n",
spaces(indent), " }\n",
spaces(indent), " }\n",

View file

@ -10,7 +10,7 @@ public final class AnyPointer {
}
public final <T> T getAsStruct(FromStructReader<T> factory) {
return factory.fromStructReader(this.reader.getStruct());
return this.reader.getStruct(factory);
}
public final <T> T getAsList(FromPointerReader<T> factory) {
@ -26,7 +26,7 @@ public final class AnyPointer {
}
public final <T> T initAsStruct(FromStructBuilder<T> factory) {
return factory.fromStructBuilder(this.builder.initStruct(factory.structSize()));
return this.builder.initStruct(factory);
}
public final void clear() {

View file

@ -1,6 +1,7 @@
package org.capnproto;
public interface FromStructBuilder<T> {
T fromStructBuilder(StructBuilder builder);
T fromStructBuilder(SegmentBuilder segment, int data, int pointers, int dataSize,
short pointerCount, byte bit0Offset);
StructSize structSize();
}

View file

@ -1,5 +1,7 @@
package org.capnproto;
public interface FromStructReader<T> {
T fromStructReader(StructReader reader);
T fromStructReader(SegmentReader segment, int data, int pointers,
int dataSize, short pointerCount,
byte bit0Offset, int nestingLimit);
}

View file

@ -85,12 +85,12 @@ public final class ListBuilder {
this.segment.buffer.putDouble(this.ptr + index * 8, value);
}
public final StructBuilder getStructElement(int index) {
public final <T> T getStructElement(FromStructBuilder<T> factory, int index) {
int indexBit = index * this.step;
int structData = this.ptr + indexBit / 8 ;
int structPointers = (structData + (this.structDataSize / 8)) / 8;
return new StructBuilder(this.segment,
return factory.fromStructBuilder(this.segment,
structData,
structPointers,
this.structDataSize,

View file

@ -66,7 +66,7 @@ public final class ListReader {
return this.segment.buffer.getDouble(this.ptr + index * 8);
}
public StructReader getStructElement(int index) {
public <T> T getStructElement(FromStructReader<T> factory, int index) {
// TODO check nesting limit
int indexBit = index * this.step;
@ -74,7 +74,7 @@ public final class ListReader {
int structData = this.ptr + (indexBit / 8);
int structPointers = structData + (this.structDataSize / 8);
return new StructReader(this.segment, structData, structPointers / 8, this.structDataSize,
return factory.fromStructReader(this.segment, structData, structPointers / 8, this.structDataSize,
this.structPointerCount, (byte) (indexBit % 8), this.nestingLimit - 1);
}

View file

@ -17,12 +17,14 @@ public final class PointerBuilder {
return this.segment.buffer.getLong(this.pointer) == 0;
}
public final StructBuilder getStruct(StructSize size) {
return WireHelpers.getWritableStructPointer(this.pointer, this.segment, size, null, 0);
public final <T> T getStruct(FromStructBuilder<T> factory) {
return WireHelpers.getWritableStructPointer(factory, this.pointer, this.segment, factory.structSize(), null, 0);
}
public final StructBuilder getStruct(StructSize size, SegmentReader defaultBuffer, int defaultOffset) {
return WireHelpers.getWritableStructPointer(this.pointer, this.segment, size, defaultBuffer, defaultOffset);
public final <T> T getStruct(FromStructBuilder<T> factory, SegmentReader defaultReader, int defaultOffset) {
return WireHelpers.getWritableStructPointer(factory, this.pointer, this.segment, factory.structSize(),
defaultReader, defaultOffset);
}
public final ListBuilder getList(byte elementSize, SegmentReader defaultBuffer, int defaultOffset) {
@ -60,8 +62,8 @@ public final class PointerBuilder {
defaultSize);
}
public final StructBuilder initStruct(StructSize size) {
return WireHelpers.initStructPointer(this.pointer, this.segment, size);
public final <T> T initStruct(FromStructBuilder<T> factory) {
return WireHelpers.initStructPointer(factory, this.pointer, this.segment, factory.structSize());
}
public final ListBuilder initList(byte elementSize, int elementCount) {

View file

@ -28,15 +28,17 @@ public final class PointerReader {
return this.segment.buffer.getLong(this.pointer) == 0;
}
public StructReader getStruct() {
return WireHelpers.readStructPointer(this.segment,
public <T> T getStruct(FromStructReader<T> factory) {
return WireHelpers.readStructPointer(factory,
this.segment,
this.pointer,
null, 0,
this.nestingLimit);
}
public StructReader getStruct(SegmentReader defaultSegment, int defaultOffset) {
return WireHelpers.readStructPointer(this.segment,
public <T> T getStruct(FromStructReader<T> factory, SegmentReader defaultSegment, int defaultOffset) {
return WireHelpers.readStructPointer(factory,
this.segment,
this.pointer,
defaultSegment, defaultOffset,
this.nestingLimit);

View file

@ -1,12 +1,12 @@
package org.capnproto;
public final class StructBuilder {
final SegmentBuilder segment;
final int data; // byte offset to data section
final int pointers; // word offset of pointer section
final int dataSize; // in bits
final short pointerCount;
final byte bit0Offset;
public class StructBuilder {
protected final SegmentBuilder segment;
protected final int data; // byte offset to data section
protected final int pointers; // word offset of pointer section
protected final int dataSize; // in bits
protected final short pointerCount;
protected final byte bit0Offset;
public StructBuilder(SegmentBuilder segment, int data,
int pointers, int dataSize, short pointerCount,
@ -19,24 +19,17 @@ public final class StructBuilder {
this.bit0Offset = bit0Offset;
}
public final StructReader asReader() {
return new StructReader(this.segment,
this.data, this.pointers, this.dataSize,
this.pointerCount, this.bit0Offset,
0x7fffffff);
}
public final boolean getBooleanField(int offset) {
public final boolean _getBooleanField(int offset) {
int bitOffset = (offset == 0 ? this.bit0Offset : offset);
int position = this.data + (bitOffset / 8);
return (this.segment.buffer.get(position) & (1 << (bitOffset % 8))) != 0;
}
public final boolean getBooleanField(int offset, boolean mask) {
return this.getBooleanField(offset) ^ mask;
return this._getBooleanField(offset) ^ mask;
}
public final void setBooleanField(int offset, boolean value) {
public final void _setBooleanField(int offset, boolean value) {
int bitOffset = offset;
if (offset == 0) { bitOffset = this.bit0Offset; }
byte bitnum = (byte)(bitOffset % 8);
@ -46,111 +39,111 @@ public final class StructBuilder {
(byte)((oldValue & (~(1 << bitnum))) | (( value ? 1 : 0) << bitnum)));
}
public final void setBooleanField(int offset, boolean value, boolean mask) {
this.setBooleanField(offset, value ^ mask);
public final void _setBooleanField(int offset, boolean value, boolean mask) {
this._setBooleanField(offset, value ^ mask);
}
public final byte getByteField(int offset) {
public final byte _getByteField(int offset) {
return this.segment.buffer.get(this.data + offset);
}
public final byte getByteField(int offset, byte mask) {
return (byte)(this.getByteField(offset) ^ mask);
public final byte _getByteField(int offset, byte mask) {
return (byte)(this._getByteField(offset) ^ mask);
}
public final void setByteField(int offset, byte value) {
public final void _setByteField(int offset, byte value) {
this.segment.buffer.put(this.data + offset, value);
}
public final void setByteField(int offset, byte value, byte mask) {
this.setByteField(offset, (byte) (value ^ mask));
public final void _setByteField(int offset, byte value, byte mask) {
this._setByteField(offset, (byte) (value ^ mask));
}
public final short getShortField(int offset) {
public final short _getShortField(int offset) {
return this.segment.buffer.getShort(this.data + offset * 2);
}
public final short getShortField(int offset, short mask) {
return (short)(this.getShortField(offset) ^ mask);
public final short _getShortField(int offset, short mask) {
return (short)(this._getShortField(offset) ^ mask);
}
public final void setShortField(int offset, short value) {
public final void _setShortField(int offset, short value) {
this.segment.buffer.putShort(this.data + offset * 2, value);
}
public final void setShortField(int offset, short value, short mask) {
this.setShortField(offset, (short)(value ^ mask));
public final void _setShortField(int offset, short value, short mask) {
this._setShortField(offset, (short)(value ^ mask));
}
public final int getIntField(int offset) {
public final int _getIntField(int offset) {
return this.segment.buffer.getInt(this.data + offset * 4);
}
public final int getIntField(int offset, int mask) {
return this.getIntField(offset) ^ mask;
public final int _getIntField(int offset, int mask) {
return this._getIntField(offset) ^ mask;
}
public final void setIntField(int offset, int value) {
public final void _setIntField(int offset, int value) {
this.segment.buffer.putInt(this.data + offset * 4, value);
}
public final void setIntField(int offset, int value, int mask) {
this.setIntField(offset, value ^ mask);
public final void _setIntField(int offset, int value, int mask) {
this._setIntField(offset, value ^ mask);
}
public final long getLongField(int offset) {
public final long _getLongField(int offset) {
return this.segment.buffer.getLong(this.data + offset * 8);
}
public final long getLongField(int offset, long mask) {
return this.getLongField(offset) ^ mask;
public final long _getLongField(int offset, long mask) {
return this._getLongField(offset) ^ mask;
}
public final void setLongField(int offset, long value) {
public final void _setLongField(int offset, long value) {
this.segment.buffer.putLong(this.data + offset * 8, value);
}
public final void setLongField(int offset, long value, long mask) {
this.setLongField(offset, value ^ mask);
public final void _setLongField(int offset, long value, long mask) {
this._setLongField(offset, value ^ mask);
}
public final float getFloatField(int offset) {
public final float _getFloatField(int offset) {
return this.segment.buffer.getFloat(this.data + offset * 4);
}
public final float getFloatField(int offset, int mask) {
public final float _getFloatField(int offset, int mask) {
return Float.intBitsToFloat(
this.segment.buffer.getInt(this.data + offset * 4) ^ mask);
}
public final void setFloatField(int offset, float value) {
public final void _setFloatField(int offset, float value) {
this.segment.buffer.putFloat(this.data + offset * 4, value);
}
public final void setFloatField(int offset, float value, int mask) {
public final void _setFloatField(int offset, float value, int mask) {
this.segment.buffer.putInt(this.data + offset * 4,
Float.floatToIntBits(value) ^ mask);
}
public final double getDoubleField(int offset) {
public final double _getDoubleField(int offset) {
return this.segment.buffer.getDouble(this.data + offset * 8);
}
public final double getDoubleField(int offset, long mask) {
public final double _getDoubleField(int offset, long mask) {
return Double.longBitsToDouble(
this.segment.buffer.getLong(this.data + offset * 8) ^ mask);
}
public final void setDoubleField(int offset, double value) {
public final void _setDoubleField(int offset, double value) {
this.segment.buffer.putDouble(this.data + offset * 8, value);
}
public final void setDoubleField(int offset, double value, long mask) {
public final void _setDoubleField(int offset, double value, long mask) {
this.segment.buffer.putLong(this.data + offset * 8,
Double.doubleToLongBits(value) ^ mask);
}
public final PointerBuilder getPointerField(int index) {
public final PointerBuilder _getPointerField(int index) {
return new PointerBuilder(this.segment, this.pointers + index);
}

View file

@ -37,7 +37,7 @@ public final class StructList {
}
public T get(int index) {
return this.factory.fromStructReader(this.reader.getStructElement(index));
return this.reader.getStructElement(factory, index);
}
@ -49,7 +49,7 @@ public final class StructList {
}
public T next() {
return list.factory.fromStructReader(list.reader.getStructElement(idx++));
return list.reader.getStructElement(factory, idx++);
}
public boolean hasNext() {
return idx < list.size();
@ -84,7 +84,7 @@ public final class StructList {
}
public final T get(int index) {
return this.factory.fromStructBuilder(this.builder.getStructElement(index));
return this.builder.getStructElement(factory, index);
}
@ -96,7 +96,7 @@ public final class StructList {
}
public T next() {
return list.factory.fromStructBuilder(list.builder.getStructElement(idx++));
return list.builder.getStructElement(factory, idx++);
}
public boolean hasNext() {
return idx < list.size();

View file

@ -1,13 +1,14 @@
package org.capnproto;
public final class StructReader {
final SegmentReader segment;
final int data; //byte offset to data section
final int pointers; // word offset of pointer section
final int dataSize; // in bits
final short pointerCount;
final byte bit0Offset;
final int nestingLimit;
public class StructReader {
protected final SegmentReader segment;
protected final int data; //byte offset to data section
protected final int pointers; // word offset of pointer section
protected final int dataSize; // in bits
protected final short pointerCount;
protected final byte bit0Offset;
protected final int nestingLimit;
public StructReader() {
this.segment = SegmentReader.EMPTY;
@ -31,7 +32,7 @@ public final class StructReader {
this.nestingLimit = nestingLimit;
}
public final boolean getBooleanField(int offset) {
public final boolean _getBooleanField(int offset) {
// XXX should use unsigned operations
if (offset < this.dataSize) {
if (offset == 0) {
@ -45,11 +46,11 @@ public final class StructReader {
}
}
public final boolean getBooleanField(int offset, boolean mask) {
return this.getBooleanField(offset) ^ mask;
public final boolean _getBooleanField(int offset, boolean mask) {
return this._getBooleanField(offset) ^ mask;
}
public final byte getByteField(int offset) {
public final byte _getByteField(int offset) {
if ((offset + 1) * 8 <= this.dataSize) {
return this.segment.buffer.get(this.data + offset);
} else {
@ -57,11 +58,11 @@ public final class StructReader {
}
}
public final byte getByteField(int offset, byte mask) {
return (byte)(this.getByteField(offset) ^ mask);
public final byte _getByteField(int offset, byte mask) {
return (byte)(this._getByteField(offset) ^ mask);
}
public final short getShortField(int offset) {
public final short _getShortField(int offset) {
if ((offset + 1) * 16 <= this.dataSize) {
return this.segment.buffer.getShort(this.data + offset * 2);
} else {
@ -69,11 +70,11 @@ public final class StructReader {
}
}
public final short getShortField(int offset, short mask) {
return (short)(this.getShortField(offset) ^ mask);
public final short _getShortField(int offset, short mask) {
return (short)(this._getShortField(offset) ^ mask);
}
public final int getIntField(int offset) {
public final int _getIntField(int offset) {
if ((offset + 1) * 32 <= this.dataSize) {
return this.segment.buffer.getInt(this.data + offset * 4);
} else {
@ -81,11 +82,11 @@ public final class StructReader {
}
}
public final int getIntField(int offset, int mask) {
return this.getIntField(offset) ^ mask;
public final int _getIntField(int offset, int mask) {
return this._getIntField(offset) ^ mask;
}
public final long getLongField(int offset) {
public final long _getLongField(int offset) {
if ((offset + 1) * 64 <= this.dataSize) {
return this.segment.buffer.getLong(this.data + offset * 8);
} else {
@ -93,11 +94,11 @@ public final class StructReader {
}
}
public final long getLongField(int offset, long mask) {
return this.getLongField(offset) ^ mask;
public final long _getLongField(int offset, long mask) {
return this._getLongField(offset) ^ mask;
}
public final float getFloatField(int offset) {
public final float _getFloatField(int offset) {
if ((offset + 1) * 32 <= this.dataSize) {
return this.segment.buffer.getFloat(this.data + offset * 4);
} else {
@ -105,7 +106,7 @@ public final class StructReader {
}
}
public final float getFloatField(int offset, int mask) {
public final float _getFloatField(int offset, int mask) {
if ((offset + 1) * 32 <= this.dataSize) {
return Float.intBitsToFloat(this.segment.buffer.getInt(this.data + offset * 4) ^ mask);
} else {
@ -113,7 +114,7 @@ public final class StructReader {
}
}
public final double getDoubleField(int offset) {
public final double _getDoubleField(int offset) {
if ((offset + 1) * 64 <= this.dataSize) {
return this.segment.buffer.getDouble(this.data + offset * 8);
} else {
@ -121,7 +122,7 @@ public final class StructReader {
}
}
public final double getDoubleField(int offset, long mask) {
public final double _getDoubleField(int offset, long mask) {
if ((offset + 1) * 64 <= this.dataSize) {
return Double.longBitsToDouble(this.segment.buffer.getLong(this.data + offset * 8) ^ mask);
} else {
@ -129,7 +130,7 @@ public final class StructReader {
}
}
public final PointerReader getPointerField(int ptrIndex) {
public final PointerReader _getPointerField(int ptrIndex) {
if (ptrIndex < this.pointerCount) {
return new PointerReader(this.segment,
this.pointers + ptrIndex,

View file

@ -145,17 +145,20 @@ final class WireHelpers {
// TODO
}
static StructBuilder initStructPointer(int refOffset,
static <T> T initStructPointer(FromStructBuilder<T> factory,
int refOffset,
SegmentBuilder segment,
StructSize size) {
AllocateResult allocation = allocate(refOffset, segment, size.total(), WirePointer.STRUCT);
StructPointer.setFromStructSize(allocation.segment.buffer, allocation.refOffset, size);
return new StructBuilder(allocation.segment, allocation.ptr * Constants.BYTES_PER_WORD,
return factory.fromStructBuilder(allocation.segment, allocation.ptr * Constants.BYTES_PER_WORD,
allocation.ptr + size.data,
size.data * 64, size.pointers, (byte)0);
}
static StructBuilder getWritableStructPointer(int refOffset,
static <T> T getWritableStructPointer(FromStructBuilder<T> factory,
int refOffset,
SegmentBuilder segment,
StructSize size,
SegmentReader defaultSegment,
@ -164,7 +167,7 @@ final class WireHelpers {
int target = WirePointer.target(refOffset, ref);
if (WirePointer.isNull(ref)) {
if (defaultSegment == null) {
return initStructPointer(refOffset, segment, size);
return initStructPointer(factory, refOffset, segment, size);
} else {
throw new Error("unimplemented");
}
@ -178,7 +181,7 @@ final class WireHelpers {
if (oldDataSize < size.data || oldPointerCount < size.pointers) {
throw new Error("unimplemented");
} else {
return new StructBuilder(resolved.segment, resolved.ptr * Constants.BYTES_PER_WORD,
return factory.fromStructBuilder(resolved.segment, resolved.ptr * Constants.BYTES_PER_WORD,
oldPointerSectionOffset, oldDataSize * Constants.BITS_PER_WORD,
oldPointerCount, (byte)0);
}
@ -417,7 +420,8 @@ final class WireHelpers {
}
static StructReader readStructPointer(SegmentReader segment,
static <T> T readStructPointer(FromStructReader<T> factory,
SegmentReader segment,
int refOffset,
SegmentReader defaultSegment,
int defaultOffset,
@ -425,9 +429,9 @@ final class WireHelpers {
long ref = WirePointer.get(segment.buffer, refOffset);
if (WirePointer.isNull(ref)) {
if (defaultSegment == null) {
return new StructReader();
throw new Error();//return new StructReader();
} else {
return (new PointerReader(defaultSegment, defaultOffset, 0x7fffffff)).getStruct();
return (new PointerReader(defaultSegment, defaultOffset, 0x7fffffff)).getStruct(factory);
}
}
@ -436,7 +440,6 @@ final class WireHelpers {
}
int refTarget = WirePointer.target(refOffset, ref);
FollowFarsResult resolved = followFars(ref, refTarget, segment);
@ -448,7 +451,7 @@ final class WireHelpers {
// TODO "bounds_check" (read limiting)
return new StructReader(resolved.segment,
return factory.fromStructReader(resolved.segment,
resolved.ptr * Constants.BYTES_PER_WORD,
(resolved.ptr + dataSizeWords),
dataSizeWords * Constants.BITS_PER_WORD,