Merge pull request #80 from Douwanna/release/2.4

Update notes
This commit is contained in:
FrankLee 2020-05-24 09:45:30 +08:00 committed by GitHub
commit f06b140b73
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -29,26 +29,31 @@ namespace tars
/**
* @file tc_config.h
* @brief .
* @brief Config File Reading Class
*/
/////////////////////////////////////////////////
/**
*
* Field Separator
*/
const char TC_CONFIG_DOMAIN_SEP = '/';
/**
*
* Parameter Start Character
*/
const char TC_CONFIG_PARAM_BEGIN = '<';
/**
*
* Parameter Ender Character
*/
const char TC_CONFIG_PARAM_END = '>';
/**
* @brief .
* @brief Config File Exception Class
*/
struct TC_Config_Exception : public TC_Exception
{
@ -59,6 +64,7 @@ struct TC_Config_Exception : public TC_Exception
/**
* @brief
* @brief No Config File Error
*/
struct TC_ConfigNoParam_Exception : public TC_Exception
{
@ -69,6 +75,7 @@ struct TC_ConfigNoParam_Exception : public TC_Exception
/**
* @brief .
* @brief Class that defines the domain in the configuration file
*/
class TC_ConfigDomain
{
@ -77,27 +84,34 @@ public:
/**
* @brief .
* @brief Constructor
*
* @param sLine
* @param sLine Refers to a line in the configuration file, read by line
*/
TC_ConfigDomain(const string &sLine);
/**
* @brief .
* @brief Destructor
*/
~TC_ConfigDomain();
/**
* @brief .
* @brief Copy
*
* @param tcd TC_ConfigDomain对象
* @param tcd a TC_ConfigDomain object, refers to a domain of the configuration file
*/
TC_ConfigDomain(const TC_ConfigDomain &tcd);
/**
* @brief .
* @brief Assignment
*
* @param tcd TC_ConfigDomain对象
* @param tcd a TC_ConfigDomain object, refers to a domain of the configuration file
*/
TC_ConfigDomain& operator=(const TC_ConfigDomain &tcd);
@ -110,42 +124,63 @@ public:
/**
* @brief domain
* @brief Parse a domain
* "/Main/Domain<Name>"path进行解析
* DomainPath _domains和路径中对应的配置项_param.
*
* Parsing a path like'/Main/Domain<Name>'results in a DomainPath type,
* including the path'_domains' and the corresponding configuration item in the path '_param'
*
* @param path
* @param path A processed string must meet certain requirements
* @param bWithParam "/Main/Domain<Name>"bWithParam为ture
* "/Main/Domain"bWithParam为false
* @param bWithParam bool: true, when'/Main/Domain<Name>';
* false, when'/Main/Domain'
* @return DomainPath DomainPath对象
* @return DomainPath A DomainPath object that resolves domain names and parameters in a domain
*/
static DomainPath parseDomainName(const string& path, bool bWithParam);
/**
* @brief
* @brief Add Subdomain Name
* name是子域的名字"/Main/Domain"
* name为subDomain的子域,"/Main/Domain/subDomain"
* Add a subdomain, and 'name' is its name, such as "/Main/Domain"
* Add an other subdomain which named 'subDomain', such as "/Main/Domain/subDomain"
*
*
* @param name
* @param name subdomain name
* @return TC_ConfigDomain*
* @return TC_ConfigDomain* the pointer which points to the subdomain
* @throws TC_Config_Exception
*/
TC_ConfigDomain* addSubDomain(const string& name);
/**
* @brief Sub Domain.
* @brief Recursive search subdomain Sub Domain.
*
* @param itBegin _domains的顶部
* @param itBegin iterator, point to the button of the _domain
* @param itEnd _domains的底部
* @param itBegin iterator, point to the button of the _domain
* @return TC_ConfigDomain*
* @return TC_ConfigDomain* a point point to the target subdomain
*/
TC_ConfigDomain *getSubTcConfigDomain(vector<string>::const_iterator itBegin, vector<string>::const_iterator itEnd);
const TC_ConfigDomain *getSubTcConfigDomain(vector<string>::const_iterator itBegin, vector<string>::const_iterator itEnd) const;
/**
* @brief Get Param Value /.
* @brief Get Param Value Get parameter/value pairs.
*
* @param sName
* @param sName Configuration Item Name
* @return
* @return the value of the configration item
*/
string getParamValue(const string &sName) const;
@ -153,7 +188,10 @@ public:
* @brief Get Param Map map
* map是参数/,
* eg. SyncThreadNum = 2
* Map is a parameter/value pair, a key-value pair corresponding to the value of the configuration item and the configuration item,
* eg. SyncThreadNum = 2
* @return map
* @return a map of parameters and their corresponding values in a domain
*/
const map<string, string>& getParamMap() const { return _param; }
@ -168,12 +206,14 @@ public:
* @brief Set Param Value /.
*
* @param sLine
* @param sLine line
* @return
*/
void setParamValue(const string &sLine);
/**
* @brief key里没有的配置项添加到最后
* @brief Insert a parameter to add a configuration item that is not in the key to the last
*
* @param map
*/
@ -183,53 +223,68 @@ public:
* @brief Destroy .
*
* @return
* @return void
*/
void destroy();
/**
* @brief Get Name
* @brief Get Name Get Domain Name
* @return
* @return the domain name
*/
string getName() const;
/**
* @brief
* @brief Set Domain Name
*
* @param
* @param name domain name
*/
void setName(const string& name);
/**
* @brief key
* @brief Get keys in the order they appear in the file
*
* @return vector<string>key的vector
* @return the vector which stores keys in vector<string>
*/
vector<string> getKey() const;
/**
* @brief line
* @brief Get 'line' in the order they appear in the file
*
* @return vector<string>key的vector
* @return the vector which stores keys in vector<string>
*/
vector<string> getLine() const;
/**
* @brief Domain
* @brief Get subdomains in the order they appear in the file
*
* @return vector<string>vector
* @return the vector which stores keys in vector<string>
*/
vector<string> getSubDomain() const;
/**
* @brief .
* @brief Convert to the string format of the configuration file.
*
* @param i tab的层数
* @param i number of layers of 'tab'
* @return string类型配置字符串
* @return string type configuration string
*/
string tostr(int i) const;
/**
* @brief .
* @brief Clone.
*
* @return TC_ConfigDomain*
*/
@ -240,6 +295,7 @@ public:
/**
* @brief .
* @brief Escape.
*
* @param name
* @return string
@ -248,6 +304,7 @@ public:
/**
* @brief .
* @brief Direction escaping
*
* @param s
* @return string
@ -256,10 +313,14 @@ public:
/**
* @brief /
* @brief Set param/key pairs
*
* @param sName
* @param sName the name of the configuration item
* @param sValue
* @param sValue the value of the configuration item
* @return
* @return void
*/
void setParamValue(const string &sName, const string &sValue);
@ -267,51 +328,66 @@ protected:
/**
*
* Domain Name
*/
string _name;
/**
* name/value对
* name/value pair, the name and value of the configuration item
*/
map<string, string> _param;
/**
* key也就是配置项的插入顺序
* key, the insertion order of configuration items
*/
vector<string> _key;
/**
*
* Subdomain
*/
map<string, TC_ConfigDomain*> _subdomain;
/**
*
* the insertion order of the domain
*/
vector<string> _domain;
/**
*
* Configuration list for the whole row
*/
vector<string> _line;
};
/**
* @brief wbl模式.
* @brief Define the class of the profile (compatible with WBL mode).
* string中解析配置文件
* Support parsing configuration files from strings;
*
* Support the generation of configuration files;
*
* Parse error and throw exception;
* []
* Use [] to get the configuration and throw an exception if there is no configuration;
* get获取配置
* Use 'get' to get the configuration, and return null if it doesn't exist
* 线insert域等函数非线程安全
* Reading configuration files is thread-safe, functions such as insert fields are not thread-safe;
*
* For example:
* <Main>
* <Domain>
@ -323,8 +399,11 @@ protected:
* </Main>
* :conf["/Main/Domain<Name>"] Map:
* Get parameter: conf ["/Main/Domain<Name>"] Get domain Map:
* getDomainMap("/Main/Domain", m); m得到Name/Value对
* getDomainMap("/Main/Domain", m); 'm' can get the Name/Value pair
* Vector: getDomainVector("/Main", v); v得到Domain列表
* Get Domain Vector: getDomainVector ('/Main', v); 'v' can get a list of Domains to increase the number of the value pairs under the domain or domain
*/
class TC_Config
@ -333,11 +412,13 @@ public:
/**
* @brief
* @brief Constructor
*/
TC_Config();
/**
* @brief .
* @brief Copy
*
* @param tc为TC_Config类型
*/
@ -345,6 +426,7 @@ public:
/**
* @brief .
* @brief Assignment
*
* @param tcd
* @return TC_Config&
@ -353,18 +435,24 @@ public:
/**
* @brief .
* @brief Parse the file.
*
* fileName对应的文件转化为输入流后调用parse对其进行解析
* Convert the file corresponding to fileName into an input stream and call parse to parse it.
* @param sFileName :
* @param sFileName file name
* @return
* @return void
* @throws TC_Config_Exception
*/
void parseFile(const string& sFileName);
/**
* @brief .
* @brief Parse string
*
* string parse对其进行解析
* Convert string type to input stream and call parse to parse it
* @return void
* @throws TC_Config_Exception
*/
@ -373,8 +461,12 @@ public:
/**
* @brief ,
* /Main/Domain<Param>/Main/Domain下的配置项名字为Param的值
* @brief Get value.
* If no exception is thrown, for strings of which type like /Main/Domain<Param>, get the value of the configuration item named 'Param' under the domain '/Main/Domain'
* @param sName ,: /Main/Domain<Param>
* @param sName param name, like: /Main/Domain<Param>
* @return
* @return the value of the configuration file
* @throws TC_Config_Exception
*/
string operator[](const string &sName) const;
@ -382,82 +474,119 @@ public:
/**
* @brief , ,.
* /Main/Domain<Param>/Main/Domain下的配置项名字为Param的值
* @brief Get value. Note that if no exception is thrown, an empty string is returned.
* For strings of type like'/main/domain<param>', get the value of the configuration item named 'Param' under the domain '/Main/Domain'
* @param sName , : /Main/Domain<Param>
* @param sName param name, like: /Main/Domain<Param>
* @return
* @return the value of the configuration file
*/
string get(const string &sName, const string &sDefault="") const;
/**
* @brief .
* @brief Set Value
* @param sName , : /Main/Domain<Param>
* @param sName param name, like: /Main/Domain<Param>
*/
void set(const string &sName, const string &value);
/**
* @brief GetDomainParamMap获取域下面的参数值对.
* @brief GetDomainParamMap Get the parameter-value pair under the domain
*
* @param path , , : /Main/Domain
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @param m map<string, string>map列表
* @param m map<string, string> type, the map list in the domain
* @return bool,
* @return bool, return the parameter-value pair under the domain
*/
bool getDomainMap(const string &path, map<string, string> &m) const;
/**
* @brief ,map.
* @brief Get the parameter value pair under the domain. If it is not saved, an empty map will be returned.
*
* @param path , , : /Main/Domain
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @return map<string,string>,
* @return bool, return the parameter-value pair under the domain
*/
map<string, string> getDomainMap(const string &path) const;
/**
* @brief key,
* @brief Get all the keys under the domain and return them in line order
* @param path , , : /Main/Domain
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @return vector<string>key
* @return vector<string>All keys under a certain ID
*/
vector<string> getDomainKey(const string &path) const;
/**
* @brief ,
* getDomainKey只能获取到key,"="
* @brief Get all non domain lines under the domain, and return them in line order of the file
* The difference is that this interface getDomainKey, which can only get the key, also returns the whole line for the configuration with "=".
* @param path , , : /Main/Domain
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @return vector<string>
* @return vector<string>All non domain lines under a certain ID
*/
vector<string> getDomainLine(const string &path) const;
/**
* @brief getDomainMap .
*
*
* @param path , , : /Main/Domain
* @param v
* @param vector<string>
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @param v vector<string>
* @param v the target subdomian namethe domain name under vector<string>
* @return truefalse
* @return bool: true, successful , false, failed
*/
bool getDomainVector(const string &path, vector<string> &v) const;
/**
* @brief ,
* vector按照在文件中的顺序返回
* @brief Get the subdomain under the domain
* @param path , , : /Main/Domain
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @return vector<string>
* @return vector<string> the subdomain under the target domain
*/
vector<string> getDomainVector(const string &path) const;
/**
* @brief .
* @brief Whether the domain exists or not.
*
* @param path , , : /Main/Domain
* @param path domain name, domain identifier, such as: '/Main/Domain'
* @return truefalse
* @return If the domain does exist, return true, else return false.
*/
bool hasDomainVector(const string &path) const;
/**
* @brief , sAddDomain域,
*
* @brief
Add domain. Add a domain under the current domain. If the sadddomain domain already exists, it is considered to be successful.
* @param sCurDomain , :/Main/Domain
* @param sCurDomain domain identifier, such as: '/Main/Domain'
* @param sAddDomain : : sCurDomain
* @param sAddDomain the name of the domain which need to be added: like: sCurDomain
* @param bCreate sCurDomain域不存在的情况下,
* @param bCreate When the domain sCurDomain does not exist, determine wheter it needs to be created automatically.
* @return 0-, 1-sCurDomain不存在
* @return 0 - add successfull, 1 - sCurDomain doesn't exist.
*/
int insertDomain(const string &sCurDomain, const string &sAddDomain, bool bCreate);
@ -465,25 +594,34 @@ public:
/**
* @brief ,
* , ()
* @brief Add parameter, i.e. configuration item. Add configuration item parameter under the current domain. If there are already related parameters, ignore (do not replace).
* @param sCurDomain , :/Main/Domain
* @param sCurDomain domain identifier, such as: '/Main/Domain'
* @param m map类型
* @param m map type, save parameter-value pairs
* @param bCreate sCurDomain域不存在的情况下,
* @param bCreate When the domain sCurDomain does not exist, determine wheter it needs to be created automatically.
* @return 0: , 1:sCurDomain不存在
* @return 0 - add successfull, 1 - sCurDomain doesn't exist.
*/
int insertDomainParam(const string &sCurDomain, const map<string, string> &m, bool bCreate);
/**
* @brief .
* @brief Merge profile to current profile
*
* @param cf
* @param bUpdate true-, false-
* @param bUpdate true - update the conflict item to this configuration, false - don't update the conflict item
*/
void joinConfig(const TC_Config &cf, bool bUpdate);
/**
* @brief .
* @brief convert to the string format of the configuration file
*
* @return
* @return the configuration string
*/
string tostr() const;
@ -491,7 +629,10 @@ protected:
/**
* @brief Parse输入流
* TC_ConfigDomain装入stack中
* @brief Parse Input Stream
* Finally, the input stream is parsed into a TC_ ConfigDomain and is loaded into the stack.
* @param
* @param the input stream, parsed by line
* @throws TC_Config_Exception
* @return
*/
@ -499,9 +640,12 @@ protected:
/**
* @brief create New Domain .
* @brief Create New subdomain
*
* @param sName
* @param sName domain name
* @return
* @return Pointer to the newly generated subfield
* @throws TC_Config_Exception
*/
TC_ConfigDomain *newTcConfigDomain(const string& sName);
@ -510,6 +654,7 @@ protected:
* @brief Search Domain .
*
* @param sDomainName ,
* @param sDomainName param name, support the subdomain search
* @return value
*/
TC_ConfigDomain *searchTcConfigDomain(const vector<string>& domains);
@ -519,6 +664,7 @@ protected:
/**
* domain
* the root domain
*/
TC_ConfigDomain _root;
};