Creating New Message Definitions
Msg File Location
The preferred message definition uses only C code to define a struct
which contains the message data. This is written in a stand-alone *.h
file located in the src/architecture/msgPayloadDefC
folder.
If the message struct
definition needs to include C++ code, then the stand-alone message definition file is stored in src/architecture/msgPayloadDefCpp
folder.
The *.h
file name need to be upper camel case (start with a capital letter) and end with ...MsgPayload.h
. An example is SomeMsgPayload.h
.
Msg Data Definition
The message data is defined through a struct
definition. For example, assume the new message is to be of type SomeMsg
:
#ifndef SOME_MSG_H
#define SOME_MSG_H
/*! @brief Brief description of what this message contains */
typedef struct {
int variable1; //!< [units] variable description
double variable2[3]; //!< [units] variable description
}SomeMsgPayload;
#endif
The #ifndef
statement ensures this header file is only included once when compiling. The struct
definition needs to have the message type name followed by MsgPayload
. In this case it is SomeMsgPayload
. The msg payload is the data of the message. This is in contrasts to the message object which contains a copy of this message payload, as well as a message header.
Creating the Msg C/C++ Swig Interface Files
To create message objects in C and C++ modules, you need to run python3 conanfile.py
again from in the Terminal or command line window. This script auto-creates the corresponding C module interface files and stores them in basilisk/dist3/autoSource/cMsgCInterface
. The C++ message objects are automatically created as a template class using the *.h
definitions in msgPayloadDefC
. Naturally no C module interface files are created for *.h
files in msgPayloadDefCpp
.
Running python3 conanfile.py
re-creates the IDE project file that will now include access to the new message definition.
Caution
Compiled message objects (built by python3 conanfile.py
) are added to the installed Basilisk package, such that they can be imported from Python. If you rename or delete a message’s *Payload.h
file, you should run a “clean” build to delete its previously compiled message objects, to avoid accidentally importing and using an old message type that should no longer exist.
“Clean” builds can be done by deleting the dist3
directory, or by running python3 conanfile.py --clean
.
For the Basilisk module to have python interfaces to the module messages, you must include the message definition
...MsgPayload.h
file in the module swig interface file *.i
. See Swig Interface File for an example
on how to do this in a C++ module, and Swig Interface File on how to do this for a C module.