DecodeException
This commit is contained in:
parent
0cd80ae324
commit
ff2116a297
4 changed files with 28 additions and 5 deletions
1
Makefile
1
Makefile
|
@ -2,6 +2,7 @@ CXX=g++ -std=c++11
|
||||||
|
|
||||||
CAPNP_SOURCES=\
|
CAPNP_SOURCES=\
|
||||||
src/capnp/AnyPointer.java\
|
src/capnp/AnyPointer.java\
|
||||||
|
src/capnp/DecodeException.java\
|
||||||
src/capnp/FieldSize.java\
|
src/capnp/FieldSize.java\
|
||||||
src/capnp/FromStructBuilder.java\
|
src/capnp/FromStructBuilder.java\
|
||||||
src/capnp/FromStructReader.java\
|
src/capnp/FromStructReader.java\
|
||||||
|
|
|
@ -15,7 +15,7 @@ public class AddressbookMain {
|
||||||
int size = people.size();
|
int size = people.size();
|
||||||
for(int ii = 0; ii < size; ++ii) {
|
for(int ii = 0; ii < size; ++ii) {
|
||||||
Addressbook.Person.Reader person = people.get(ii);
|
Addressbook.Person.Reader person = people.get(ii);
|
||||||
System.out.println(person.getName().toString() + ": " + person.getEmail().toString());
|
System.out.println(person.getName() + ": " + person.getEmail());
|
||||||
|
|
||||||
StructList.Reader<Addressbook.Person.PhoneNumber.Reader> phones = person.getPhones();
|
StructList.Reader<Addressbook.Person.PhoneNumber.Reader> phones = person.getPhones();
|
||||||
for (int jj = 0; jj < phones.size(); ++jj) {
|
for (int jj = 0; jj < phones.size(); ++jj) {
|
||||||
|
@ -32,7 +32,7 @@ public class AddressbookMain {
|
||||||
typeName = "work";
|
typeName = "work";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
System.out.println(" " + typeName + " phone: " + phone.getNumber().toString());
|
System.out.println(" " + typeName + " phone: " + phone.getNumber());
|
||||||
}
|
}
|
||||||
|
|
||||||
Addressbook.Person.Employment.Reader employment = person.getEmployment();
|
Addressbook.Person.Employment.Reader employment = person.getEmployment();
|
||||||
|
@ -41,10 +41,10 @@ public class AddressbookMain {
|
||||||
System.out.println(" unemployed");
|
System.out.println(" unemployed");
|
||||||
break;
|
break;
|
||||||
case EMPLOYER :
|
case EMPLOYER :
|
||||||
System.out.println(" employer: " + employment.getEmployer().toString());
|
System.out.println(" employer: " + employment.getEmployer());
|
||||||
break;
|
break;
|
||||||
case SCHOOL :
|
case SCHOOL :
|
||||||
System.out.println(" student at: " + employment.getSchool().toString());
|
System.out.println(" student at: " + employment.getSchool());
|
||||||
break;
|
break;
|
||||||
case SELF_EMPLOYED:
|
case SELF_EMPLOYED:
|
||||||
System.out.println(" self-employed");
|
System.out.println(" self-employed");
|
||||||
|
|
7
src/capnp/DecodeException.java
Normal file
7
src/capnp/DecodeException.java
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
package org.capnproto;
|
||||||
|
|
||||||
|
public class DecodeException extends RuntimeException {
|
||||||
|
public DecodeException(String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
|
@ -81,6 +81,21 @@ final class WireHelpers {
|
||||||
int ptrOffset = WirePointer.target(refOffset, ref);
|
int ptrOffset = WirePointer.target(refOffset, ref);
|
||||||
int listPtr = WirePointer.listPointer(ref);
|
int listPtr = WirePointer.listPointer(ref);
|
||||||
int size = ListPointer.elementCount(listPtr);
|
int size = ListPointer.elementCount(listPtr);
|
||||||
return new Text.Reader(segment.buffer, ptrOffset, size);
|
|
||||||
|
if (WirePointer.kind(ref) != WirePointer.LIST) {
|
||||||
|
throw new DecodeException("Message contains non-list pointer where text was expected.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ListPointer.elementSize(listPtr) != FieldSize.BYTE) {
|
||||||
|
throw new DecodeException("Message contains list pointer of non-bytes where text was expected.");
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO bounds check?
|
||||||
|
|
||||||
|
if (size == 0 || segment.buffer.get(8 * ptrOffset + size - 1) != 0) {
|
||||||
|
throw new DecodeException("Message containts text that is not NUL-terminated.");
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Text.Reader(segment.buffer, ptrOffset, size - 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue