X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/ab73d1ffd4233fbfc97c53ba5160f6e0367196a4..6a79784ca465afb804fd43a233f6a02e4ca894d9:/projects/sgconf/config.h?ds=sidebyside diff --git a/projects/sgconf/config.h b/projects/sgconf/config.h index 68aade1d..e52111e3 100644 --- a/projects/sgconf/config.h +++ b/projects/sgconf/config.h @@ -21,6 +21,7 @@ #ifndef __STG_SGCONF_CONFIG_H__ #define __STG_SGCONF_CONFIG_H__ +#include "stg/common.h" #include "stg/resetable.h" #include "stg/os_int.h" @@ -34,8 +35,51 @@ struct CONFIG RESETABLE configFile; RESETABLE server; RESETABLE port; + RESETABLE localAddress; + RESETABLE localPort; RESETABLE userName; RESETABLE userPass; + + CONFIG & operator=(const CONFIG & rhs) + { + if (!rhs.configFile.empty()) + configFile = rhs.configFile; + if (!rhs.server.empty()) + server = rhs.server; + if (!rhs.port.empty()) + port = rhs.port; + if (!rhs.localAddress.empty()) + localAddress = rhs.localAddress; + if (!rhs.localPort.empty()) + localPort = rhs.localPort; + if (!rhs.userName.empty()) + userName = rhs.userName; + if (!rhs.userPass.empty()) + userPass = rhs.userPass; + return *this; + } + + std::string Serialize() const + { + std::string res("{ "); + if (!configFile.empty()) + res += "configFile: '" + configFile.data() + "',"; + if (!server.empty()) + res += " server: '" + server.data() + "',"; + if (!port.empty()) + res += " port: " + x2str(port.data()) + ","; + if (!localAddress.empty()) + res += " local address: '" + localAddress.data() + "',"; + if (!localPort.empty()) + res += " local port: " + x2str(localPort.data()) + ","; + if (!userName.empty()) + res += " userName: '" + userName.data() + "',"; + if (!userPass.empty()) + res += " userPass: '" + userPass.data() + "'"; + return res + " }"; + } }; -} +} // namespace SGCONF + +#endif