]> git.stg.codes - stg.git/blobdiff - include/stg/service_conf.h
Fixed stupid bugs in BPF capturer.
[stg.git] / include / stg / service_conf.h
index 6c958c41289e5357b9756189023c731632d7201a..ca58154b2a08d53612b64f6419f4f6e4cdbcfa6b 100644 (file)
@@ -1,13 +1,40 @@
 #ifndef SERVICE_CONF_H
 #define SERVICE_CONF_H
 
 #ifndef SERVICE_CONF_H
 #define SERVICE_CONF_H
 
+#include <string>
+
+#include "os_int.h"
+
 struct SERVICE_CONF
 {
 struct SERVICE_CONF
 {
-string  name;
-string  comment;
-double  cost;
-int     payDay;
+SERVICE_CONF()
+    : name(), comment(), cost(0), payDay(0)
+{}
+SERVICE_CONF(const std::string & n)
+    : name(n), comment(), cost(0), payDay(0)
+{}
+SERVICE_CONF(const std::string & n, double c)
+    : name(n), comment(), cost(c), payDay(0)
+{}
+SERVICE_CONF(const std::string & n, double c, unsigned p)
+    : name(n), comment(), cost(c), payDay(static_cast<uint8_t>(p))
+{}
+SERVICE_CONF(const std::string & n, double c,
+             unsigned p, const std::string & com)
+    : name(n), comment(com), cost(c), payDay(static_cast<uint8_t>(p))
+{}
+
+std::string name;
+std::string comment;
+double      cost;
+uint8_t     payDay;
 };
 
 };
 
+inline
+bool operator==(const SERVICE_CONF & a, const SERVICE_CONF & b)
+{
+return a.name == b.name;
+}
+
 #endif //SERVICE_CONF_H
 
 #endif //SERVICE_CONF_H