User Defined Command Line Parameters
Background
An OPC UA server may be a rather complex process, as such, developers may well want to provide implementation specific command line options - to allows end-users to control aspects of the server’s runtime behaviour, say specifying additional configuration options outside of the quasar generated configuration file for example. This document describes the means by which a developer can add their own command line options to a server developed using quasar and retrieve the end-user values for those options for treatment in their implementation code.
Boost Program Options
quasar handles command line options using the Boost C++ library, specifically the program_options library subset. To understand this document, some knowledge of the program_options library is required:
Boost’s full program options documentation can be found at boost.org
The program options tutorial could be a good place to start
The remainder of this document assumes sufficient knowledge of the program options library.
Adding the command line options
As is often the case in quasar, user specific implementation code is included in the server by overriding methods. The virtual method to override is
BaseQuasarServer::appendCustomCommandLineOptions(boost::program_options::options_description& commandLineOptions, boost::program_options::positional_options_description& positionalOptionsDescription)
A Simple Example
This example shows how to add the 2 command line options listed below such that a quasar OPC UA server executable, once built, will parse for these options, complete with end-user facing, option specifc, documentation:
some_switch: A simple boolean switch (i.e. without any value; specifying the value at the command line implies TRUE, otherwise FALSE
some_string: A named string value
So, we want to be able to start the server process wit a command line like:
./myServerExecutable [possibly other options here] --some_switch --some_string="hello, world!"
class QuasarServer : ...etc...
{
...etc...
virtual void appendCustomCommandLineOptions(boost::program_options::options_description& commandLineOptions,
boost::program_options::positional_options_description& positionalOptionsDescription);
... etc ... bool m_someSwitch; std::string m_someString; }``
Now add the implementation of the method ‘appendCustomCommandLineOptions’, for example
void QuasarServer::appendCustomCommandLineOptions(boost::program_options::options_description& commandLineOptions, boost::program_options::positional_options_description& positionalOptionsDescription) {
commandLineOptions.add_options() ("some_switch", boost::program_options::bool_switch(&m_someSwitch)->default_value(false), "User documentation of some_switch") ("some_string", boost::program_options::value(&m_someString)->default_value("anyDefaultValue"), "User documentation of some_string"); }
Now, starting the server process with a command line above will result in values
QuasarServer::m_someSwitch = true
QuasarServer::m_someString "hello, world!"
Furthermore, starting the server process with a command line like
./myServerExecutable -help
will print the help documentation described above, at the command line, for example:
...etc...
--some_switch User documentation of some_switch
--some_string arg User documentation of some_string