Embedding the Ioto Agent
The Ioto agent is provided as a stand-alone program and as a library that can be customized with your code for a more tailored experience.
The Ioto agent can be customized two ways:
- Use the Ioto main() and provide "ioStart" and "ioStop" functions that link to your code.
- Use your own main() and code and link with the Ioto library.
Use the Ioto Main
The first way to integrate Ioto is to use the Ioto main program and provide your own ioStart and ioStop functions. These functions are invoked by Ioto during startup and shutdown. The default versions of these functions are provided by the Ioto library, however if you provide your alternates and link them before libioto.a, your versions will be used instead.
To build with your start/stop functions you need to do the following things:
- Add #include "ioto.h" to the relevant source files.
- Provide an ioStart function to initialize your code and ioStop function to terminate your code. Reference your required code from these functions.
- Add the libioto.a library to the build/link target in your Makefile.
- Build your application.
- Create or edit the Ioto ioto.json5 and other Ioto config files to suit your needs.
Embedding API
The following code demonstrates the Ioto embedding API.
If this source is contained in a file called main.c, you can build this sample and link with the Ioto library:
If you are building on Mac OS, you will need to install openssl and provide a -L /opt/homebrew/lib library directory option.
You can alternatively compile your code and put the object into a static library then rebuild Ioto using the Ioto Makefile. For example:
Provide your own main()
The second way to integrate your code with Ioto is to create your own main program and link with the Ioto library.
This method is desirable if you have more extensive customizations or need to parse custom Ioto command line options that require full control over the main() program.
The Ioto libioto.a library includes a default main() program. If you provide your own main() and link it before the libioto.a, then your main will be used instead.
To build with your own main, you need to do the following things:
- Add #include "ioto.h" to the relevant source files.
- Provide a main().
- Invoke ioInit and ioTerm from your main().
- Build your app and references the libioto.a library.
- Create or edit the Ioto config/ioto.json5 configuration file and other Ioto config files to suit your needs.
The following code demonstrates providing your own main().
If this source is contained in a file called main.c, you can build this sample and link with the Ioto library:
Samples
The link-agent-main sample demonstrates linking with the Ioto library.
The own-main sample demonstrates linking with your own main.
More Details
For more details about the embedding API, please consult the Ioto APIs.