in protonj2/src/main/java/org/apache/qpid/protonj2/codec/decoders/transport/DispositionTypeDecoder.java [163:220]
private Disposition readDisposition(InputStream stream, StreamDecoder decoder, StreamDecoderState state, ListTypeDecoder listDecoder) throws DecodeException {
final Disposition disposition = new Disposition();
@SuppressWarnings("unused")
final int size = listDecoder.readSize(stream, state);
final int count = listDecoder.readCount(stream, state);
if (count < MIN_DISPOSITION_LIST_ENTRIES) {
throw new DecodeException(errorForMissingRequiredFields(count));
}
if (count > MAX_DISPOSITION_LIST_ENTRIES) {
throw new DecodeException("To many entries in Disposition list encoding: " + count);
}
for (int index = 0; index < count; ++index) {
// If the stream allows we peek ahead and see if there is a null in the next slot,
// if so we don't call the setter for that entry to ensure the returned type reflects
// the encoded state in the modification entry.
if (stream.markSupported()) {
stream.mark(1);
final boolean nullValue = ProtonStreamUtils.readByte(stream) == EncodingCodes.NULL;
if (nullValue) {
// Ensure mandatory fields are set
if (index < MIN_DISPOSITION_LIST_ENTRIES) {
throw new DecodeException(errorForMissingRequiredFields(index));
}
continue;
} else {
ProtonStreamUtils.reset(stream);
}
}
switch (index) {
case 0:
disposition.setRole(decoder.readBoolean(stream, state, false) ? Role.RECEIVER : Role.SENDER);
break;
case 1:
disposition.setFirst(decoder.readUnsignedInteger(stream, state, 0l));
break;
case 2:
disposition.setLast(decoder.readUnsignedInteger(stream, state, 0l));
break;
case 3:
disposition.setSettled(decoder.readBoolean(stream, state, false));
break;
case 4:
disposition.setState(decoder.readObject(stream, state, DeliveryState.class));
break;
case 5:
disposition.setBatchable(decoder.readBoolean(stream, state, false));
break;
}
}
return disposition;
}