diff options
author | Christian Pointner <equinox@anytun.org> | 2010-01-20 07:38:36 +0000 |
---|---|---|
committer | Christian Pointner <equinox@anytun.org> | 2010-01-20 07:38:36 +0000 |
commit | 91b4dfa446e352f5d9c7d0ef58da1ceee9ce7b34 (patch) | |
tree | bcc677584cbec7bedf9b6f112fd14a78d0e06f82 /src/win32/winService.h | |
parent | updated windows signal handler (diff) |
integrated winservice into signal controller
Diffstat (limited to 'src/win32/winService.h')
-rw-r--r-- | src/win32/winService.h | 22 |
1 files changed, 4 insertions, 18 deletions
diff --git a/src/win32/winService.h b/src/win32/winService.h index 6867c7c..e2bab90 100644 --- a/src/win32/winService.h +++ b/src/win32/winService.h @@ -40,39 +40,25 @@ class WinService { public: - static WinService& instance(); #define SVC_NAME "anytun" static void install(); static void uninstall(); static void start(); - void waitForStop(); - void stop(); - static VOID WINAPI main(DWORD dwArgc, LPTSTR *lpszArgv); static VOID WINAPI ctrlHandler(DWORD dwCtrl); + + void reportStatus(DWORD dwCurrentState, DWORD dwWin32ExitCode); + int handleCtrlSignal(const SigNum& sig, const std::string& msg); + private: WinService() : started_(false) {}; ~WinService(); WinService(const WinService &w); void operator=(const WinService &w); - void reportStatus(DWORD dwCurrentState, DWORD dwWin32ExitCode, DWORD dwWaitHint=0); - - static WinService* inst; - static Mutex instMutex; - class instanceCleaner { - public: ~instanceCleaner() { - if(WinService::inst != NULL) - delete WinService::inst; - } - }; - friend class instanceCleaner; - - bool started_; SERVICE_STATUS status_; SERVICE_STATUS_HANDLE status_handle_; - HANDLE stop_event_; }; extern WinService& gWinService; |