X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/d084d9ae9f7bcd7f7d1926e7eeae921dbad49273..cea081452750a357baae9edf2764dcd4f3b78ca9:/projects/sgconf/options.h?ds=sidebyside diff --git a/projects/sgconf/options.h b/projects/sgconf/options.h index c00707bf..012b5167 100644 --- a/projects/sgconf/options.h +++ b/projects/sgconf/options.h @@ -18,14 +18,13 @@ * Author : Maxim Mamontov */ -#ifndef __STG_SGCONF_OPTIONS_H__ -#define __STG_SGCONF_OPTIONS_H__ +#pragma once #include #include -#include #include #include +#include #include // size_t namespace SGCONF @@ -39,15 +38,14 @@ class OPTION public: OPTION(const std::string & shortName, const std::string & longName, - ACTION * action, + std::unique_ptr action, const std::string & description); OPTION(const std::string & longName, - ACTION * action, + std::unique_ptr action, const std::string & description); - OPTION(const OPTION & rhs); - ~OPTION(); - OPTION & operator=(const OPTION & rhs); + OPTION(OPTION&& rhs) = default; + OPTION& operator=(OPTION& rhs) = default; void Help(size_t level = 0) const; PARSER_STATE Parse(int argc, char ** argv, void * data); @@ -55,17 +53,16 @@ class OPTION bool Check(const char * arg) const; const std::string & Name() const { return m_longName; } - class ERROR : public std::runtime_error + struct ERROR : std::runtime_error { - public: - ERROR(const std::string & message) - : std::runtime_error(message.c_str()) {} + explicit ERROR(const std::string & message) + : std::runtime_error(message.c_str()) {} }; private: std::string m_shortName; std::string m_longName; - ACTION * m_action; + std::unique_ptr m_action; std::string m_description; }; @@ -73,14 +70,18 @@ class OPTION_BLOCK { public: OPTION_BLOCK() {} - OPTION_BLOCK(const std::string & description) + explicit OPTION_BLOCK(const std::string & description) : m_description(description) {} + + OPTION_BLOCK(OPTION_BLOCK&&) = default; + OPTION_BLOCK& operator=(OPTION_BLOCK&&) = default; + OPTION_BLOCK & Add(const std::string & shortName, const std::string & longName, - ACTION * action, + std::unique_ptr action, const std::string & description); OPTION_BLOCK & Add(const std::string & longName, - ACTION * action, + std::unique_ptr action, const std::string & description); void Help(size_t level) const; @@ -88,11 +89,10 @@ class OPTION_BLOCK PARSER_STATE Parse(int argc, char ** argv, void * data = NULL); void ParseFile(const std::string & filePath); - class ERROR : public std::runtime_error + struct ERROR : std::runtime_error { - public: - ERROR(const std::string & message) - : std::runtime_error(message.c_str()) {} + explicit ERROR(const std::string & message) + : std::runtime_error(message.c_str()) {} }; private: @@ -107,14 +107,12 @@ class OPTION_BLOCKS public: OPTION_BLOCK & Add(const std::string & description) { m_blocks.push_back(OPTION_BLOCK(description)); return m_blocks.back(); } - void Add(const OPTION_BLOCK & block) { m_blocks.push_back(block); } + void Add(OPTION_BLOCK&& block) { m_blocks.push_back(std::move(block)); } void Help(size_t level) const; PARSER_STATE Parse(int argc, char ** argv); private: - std::list m_blocks; + std::vector m_blocks; }; } // namespace SGCONF - -#endif