public final class PriceInHundredthsOfUnits extends AbstractLazyEncodedByteArray implements FastSerializable
The API offered by this class is as if the type were specified in ASN.1 as follows.
PriceInHundredthsOfUnits ::= SEQUENCE { price INTEGER }The class takes care of encoding the field value into a byte-array and decoding the field value from a byte-array, the encoded representation being as tabulated below.
Data Encoding - based on comment in ASN.1 module CAP-datatypes | ||||||||
---|---|---|---|---|---|---|---|---|
8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | |
Octet 0 | Tens of thousands | Hundreds of thousands | ||||||
Octet 1 | Hundreds | Thousands | ||||||
Octet 2 | Units | Tens | ||||||
Octet 3 | Hundredths | Tenths |
StringCodec
,
the encoding to semi-octets is as tabulated below.
Decoded character | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | ||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Encoded hexadecimal | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
isDecoded
encoded
FIELD_ABSENT, FIELD_UNINITIALISED
Constructor and Description |
---|
PriceInHundredthsOfUnits()
Constructs a new PriceInHundredthsOfUnits object with no fields set.
|
PriceInHundredthsOfUnits(byte[] data)
Constructs a new PriceInHundredthsOfUnits object from network-encoded data.
|
PriceInHundredthsOfUnits(byte[] data,
int start,
int len)
Constructs a new PriceInHundredthsOfUnits object from part of network-encoded data.
|
PriceInHundredthsOfUnits(DataInput in)
Constructs a new PriceInHundredthsOfUnits object from data deserialized from a stream that was written by
toStream(DataOutput) . |
PriceInHundredthsOfUnits(int price)
Constructs a new PriceInHundredthsOfUnits object from given values for all fields.
|
Modifier and Type | Method and Description |
---|---|
void |
checkFieldsSet()
Checks that all mandatory fields are present.
|
PriceInHundredthsOfUnits |
clone()
Constructs a copy of this object and everything reachable from it.
|
static PriceInHundredthsOfUnits |
copyOf(PriceInHundredthsOfUnits from)
Creates a new object of this type, cloning the values of common fields from the given object of any subclass of the same base type.
|
protected void |
decode()
Computes the decoded form from the encoded form.
|
protected void |
encode()
Computes the encoded form from the decoded form.
|
protected boolean |
encodedIsInvalid()
Determines whether the encoded form is invalid.
|
static int |
getContainedLength(byte[] data,
int start,
int len)
Determines the length of the encoded value that commences at offset
start in the given data . |
byte[] |
getEncodedForm()
Gets the encoded form.
|
static FieldAccessor[] |
getFieldAccessors()
Gets a new array of the accessors for fields of this type.
|
Map<String,Object> |
getFieldsMap(boolean withAbsents)
Gets a Map from field-name to field-value for the fields of a sequence.
|
int |
getPrice()
Gets the value of the price as integer number of hundredths.
|
BigDecimal |
getPriceAsBigDecimal()
Gets the value of the field Price as a BigDecimal.
|
String |
getPriceAsString()
Gets the value of the field Price as a String.
|
boolean |
hasPrice()
Tests whether the field Price has a value.
|
PriceInHundredthsOfUnits |
setPrice(int value)
Sets the value of the price as integer number of hundredths.
|
PriceInHundredthsOfUnits |
setPriceAsBigDecimal(BigDecimal value)
Sets the value of the field Price as a BigDecimal.
|
PriceInHundredthsOfUnits |
setPriceAsString(String value)
Sets the value of the field Price as a String.
|
PriceInHundredthsOfUnits |
setPricePresent(boolean flag)
Sets the presence or absence of the field Price.
|
void |
toStream(DataOutput out)
Serializes this object to a stream in a form suitable for reading by
PriceInHundredthsOfUnits(DataInput) . |
checkDecode, checkModifyAndDecode
equals, hashCode, toString
checkModify, isReadOnly, setReadOnly
public PriceInHundredthsOfUnits()
public PriceInHundredthsOfUnits(byte[] data)
data
- network-encoded dataNullPointerException
- if data is nullpublic PriceInHundredthsOfUnits(byte[] data, int start, int len)
start
and is len
bytes long.
The data is not decoded and might not be decodable.data
- network-encoded datastart
- starting offset of network-encoded data in byte arraylen
- default length if not predictableNullPointerException
- if data is nullIllegalArgumentException
- if len is negativepublic PriceInHundredthsOfUnits(int price)
price
- the price as integer number of hundredthspublic PriceInHundredthsOfUnits(DataInput in) throws IOException
toStream(DataOutput)
.in
- the stream to read fromEOFException
- if reading is pre-empted by end-of-fileIOException
- if the data cannot be readpublic void toStream(DataOutput out) throws IOException
PriceInHundredthsOfUnits(DataInput)
.toStream
in interface FastSerializable
out
- the stream to write toIOException
- if an I/O error occurspublic boolean hasPrice() throws DecodeException
DecodeException
- if encoded state cannot be decodedpublic PriceInHundredthsOfUnits setPricePresent(boolean flag) throws IllegalStateException
flag
- whether the field should be marked as presentIllegalStateException
- if this instance has been marked as read-onlypublic void checkFieldsSet() throws EncodeException
checkFieldsSet
in class AbstractLazyEncodedDataObject<byte[]>
EncodeException
- if any mandatory field is not presentpublic int getPrice() throws DecodeException
DecodeException
- if encoded state cannot be decodedpublic PriceInHundredthsOfUnits setPrice(int value) throws IllegalStateException
value
- int representation of the price as integer number of hundredthsIllegalStateException
public static PriceInHundredthsOfUnits copyOf(PriceInHundredthsOfUnits from)
from
- the object from which to copypublic PriceInHundredthsOfUnits clone()
clone
in interface DataObject
clone
in class AbstractDataObject
public static FieldAccessor[] getFieldAccessors()
public Map<String,Object> getFieldsMap(boolean withAbsents)
getFieldsMap
in class AbstractFieldsObject
withAbsents
- whether to put absent optional fields into Mapprotected boolean encodedIsInvalid()
public byte[] getEncodedForm() throws EncodeException
EncodeException
- if encoding failspublic static int getContainedLength(byte[] data, int start, int len)
start
in the given data
.
The value is not fully decoded and might not be decodable.
Values of this type are of a fixed length, so that length
is returned if the data is long enough, otherwise 0 is returned.data
- network-encoded datastart
- index into data where value commenceslen
- length in data to be consideredprotected void encode() throws EncodeException
encode
in class AbstractLazyEncodedDataObject<byte[]>
EncodeException
- if Price is not in range [0,99999999]protected void decode() throws DecodeException
decode
in class AbstractLazyEncodedDataObject<byte[]>
DecodeException
- if not 4 octets to be decodedpublic String getPriceAsString()
public BigDecimal getPriceAsBigDecimal()
public PriceInHundredthsOfUnits setPriceAsBigDecimal(BigDecimal value)
value
- the new value for the field in hundredthspublic PriceInHundredthsOfUnits setPriceAsString(String value) throws EncodeException
value
- the new value for the field in hundredthsEncodeException