diff options
author | unknown <reggie@fedora.(none)> | 2005-07-20 10:55:40 -0500 |
---|---|---|
committer | unknown <reggie@fedora.(none)> | 2005-07-20 10:55:40 -0500 |
commit | 875b0e6322df380b6fcd4bd4f66d0d3e0142039f (patch) | |
tree | fd59532b923e8ee6c5bb48afac93f8d93e48fec6 /server-tools/instance-manager/IMService.cpp | |
parent | 6ae060305541019882bcb60bf086458b010faa45 (diff) | |
download | mariadb-git-875b0e6322df380b6fcd4bd4f66d0d3e0142039f.tar.gz |
initial import of Windows port of IM.
server-tools/instance-manager/commands.cc:
type cleanups for compiling on Windows
now using Options::config_file for the location of the single
my.cnf file we are using
server-tools/instance-manager/guardian.cc:
pthread_mutex_lock and unlock do not return a value on Windows
so we return 0 in all cases
server-tools/instance-manager/instance.cc:
big changes here.
Had to implement Windows versions of launch_and_wait and kill()
server-tools/instance-manager/instance.h:
added some function defs
server-tools/instance-manager/instance_map.cc:
pthread_mutex_lock and unlock do not return a value on Windows
Also, now using only the file named as Options::config_file
server-tools/instance-manager/instance_options.h:
added reference to port.h
server-tools/instance-manager/listener.cc:
reworked and simplified the socket handling code.
Added windows versions of the code that sets the sockets to be
non-blocking and non-inheritable
server-tools/instance-manager/listener.h:
change Options to always be a struct. Really surprised GCC was
letting this go. Options was declared to be struct in some places
and class in other places.
server-tools/instance-manager/log.cc:
added reference to port.h
server-tools/instance-manager/manager.cc:
moved all the signal code inside some #ifndef __WIN__ blocks
server-tools/instance-manager/manager.h:
change Options to always be a struct. Really surprised GCC was
letting this go. Options was declared to be struct in some places
and class in other places.
server-tools/instance-manager/mysqlmanager.cc:
added in the Windows service code.
server-tools/instance-manager/options.cc:
Added in the windows options for running as a service and the code
for loading settings only from a single file
server-tools/instance-manager/options.h:
added definitions for the new Windows service vars and routines
server-tools/instance-manager/parse_output.cc:
added reference to port.h
server-tools/instance-manager/priv.cc:
added reference to port.h
server-tools/instance-manager/priv.h:
linuxthreads should not be visible on Windows
server-tools/instance-manager/thread_registry.cc:
more __WIN__ blocking
server-tools/instance-manager/user_map.cc:
fixed passwd file code to handle files with \r\n line endings
server-tools/instance-manager/IMService.cpp:
New BitKeeper file ``server-tools/instance-manager/IMService.cpp''
server-tools/instance-manager/IMService.h:
New BitKeeper file ``server-tools/instance-manager/IMService.h''
server-tools/instance-manager/WindowsService.cpp:
New BitKeeper file ``server-tools/instance-manager/WindowsService.cpp''
server-tools/instance-manager/WindowsService.h:
New BitKeeper file ``server-tools/instance-manager/WindowsService.h''
server-tools/instance-manager/mysqlmanager.vcproj:
New BitKeeper file ``server-tools/instance-manager/mysqlmanager.vcproj''
server-tools/instance-manager/port.h:
New BitKeeper file ``server-tools/instance-manager/port.h''
Diffstat (limited to 'server-tools/instance-manager/IMService.cpp')
-rwxr-xr-x | server-tools/instance-manager/IMService.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/server-tools/instance-manager/IMService.cpp b/server-tools/instance-manager/IMService.cpp new file mode 100755 index 00000000000..920a0f3db0c --- /dev/null +++ b/server-tools/instance-manager/IMService.cpp @@ -0,0 +1,73 @@ +#include <windows.h> +#include "log.h" +#include "options.h" +#include "IMService.h" + +IMService::IMService(void) +{ + serviceName = "MySqlManager"; + displayName = "MySQL Manager"; +} + +IMService::~IMService(void) +{ +} + +void IMService::Stop() +{ + ReportStatus(SERVICE_STOP_PENDING); + // stop the IM work +} + +void IMService::Run() +{ + // report to the SCM that we're about to start + ReportStatus((DWORD)SERVICE_START_PENDING); + + // init goes here + + ReportStatus((DWORD)SERVICE_RUNNING); + + // wait for main loop to terminate +} + +void IMService::Log(const char *msg) +{ + log_info(msg); +} + +int HandleServiceOptions(Options options) +{ + int ret_val = 0; + + IMService winService; + + if (options.install_as_service) + { + if (winService.IsInstalled()) + log_info("Service is already installed\n"); + else if (winService.Install()) + log_info("Service installed successfully\n"); + else + { + log_info("Service failed to install\n"); + ret_val = -1; + } + } + else if (options.remove_service) + { + if (! winService.IsInstalled()) + log_info("Service is not installed\n"); + else if (winService.Remove()) + log_info("Service removed successfully\n"); + else + { + log_info("Service failed to remove\n"); + ret_val = -1; + } + } + else + return (int)winService.Init(); + return ret_val; +} + |