summaryrefslogtreecommitdiff
path: root/server-tools/instance-manager/IMService.cpp
diff options
context:
space:
mode:
authorunknown <reggie@fedora.(none)>2005-07-20 10:55:40 -0500
committerunknown <reggie@fedora.(none)>2005-07-20 10:55:40 -0500
commit875b0e6322df380b6fcd4bd4f66d0d3e0142039f (patch)
treefd59532b923e8ee6c5bb48afac93f8d93e48fec6 /server-tools/instance-manager/IMService.cpp
parent6ae060305541019882bcb60bf086458b010faa45 (diff)
downloadmariadb-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-xserver-tools/instance-manager/IMService.cpp73
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;
+}
+