merge -r 60439:60440
[mono.git] / mcs / class / System.ServiceProcess / System.ServiceProcess / ServiceBase.cs
index 233b37e79a164dcb2833ab9dd6db6e37767e9164..82758996bed8268cb24d3183383c16c6a0a872bc 100644 (file)
@@ -4,8 +4,10 @@
 // Authors:
 //      Cesar Octavio Lopez Nataren (cesar@ciencias.unam.mx)
 //      Duncan Mak (duncan@ximian.com)
+//      Joerg Rosenkranz (joergr@voelcker.com)
 //
 // (C) 2003, Ximian Inc and Cesar Octavio Lopez Nataren.
+// (C) 2005, Voelcker Informatik AG
 //
 
 //
@@ -38,18 +40,23 @@ namespace System.ServiceProcess
 {
        public class ServiceBase : System.ComponentModel.Component
        {
+               internal delegate void RunServiceCallback (ServiceBase [] services);
+               
+               // This member is used for interoperation with mono-service
+               internal static RunServiceCallback RunService = null;
+               
                public ServiceBase() { }
 
                 public const int MaxNameLength = 80;
 
-                bool hasStarted;
+                bool hasStarted = false;
                 
-                bool auto_log;
-                bool can_handle_power_event;
-                bool can_pause_and_continue;
-                bool can_shutdown;
-                bool can_stop;
-                EventLog event_log;
+                bool auto_log = true;
+                bool can_handle_power_event = false;
+                bool can_pause_and_continue = false;
+                bool can_shutdown = false;
+                bool can_stop = true;
+                EventLog event_log = null;
                 string service_name;
 
                 public bool AutoLog {
@@ -116,7 +123,11 @@ namespace System.ServiceProcess
                 }
                 
                 public virtual EventLog EventLog {
-                        get { return event_log; }
+                        get { 
+                                                       if (event_log == null)
+                                                               event_log = new EventLog ("Application", ".", service_name);
+                                                       return event_log; 
+                                               }
                 }
 
                 public string ServiceName {
@@ -138,10 +149,27 @@ namespace System.ServiceProcess
                protected virtual void OnStart (string [] args) { }
 
                protected virtual void OnStop () { }
+               
+               protected virtual void OnContinue () { }
 
-                public static void Run (ServiceBase service) { }
+               protected virtual void OnCustomCommand () { }
 
-               public static void Run (ServiceBase [] ServicesToRun) { }
+               protected virtual void OnPause () { }
+
+               protected virtual void OnPowerEvent () { }
+
+               protected virtual void OnShutdown () { }
+
+        public static void Run (ServiceBase service) 
+               {
+                       Run (new ServiceBase [] {service});
+               }
+
+               public static void Run (ServiceBase [] servicesToRun) 
+               {
+                       if (RunService != null)
+                               RunService (servicesToRun);
+               }
 
        }
 }