In the future any client library may add additional constraint checking when a field is set or modified. This could be inconsistent across client library implementations depending on language features and performance cost.
Idl in corba code#
Generated code for messages is only guaranteed to enforce constraints when a message is published.įor example, there might not be an error when a field constrained to be a fixed size array is assigned an array with the wrong size. TODO: All of this too Constraint Checking How each annotation type is being handled depends on the code generation described below. The syntax for arbitrary annotations is supported. 7.4.1.4.4.5 ArraysĪ multidimensional, fixed-size array is defined by the type of each item and the explicit sizes for each dimension.įor now only a one-dimensional, fixed-size array is supported though. 7.4.1.4.4.4.3 EnumerationsĪn enumerated type consist of an ordered list of enumerators. The sequence is bounded and contain between 0 and N itemsĬonstructed Types 7.4.1.4.4.4.1 StructuresĪ structure is a grouping of at least one member. Sequence of of up to N items of the specified type_spec The sequence is unbounded and no maximum size is specified Sequence of items of the specific type_spec Template Types 7.4.1.4.4.3.1 Sequences IDL type 7.4.1.4.4.2.5 Boolean Type IDL typeħ.4.13.4.5 Explicitly-named Integer Types IDL type The DDS-XTypes specification 1.2 defines it with 16-bit. While the IDL spec only defines the size of wchar as implementation-dependent When used in an array, encode a multi-byte character from a multi-byte code set. The type can store a single-byte character from any byte-oriented code set, or IEEE double-extended floating-point numberĪ 8-bit single-byte character with a numerical value between 0 and 255 (see 7.2.6.2.1) IEEE double-precision floating point number IEEE single-precision floating point number Basic Types 7.4.1.4.4.2.1 Integer Types IDL typeħ.4.1.4.4.2.2 Floating-Point Types IDL type 7.4.1.4.3 Constants 7.4.1.4.4.4.1 StructuresĪ structure must contain at least one member. The second module level distinguishes the type of the interface ( msg, srv,Īction). 7.4.1.4.2 ModulesĮach module must contain at least one definition and they can be nested.įor ROS interfaces the first module level commonly represents the package name, 7.2.6 LiteralsĪll of the following literals are supported:Īt the moment there is no preprocessing happening when reading the `.idl files. 7.2.3 IdentifiersĪn identifier must start with an is an ASCII alphabetic characteran followed by any number of ASCII alphabetic, digit and underscore ( _) characters. Lexical Conventions 7.2.2 Commentsīoth line comments ( //) as well as block comments ( /*. Whatever is not listed below is probably not supported at the moment (e.g. ROS 2 supports a subset of the OMG IDL 4.2 specification. This article identifies a subset of the Interface Definition Language (IDL) that can be used to describe interfaces between components.įurther it describes how the interfaces are used to generate code in C, C++ and Python. This describes defining interfaces using a subset of the Interface Definition Language (IDL).