@lichtblick/cdr
Version:
Common Data Representation serialization and deserialization library
60 lines • 3.48 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.getEncapsulationKindInfo = void 0;
const EncapsulationKind_1 = require("./EncapsulationKind");
// From <https://www.omg.org/spec/DDS-XTypes/1.2/PDF>
// 7.4.2 Extended CDR Representation
/**
* Excerpt:
* PLAIN_CDR2 shall be used for all primitive, strings, and enumerated types. It is also
* used for any type with extensibility kind FINAL. The encoding is similar to
* PLAIN_CDR except that INT64, UINT64, FLOAT64, and FLOAT128 are serialized into
* the CDR buffer at offsets that are aligned to 4 rather than 8 as was the case in
* PLAIN_CDR.
*
* DELIMITED_CDR shall be used for types with extensibility kind APPENDABLE. It
* serializes a UINT32 delimiter header (DHEADER) before serializing the object using
* PLAIN_CDR2. The delimiter encodes the endianness and the length of the serialized
* object that follows.
*
* PL_CDR2 shall be used for aggregated types with extensibility kind MUTABLE.
* Similar to DELIMITED_CDR it also serializes a DHEADER before serializing the
* object. In addition it serializes a member header (EMHEADER) ahead each serialized
* member. The member header encodes the member ID, the must-understand flag, and
* length of the serialized member that follows.
*/
/**
* Extracts information about the serialization behavior of an EncapsulationKind. Such as whether it's CDR2, little-endian, uses a delimiter header or uses a member header.
* @param kind - EncapsulationKind to extract information from
* @returns {Object} - Object containing boolean values that describe the serialization behavior of the EncapsulationKind
*/
const getEncapsulationKindInfo = (kind) => {
const isCDR2 = kind > EncapsulationKind_1.EncapsulationKind.PL_CDR_LE;
const littleEndian = kind === EncapsulationKind_1.EncapsulationKind.CDR_LE ||
kind === EncapsulationKind_1.EncapsulationKind.PL_CDR_LE ||
kind === EncapsulationKind_1.EncapsulationKind.CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.PL_CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.DELIMITED_CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_PL_CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_DELIMITED_CDR2_LE;
const isDelimitedCDR2 = kind === EncapsulationKind_1.EncapsulationKind.DELIMITED_CDR2_BE ||
kind === EncapsulationKind_1.EncapsulationKind.DELIMITED_CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_DELIMITED_CDR2_BE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_DELIMITED_CDR2_LE;
const isPLCDR2 = kind === EncapsulationKind_1.EncapsulationKind.PL_CDR2_BE ||
kind === EncapsulationKind_1.EncapsulationKind.PL_CDR2_LE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_PL_CDR2_BE ||
kind === EncapsulationKind_1.EncapsulationKind.RTPS_PL_CDR2_LE;
const isPLCDR1 = kind === EncapsulationKind_1.EncapsulationKind.PL_CDR_BE || kind === EncapsulationKind_1.EncapsulationKind.PL_CDR_LE;
const usesDelimiterHeader = isDelimitedCDR2 || isPLCDR2;
const usesMemberHeader = isPLCDR2 || isPLCDR1;
return {
isCDR2,
littleEndian,
usesDelimiterHeader,
usesMemberHeader,
};
};
exports.getEncapsulationKindInfo = getEncapsulationKindInfo;
//# sourceMappingURL=getEncapsulationKindInfo.js.map