]> git.stg.codes - stg.git/blobdiff - projects/stargazer/services_impl.h
Merge remote-tracking branch 'github/master'
[stg.git] / projects / stargazer / services_impl.h
index 31aa72b2ed612e43e1bb8aeb383233d5bc873811..eea5e7f13094d35034924e3b302dc4881481ab39 100644 (file)
  *    Author : Maxim Mamontov <faust@stargazer.dp.ua>
  */
 
  *    Author : Maxim Mamontov <faust@stargazer.dp.ua>
  */
 
-#ifndef SERVICES_IMPL_H
-#define SERVICES_IMPL_H
-
-#include <pthread.h>
-
-#include <list>
-#include <map>
-#include <string>
+#pragma once
 
 #include "stg/services.h"
 #include "stg/service_conf.h"
 
 #include "stg/services.h"
 #include "stg/service_conf.h"
-#include "stg/locker.h"
-#include "stg/store.h"
 #include "stg/noncopyable.h"
 #include "stg/logger.h"
 
 #include "stg/noncopyable.h"
 #include "stg/logger.h"
 
-class ADMIN;
+#include <vector>
+#include <map>
+#include <string>
+#include <mutex>
+
+namespace STG
+{
 
 
-class SERVICES_IMPL : private NONCOPYABLE, public SERVICES {
-public:
-    SERVICES_IMPL(STORE * st);
-    virtual ~SERVICES_IMPL() {}
+class Admin;
+struct Store;
 
 
-    int Add(const SERVICE_CONF & service, const ADMIN * admin);
-    int Del(const std::string & name, const ADMIN * admin);
-    int Change(const SERVICE_CONF & service, const ADMIN * admin);
-    bool Find(const std::string & name, SERVICE_CONF * service);
-    bool Exists(const std::string & name) const;
-    const std::string & GetStrError() const { return strError; }
+class ServicesImpl : public Services {
+    public:
+        explicit ServicesImpl(Store* st);
 
 
-    size_t Count() const { return data.size(); }
+        int Add(const ServiceConf& service, const Admin* admin) override;
+        int Del(const std::string& name, const Admin* admin) override;
+        int Change(const ServiceConf& service, const Admin* admin) override;
+        bool Find(const std::string& name, ServiceConf* service) const override;
+        bool Find(const std::string& name, ServiceConfOpt* service) const override;
+        bool Exists(const std::string& name) const override;
+        const std::string& GetStrError() const override { return strError; }
 
 
-    int OpenSearch() const;
-    int SearchNext(int, SERVICE_CONF * service) const;
-    int CloseSearch(int) const;
+        size_t Count() const override { return data.size(); }
 
 
-private:
-    SERVICES_IMPL(const SERVICES_IMPL & rvalue);
-    SERVICES_IMPL & operator=(const SERVICES_IMPL & rvalue);
+        int OpenSearch() const override;
+        int SearchNext(int, ServiceConf* service) const override;
+        int CloseSearch(int) const override;
 
 
-    typedef std::list<SERVICE_CONF>::iterator       srv_iter;
-    typedef std::list<SERVICE_CONF>::const_iterator const_srv_iter;
+    private:
+        typedef std::vector<ServiceConf>::iterator       iterator;
+        typedef std::vector<ServiceConf>::const_iterator const_iterator;
 
 
-    bool Read();
+        bool Read();
 
 
-    std::list<SERVICE_CONF> data;
-    STORE *                 store;
-    STG_LOGGER &            WriteServLog;
-    mutable std::map<int, const_srv_iter> searchDescriptors;
-    mutable unsigned int    handle;
-    mutable pthread_mutex_t mutex;
-    std::string             strError;
+        std::vector<ServiceConf> data;
+        Store*                 store;
+        Logger&            WriteServLog;
+        mutable std::map<int, const_iterator> searchDescriptors;
+        mutable unsigned int    handle;
+        mutable std::mutex mutex;
+        std::string             strError;
 };
 
 };
 
-#endif
+}