From a2f27293f7b2c6d5c24d4dfb11128da6419df295 Mon Sep 17 00:00:00 2001 From: gereon Date: Sun, 9 Dec 2012 14:57:34 +0100 Subject: [PATCH] adding code samples for Register class --- src/utility/settings.h | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/src/utility/settings.h b/src/utility/settings.h index 10fba3520..49ddda8d9 100644 --- a/src/utility/settings.h +++ b/src/utility/settings.h @@ -189,12 +189,31 @@ namespace settings { /*! * @brief Wrapper class to allow for registering callbacks during * static initialization. + * + * To use this class, use the following includes: + * @code + * #include "src/utility/settings.h" + * #include + * namespace bpo = boost::program_options; + * @endcode */ class Register { public: /*! * @brief Registers given function as register callback. + * + * This constructor registers a callback routine that might add + * new options for the Settings class. It should be used like + * this: + * @code + * void register(bpo::options_description& desc) { + * // do something with desc here + * } + * mrmc::settings::Register reg(mrmc::settings::CB_CLI, ®ister); + * @endcode + * This code should be executed during static initialization, i.e. + * it should be somewhere in the cpp-file. */ Register(const CallbackType type, const RegisterCallback ptr) { @@ -203,6 +222,18 @@ namespace settings { /*! * @brief Registers given function as check callback. + * + * This constructor registers a callback routine that can check + * the option assignment after the Settings class has loaded + * them. It should be used like this: + * @code + * void check(bpo::variables_map& map) { + * // check contents of map + * } + * mrmc::settings::Register reg(&check); + * @endcode + * This code should be executed during static initialization, i.e. + * it should be somewhere in the cpp-file. */ Register(const CheckerCallback ptr) {