win32-service 0.7.0-x86-mswin32-60 → 0.7.1-x86-mswin32-60

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
data/MANIFEST CHANGED
@@ -1,19 +1,19 @@
1
- * MANIFEST
2
- * CHANGES
3
- * README
4
- * Rakefile
5
- * win32-service.gemspec
6
- * doc/daemon.txt
7
- * doc/service.txt
8
- * ext/extconf.rb
9
- * ext/win32/daemonc.c
10
- * examples/demo_daemon.rb
11
- * examples/demo_daemon_ctl.rb
12
- * examples/demo_services.rb
13
- * lib/win32/service.rb
14
- * test/test_win32_daemon.rb
15
- * test/test_win32_service_configure.rb
16
- * test/test_win32_service_create.rb
17
- * test/test_win32_service_info.rb
18
- * test/test_win32_service_status.rb
1
+ * MANIFEST
2
+ * CHANGES
3
+ * README
4
+ * Rakefile
5
+ * win32-service.gemspec
6
+ * doc/daemon.txt
7
+ * doc/service.txt
8
+ * ext/extconf.rb
9
+ * ext/win32/daemonc.c
10
+ * examples/demo_daemon.rb
11
+ * examples/demo_daemon_ctl.rb
12
+ * examples/demo_services.rb
13
+ * lib/win32/service.rb
14
+ * test/test_win32_daemon.rb
15
+ * test/test_win32_service_configure.rb
16
+ * test/test_win32_service_create.rb
17
+ * test/test_win32_service_info.rb
18
+ * test/test_win32_service_status.rb
19
19
  * test/test_win32_service.rb
data/README CHANGED
@@ -1,45 +1,74 @@
1
- = Description
2
- The win32-service library allows you to control or create MS Windows services.
3
-
4
- = Installation
5
- rake test (optional)
6
- rake install
7
-
8
- = Documentation
9
- Please see the documentation in the 'doc' directory, or the gem documentation
10
- that was installed when you installed this library as a gem.
11
-
12
- = Possible errors
13
- * Service.delete causes "Unable to delete: The specified service has
14
- been marked for deletion."
15
-
16
- This can be caused by two things. Either you attempted to delete a running
17
- service without stopping it first, or you have the Services administrative
18
- tool (GUI) open. The solution is to first stop the service if it's running
19
- and close the Services GUI admin tool before deleting.
20
-
21
- * Service.start causes, "The service did not respond to the start or control
22
- request in a timely fashion."
23
-
24
- The best way to debug your services is to wrap your entire Daemon subclass
25
- in a begin/end block and send error messages to a file. That should give a
26
- good clue as to the nature of the problem. The most probable culprits are:
27
-
28
- * You've tried to require a library that's not in your $LOAD_PATH. Make sure
29
- that your require statements are inside the begin/rescue block so that you can
30
- easily find those mistakes.
31
-
32
- * Your have a bad binary path name. Be sure to use an absolute path name for
33
- the binary path name, including the full path to the Ruby interpreter, e.g.
34
- 'c:\ruby\bin\ruby' instead of just 'ruby'.
35
-
36
- * You've got a syntax error in your code somewhere.
37
-
38
- = Possible test failures
39
- The 'test_service_start_stop' test in the tc_service.rb file may fail. This
40
- will happen if your W32Time service isn't running.
41
-
42
- = Future Plans
43
- * Pure Ruby Daemon class
44
- * Add service_session_change hook
45
- * Add a WMI variant of the Service class.
1
+ == Description
2
+ The win32-service library allows you to control or create MS Windows services.
3
+
4
+ == Installation
5
+ gem install win32-service
6
+
7
+ == Synopsis
8
+ require 'win32/service'
9
+
10
+ # Iterate over the available services
11
+ Service.services do |service|
12
+ p service
13
+ end
14
+
15
+ == More Documentation
16
+ Please see the documentation in the 'doc' directory, or the gem documentation
17
+ that was installed when you installed this library as a gem.
18
+
19
+ == Known Issues
20
+ === Problem:
21
+ Service.delete causes "Unable to delete: The specified service has been
22
+ marked for deletion."
23
+
24
+ === Troubleshooting:
25
+ This can be caused by one of two things. Either you attempted to delete a
26
+ running service without stopping it first, or you have the Services
27
+ administrative tool (GUI) open. In the form case, the solution is to first
28
+ stop the service if it's running. In the latter, close the Services GUI
29
+ admin tool before deleting.
30
+
31
+ === Problem:
32
+ Service.start causes, "The service did not respond to the start or control
33
+ request in a timely fashion."
34
+
35
+ === Troubleshooting:
36
+ The best way to debug your services is to wrap your entire Daemon subclass
37
+ in a begin/end block and send error messages to a file. That should give a
38
+ good clue as to the nature of the problem. The most probable culprits are:
39
+
40
+ * You've tried to require a library that's not in your $LOAD_PATH. Make sure
41
+ that your require statements are inside the begin/rescue block so that you can
42
+ easily find those mistakes.
43
+
44
+ * Your have a bad binary path name. Be sure to use an absolute path name for
45
+ the binary path name, including the full path to the Ruby interpreter, e.g.
46
+ 'c:\ruby\bin\ruby' instead of just 'ruby'.
47
+
48
+ * You've got a syntax error in your code somewhere.
49
+
50
+ == Possible test failures
51
+ The 'test_service_start_stop' test in the test_win32_service.rb file may
52
+ fail. This will happen if your W32Time service isn't running.
53
+
54
+ == See Also
55
+ ruby-wmi
56
+
57
+ == Future Plans
58
+ Pure Ruby Daemon class
59
+ Add service_session_change hook
60
+
61
+ == Copyright
62
+ (C) 2003-2010, Daniel J. Berger, All Rights Reserved
63
+
64
+ == License
65
+ Artistic 2.0
66
+
67
+ == Warranty
68
+ This package is provided "as is" and without any express or
69
+ implied warranties, including, without limitation, the implied
70
+ warranties of merchantability and fitness for a particular purpose.
71
+
72
+ == Authors
73
+ Daniel J. Berger
74
+ Park Heesob
data/Rakefile CHANGED
@@ -1,128 +1,139 @@
1
- require 'rake'
2
- require 'rake/clean'
3
- require 'rake/testtask'
4
- require 'rbconfig'
5
- include Config
6
-
7
- desc "Cleans up the C related files created during the build"
8
- task :clean do
9
- Dir.chdir('ext') do
10
- if File.exists?('daemon.o') || File.exists?('daemon.so')
11
- sh 'nmake distclean'
12
- end
13
- File.delete('win32/daemon.so') if File.exists?('win32/daemon.so')
14
- end
15
- end
16
-
17
- desc "Builds, but does not install, the win32-service library"
18
- task :build => [:clean] do
19
- Dir.chdir('ext') do
20
- ruby 'extconf.rb'
21
- sh 'nmake'
22
- FileUtils.cp('daemon.so', 'win32/daemon.so')
23
- end
24
- end
25
-
26
- desc "Install the win32-service library (non-gem)"
27
- task :install => [:build] do
28
- Dir.chdir('ext') do
29
- sh 'nmake install'
30
- end
31
- install_dir = File.join(CONFIG['sitelibdir'], 'win32')
32
- Dir.mkdir(install_dir) unless File.exists?(install_dir)
33
- FileUtils.cp('lib/win32/service.rb', install_dir, :verbose => true)
34
- end
35
-
36
- desc 'Install the win32-service library as a gem'
37
- task :install_gem => [:clean] do
38
- ruby 'win32-service.gemspec'
39
- file = Dir['win32-service*.gem'].first
40
- sh "gem install #{file}"
41
- end
42
-
43
- desc 'Uninstall the (non-gem) win32-service library.'
44
- task :uninstall do
45
- service = File.join(CONFIG['sitelibdir'], 'win32', 'service.rb')
46
- FileUtils.rm(service, :verbose => true) if File.exists?(service)
47
-
48
- daemon = File.join(CONFIG['sitearchdir'], 'win32', 'daemon.so')
49
- FileUtils.rm(daemon, :verbose => true) if File.exists?(daemon)
50
- end
51
-
52
- desc "Build a binary gem"
53
- task :build_binary_gem => [:build] do
54
- if File.exists?('lib/win32/daemon.rb')
55
- mv 'lib/win32/daemon.rb', 'lib/win32/daemon.orig'
56
- end
57
-
58
- cp 'ext/win32/daemon.so', 'lib/win32/daemon.so'
59
-
60
- task :build_binary_gem => [:clean]
61
-
62
- spec = Gem::Specification.new do |gem|
63
- gem.name = 'win32-service'
64
- gem.version = '0.7.0'
65
- gem.authors = ['Daniel J. Berger', 'Park Heesob']
66
- gem.email = 'djberg96@gmail.com'
67
- gem.license = 'Artistic 2.0'
68
- gem.homepage = 'http://www.rubyforge.org/projects/win32utils'
69
- gem.platform = Gem::Platform::CURRENT
70
- gem.summary = 'An interface for MS Windows services'
71
- gem.test_files = Dir['test/test*.rb']
72
- gem.has_rdoc = true
73
- gem.files = Dir['**/*'].delete_if{ |f|
74
- f.include?('CVS') || f.include?('ext') || f.include?('daemon.orig')
75
- }
76
-
77
- gem.extra_rdoc_files = [
78
- 'CHANGES',
79
- 'README',
80
- 'MANIFEST',
81
- 'doc/service.txt',
82
- 'doc/daemon.txt',
83
- 'ext/win32/daemon.c'
84
- ]
85
-
86
- gem.rubyforge_project = 'win32utils'
87
- gem.required_ruby_version = '>= 1.8.2'
88
-
89
- gem.add_dependency('windows-pr', '>= 1.0.5')
90
- gem.add_dependency('test-unit', '>= 2.0.2')
91
-
92
- gem.description = <<-EOF
93
- The win32-service library provides a Ruby interface to services on
94
- MS Windows. You can create new services, or control, configure and
95
- inspect existing services.
96
-
97
- In addition, you can create a pure Ruby service by using the Daemon
98
- class that is included as part of the library.
99
- EOF
100
- end
101
-
102
- Gem::Builder.new(spec).build
103
- end
104
-
105
- desc "Run the test suite for the win32-service library"
106
- Rake::TestTask.new do |t|
107
- task :test => :build
108
- t.libs << 'ext'
109
- t.verbose = true
110
- t.warning = true
111
- end
112
-
113
- desc "Run the test suite for the Win32::Daemon class (only)"
114
- Rake::TestTask.new('test_daemon') do |t|
115
- task :test_daemon => :build
116
- t.libs << 'ext'
117
- t.verbose = true
118
- t.warning = true
119
- t.test_files = FileList['test/test_win32_daemon.rb']
120
- end
121
-
122
- task :test do
123
- Rake.application[:clean].execute
124
- end
125
-
126
- task :test_daemon do
127
- Rake.application[:clean].execute
128
- end
1
+ require 'rake'
2
+ require 'rake/clean'
3
+ require 'rake/testtask'
4
+ require 'rbconfig'
5
+ include Config
6
+
7
+ desc "Cleans up the C related files created during the build"
8
+ task :clean do
9
+ Dir.chdir('ext') do
10
+ if File.exists?('daemon.o') || File.exists?('daemon.so')
11
+ sh 'nmake distclean'
12
+ end
13
+ File.delete('win32/daemon.so') if File.exists?('win32/daemon.so')
14
+ end
15
+ Dir['*.gem'].each{ |f| File.delete(f) }
16
+ File.delete('lib/win32/daemon.so') if File.exists?('lib/win32/daemon.so')
17
+ end
18
+
19
+ desc "Builds, but does not install, the win32-service library"
20
+ task :build => [:clean] do
21
+ Dir.chdir('ext') do
22
+ ruby 'extconf.rb'
23
+ sh 'nmake'
24
+ FileUtils.cp('daemon.so', 'win32/daemon.so')
25
+ end
26
+ end
27
+
28
+ desc "Install the win32-service library (non-gem)"
29
+ task :install => [:build] do
30
+ Dir.chdir('ext') do
31
+ sh 'nmake install'
32
+ end
33
+ install_dir = File.join(CONFIG['sitelibdir'], 'win32')
34
+ Dir.mkdir(install_dir) unless File.exists?(install_dir)
35
+ FileUtils.cp('lib/win32/service.rb', install_dir, :verbose => true)
36
+ end
37
+
38
+ desc 'Uninstall the win32-service library (non-gem)'
39
+ task :uninstall do
40
+ service = File.join(CONFIG['sitelibdir'], 'win32', 'service.rb')
41
+ FileUtils.rm(service, :verbose => true) if File.exists?(service)
42
+
43
+ daemon = File.join(CONFIG['sitearchdir'], 'win32', 'daemon.so')
44
+ FileUtils.rm(daemon, :verbose => true) if File.exists?(daemon)
45
+ end
46
+
47
+ namespace 'gem' do
48
+ desc 'Build the gem'
49
+ task :create => [:clean] do
50
+ spec = eval(IO.read('win32-service.gemspec'))
51
+ Gem::Builder.new(spec).build
52
+ end
53
+
54
+ desc 'Install the gem'
55
+ task :install => [:create] do
56
+ file = Dir['*.gem'].first
57
+ sh "gem install #{file}"
58
+ end
59
+
60
+ desc 'Build a binary gem'
61
+ task :binary => [:build] do
62
+ mkdir_p 'lib/win32'
63
+ mv 'ext/win32/daemon.so', 'lib/win32/daemon.so'
64
+
65
+ spec = eval(IO.read('win32-service.gemspec'))
66
+ spec.extensions = nil
67
+ spec.platform = Gem::Platform::CURRENT
68
+
69
+ spec.files = spec.files.reject{ |f| f.include?('ext') }
70
+
71
+ Gem::Builder.new(spec).build
72
+ end
73
+ end
74
+
75
+ namespace 'test' do
76
+ desc 'Run all tests for the win32-service library'
77
+ Rake::TestTask.new('all') do |t|
78
+ task :all => :build
79
+ t.libs << 'ext'
80
+ t.verbose = true
81
+ t.warning = true
82
+ end
83
+
84
+ desc 'Run the tests for the Win32::Daemon class'
85
+ Rake::TestTask.new('daemon') do |t|
86
+ task :daemon => :build
87
+ t.libs << 'ext'
88
+ t.verbose = true
89
+ t.warning = true
90
+ t.test_files = FileList['test/test_win32_daemon.rb']
91
+ end
92
+
93
+ namespace 'service' do
94
+ desc 'Run the tests for the Win32::Service class'
95
+ Rake::TestTask.new('all') do |t|
96
+ t.verbose = true
97
+ t.warning = true
98
+ t.test_files = FileList['test/test_win32_service*.rb']
99
+ end
100
+
101
+ Rake::TestTask.new('configure') do |t|
102
+ t.verbose = true
103
+ t.warning = true
104
+ t.test_files = FileList['test/test_win32_service_configure.rb']
105
+ end
106
+
107
+ Rake::TestTask.new('control') do |t|
108
+ t.verbose = true
109
+ t.warning = true
110
+ t.test_files = FileList['test/test_win32_service.rb']
111
+ end
112
+
113
+ Rake::TestTask.new('create') do |t|
114
+ t.verbose = true
115
+ t.warning = true
116
+ t.test_files = FileList['test/test_win32_service_create.rb']
117
+ end
118
+
119
+ Rake::TestTask.new('info') do |t|
120
+ t.verbose = true
121
+ t.warning = true
122
+ t.test_files = FileList['test/test_win32_service_info.rb']
123
+ end
124
+
125
+ Rake::TestTask.new('status') do |t|
126
+ t.verbose = true
127
+ t.warning = true
128
+ t.test_files = FileList['test/test_win32_service_status.rb']
129
+ end
130
+ end
131
+
132
+ task :all do
133
+ Rake.application[:clean].execute
134
+ end
135
+
136
+ task :daemon do
137
+ Rake.application[:clean].execute
138
+ end
139
+ end
data/doc/daemon.txt CHANGED
@@ -1,157 +1,157 @@
1
- = Description
2
- The Daemon class is a wrapper class that allows you to run your code as a
3
- Windows service.
4
-
5
- = Synopsis
6
- class Daemon
7
- def service_main
8
- while running?
9
- sleep 3
10
- File.open("c:\\test.log", "a"){ |f| f.puts "service is running" }
11
- end
12
- end
13
- end
14
-
15
- Daemon.mainloop
16
-
17
- = Class Methods
18
- Daemon.mainloop
19
- This is the method that actually puts your code into a loop and allows it
20
- to run as a service. The code that is actually run while in the mainloop
21
- is what you defined in the Daemon#service_main method.
22
-
23
- = Instance Methods
24
- Daemon#running?
25
- Returns whether or not the daemon is running. This is just a shortcut
26
- for checking if the state is RUNNING, PAUSED or IDLE.
27
-
28
- This is typically used within your service_main method. See the
29
- demo_daemon.rb file in the 'examples' directory for an example of how it's
30
- used in practice.
31
-
32
- Daemon#service_init
33
- Any code defined defined within this method occurs before service_main is
34
- reached. Any initialization code that takes more than two seconds to
35
- execute should be placed here. Otherwise, your service may timeout when
36
- you try to start it.
37
-
38
- Daemon#service_main(*args)
39
- You are expected to define your own service_main() method. The code
40
- defined in this method is the code that will run while running as a
41
- service.
42
-
43
- Any +args+ passed to Service.start are passed to this method.
44
-
45
- Daemon#state
46
- Returns the current state of the Daemon. For a list of valid states, see
47
- the Constants section below.
48
-
49
- = Signal Event Hooks
50
- These methods are called if defined within your Daemon class, and the
51
- appropriate signal is received by your service.
52
-
53
- Daemon#service_stop
54
- Called if the service receives a SERVICE_CONTROL_STOP signal. This is
55
- what the Service.stop() method sends.
56
-
57
- Daemon#service_pause
58
- Called if the service receives a SERVICE_CONTROL_PAUSE signal. This is
59
- what the Service.pause() method sends.
60
-
61
- Daemon#service_resume
62
- Called if the service receives a SERVICE_CONTROL_CONTINUE signal. This
63
- is what the Service.resume() method sends.
64
-
65
- Daemon#service_interrogate
66
- Called if the service receives a SERVICE_CONTROL_INTERROGATE signal. This
67
- notifies a service that it should report its current status information to
68
- the service control manager.
69
-
70
- Daemon#service_shutdown
71
- Called if the service receives a SERVICE_CONTROL_SHUTDOWN signal.
72
-
73
- Daemon#service_netbindadd
74
- Called if the service receives a SERVICE_CONTROL_NETBINDADD signal. This
75
- notifies a network service that there is a new component for binding.
76
-
77
- Daemon#service_netbinddisable
78
- Called if the service receives a SERVICE_CONTROL_NETBINDDISABLE signal.
79
- This notifies a network service that one of its bindings has been
80
- disabled.
81
-
82
- Daemon#service_netbindenable
83
- Called if the service receives a SERVICE_CONTROL_NETBINDENABLE signal.
84
- This Notifies a network service that a disabled binding has been enabled.
85
-
86
- Daemon#service_netbindremove
87
- Called if the service receives a SERVICE_CONTROL_NETBINDREMOVE signal.
88
- This notifies a network service that that a component for binding has
89
- been removed.
90
-
91
- Daemon#service_paramchange
92
- Called if the service receives a SERVICE_CONTROL_PARAMCHANGE signal.
93
- This notifies a service that its startup parameters have changed.
94
-
95
- = Constants
96
-
97
- === Service state constants
98
- Daemon::CONTINUE_PENDING
99
- The service continue is pending.
100
-
101
- Daemon::PAUSE_PENDING
102
- The service pause is pending.
103
-
104
- Daemon::PAUSED
105
- The service is paused (but not STOPPED).
106
-
107
- Daemon::RUNNING
108
- The service is running.
109
-
110
- Daemon::START_PENDING
111
- The service is starting (but is not yet in a RUNNING state).
112
-
113
- Daemon::STOP_PENDING
114
- The service is stopping (but is not yet in a STOPPED state).
115
-
116
- Daemon::STOPPED
117
- The service is not running.
118
-
119
- Daemon::IDLE
120
- The service is running, in an idle state. This is a custom state that
121
- we added that gets around a thread blocking issue.
122
-
123
- = Notes
124
- You must create a service before you can actually run it. Look in the
125
- examples directory for the files 'demo_daemon.rb' and 'demodaemon_ctl.rb'.
126
- They're small and straightforward examples of how to control, install and
127
- setup your own Daemon.
128
-
129
- = Known Bugs
130
- None known. Please report any bugs you find on the Bug tracker at
131
- http://rubyforge.org/projects/win32utils.
132
-
133
- = Future Plans
134
- Rewrite the Daemon class in pure Ruby.
135
-
136
- Suggestions welcome. Please log them on the Feature Request tracker at
137
- http://rubyforge.org/projects/win32utils
138
-
139
- = Acknowledgements
140
- Many thanks go to Patrick Hurley for providing the fix for the thread
141
- blocking issue. Thanks also go to Kevin Burge for his patch that solved
142
- service responsiveness issues.
143
-
144
- = Copyright
145
- (C) 2003-2009 Daniel J. Berger, All Rights Reserved
146
-
147
- = License
148
- Artistic 2.0
149
-
150
- = Warranty
151
- This package is provided "as is" and without any express or
152
- implied warranties, including, without limitation, the implied
153
- warranties of merchantability and fitness for a particular purpose.
154
-
155
- = Author(s)
156
- * Daniel J. Berger
157
- * Park Heesob
1
+ = Description
2
+ The Daemon class is a wrapper class that allows you to run your code as a
3
+ Windows service.
4
+
5
+ = Synopsis
6
+ class Daemon
7
+ def service_main
8
+ while running?
9
+ sleep 3
10
+ File.open("c:\\test.log", "a"){ |f| f.puts "service is running" }
11
+ end
12
+ end
13
+ end
14
+
15
+ Daemon.mainloop
16
+
17
+ = Class Methods
18
+ Daemon.mainloop
19
+ This is the method that actually puts your code into a loop and allows it
20
+ to run as a service. The code that is actually run while in the mainloop
21
+ is what you defined in the Daemon#service_main method.
22
+
23
+ = Instance Methods
24
+ Daemon#running?
25
+ Returns whether or not the daemon is running. This is just a shortcut
26
+ for checking if the state is RUNNING, PAUSED or IDLE.
27
+
28
+ This is typically used within your service_main method. See the
29
+ demo_daemon.rb file in the 'examples' directory for an example of how it's
30
+ used in practice.
31
+
32
+ Daemon#service_init
33
+ Any code defined defined within this method occurs before service_main is
34
+ reached. Any initialization code that takes more than two seconds to
35
+ execute should be placed here. Otherwise, your service may timeout when
36
+ you try to start it.
37
+
38
+ Daemon#service_main(*args)
39
+ You are expected to define your own service_main() method. The code
40
+ defined in this method is the code that will run while running as a
41
+ service.
42
+
43
+ Any +args+ passed to Service.start are passed to this method.
44
+
45
+ Daemon#state
46
+ Returns the current state of the Daemon. For a list of valid states, see
47
+ the Constants section below.
48
+
49
+ = Signal Event Hooks
50
+ These methods are called if defined within your Daemon class, and the
51
+ appropriate signal is received by your service.
52
+
53
+ Daemon#service_stop
54
+ Called if the service receives a SERVICE_CONTROL_STOP signal. This is
55
+ what the Service.stop() method sends.
56
+
57
+ Daemon#service_pause
58
+ Called if the service receives a SERVICE_CONTROL_PAUSE signal. This is
59
+ what the Service.pause() method sends.
60
+
61
+ Daemon#service_resume
62
+ Called if the service receives a SERVICE_CONTROL_CONTINUE signal. This
63
+ is what the Service.resume() method sends.
64
+
65
+ Daemon#service_interrogate
66
+ Called if the service receives a SERVICE_CONTROL_INTERROGATE signal. This
67
+ notifies a service that it should report its current status information to
68
+ the service control manager.
69
+
70
+ Daemon#service_shutdown
71
+ Called if the service receives a SERVICE_CONTROL_SHUTDOWN signal.
72
+
73
+ Daemon#service_netbindadd
74
+ Called if the service receives a SERVICE_CONTROL_NETBINDADD signal. This
75
+ notifies a network service that there is a new component for binding.
76
+
77
+ Daemon#service_netbinddisable
78
+ Called if the service receives a SERVICE_CONTROL_NETBINDDISABLE signal.
79
+ This notifies a network service that one of its bindings has been
80
+ disabled.
81
+
82
+ Daemon#service_netbindenable
83
+ Called if the service receives a SERVICE_CONTROL_NETBINDENABLE signal.
84
+ This Notifies a network service that a disabled binding has been enabled.
85
+
86
+ Daemon#service_netbindremove
87
+ Called if the service receives a SERVICE_CONTROL_NETBINDREMOVE signal.
88
+ This notifies a network service that that a component for binding has
89
+ been removed.
90
+
91
+ Daemon#service_paramchange
92
+ Called if the service receives a SERVICE_CONTROL_PARAMCHANGE signal.
93
+ This notifies a service that its startup parameters have changed.
94
+
95
+ = Constants
96
+
97
+ === Service state constants
98
+ Daemon::CONTINUE_PENDING
99
+ The service continue is pending.
100
+
101
+ Daemon::PAUSE_PENDING
102
+ The service pause is pending.
103
+
104
+ Daemon::PAUSED
105
+ The service is paused (but not STOPPED).
106
+
107
+ Daemon::RUNNING
108
+ The service is running.
109
+
110
+ Daemon::START_PENDING
111
+ The service is starting (but is not yet in a RUNNING state).
112
+
113
+ Daemon::STOP_PENDING
114
+ The service is stopping (but is not yet in a STOPPED state).
115
+
116
+ Daemon::STOPPED
117
+ The service is not running.
118
+
119
+ Daemon::IDLE
120
+ The service is running, in an idle state. This is a custom state that
121
+ we added that gets around a thread blocking issue.
122
+
123
+ = Notes
124
+ You must create a service before you can actually run it. Look in the
125
+ examples directory for the files 'demo_daemon.rb' and 'demodaemon_ctl.rb'.
126
+ They're small and straightforward examples of how to control, install and
127
+ setup your own Daemon.
128
+
129
+ = Known Bugs
130
+ None known. Please report any bugs you find on the Bug tracker at
131
+ http://rubyforge.org/projects/win32utils.
132
+
133
+ = Future Plans
134
+ Rewrite the Daemon class in pure Ruby.
135
+
136
+ Suggestions welcome. Please log them on the Feature Request tracker at
137
+ http://rubyforge.org/projects/win32utils
138
+
139
+ = Acknowledgements
140
+ Many thanks go to Patrick Hurley for providing the fix for the thread
141
+ blocking issue. Thanks also go to Kevin Burge for his patch that solved
142
+ service responsiveness issues.
143
+
144
+ = Copyright
145
+ (C) 2003-2009 Daniel J. Berger, All Rights Reserved
146
+
147
+ = License
148
+ Artistic 2.0
149
+
150
+ = Warranty
151
+ This package is provided "as is" and without any express or
152
+ implied warranties, including, without limitation, the implied
153
+ warranties of merchantability and fitness for a particular purpose.
154
+
155
+ = Author(s)
156
+ * Daniel J. Berger
157
+ * Park Heesob