activesambaldap 0.0.8 → 0.0.9

Sign up to get free protection for your applications and to get access to all the features.
Files changed (180) hide show
  1. data/Gemfile +21 -0
  2. data/NEWS.en +1 -1
  3. data/NEWS.ja +1 -1
  4. data/README.en +12 -8
  5. data/README.ja +6 -3
  6. data/Rakefile +27 -121
  7. data/lib/active_samba_ldap.rb +1 -1
  8. data/lib/active_samba_ldap/get_text_support.rb +1 -1
  9. data/lib/active_samba_ldap/version.rb +1 -1
  10. data/license/lgpl-2.1.txt +165 -0
  11. data/po/ja/active-samba-ldap.po +2 -2
  12. data/test/run-test.rb +3 -3
  13. metadata +145 -277
  14. data/bin/asl-groupadd.help +0 -16
  15. data/bin/asl-groupdel.help +0 -13
  16. data/bin/asl-groupmod.help +0 -19
  17. data/bin/asl-groupshow.help +0 -11
  18. data/bin/asl-passwd.help +0 -15
  19. data/bin/asl-populate.help +0 -28
  20. data/bin/asl-purge.help +0 -11
  21. data/bin/asl-samba-computeradd.help +0 -13
  22. data/bin/asl-samba-groupadd.help +0 -11
  23. data/bin/asl-samba-groupdel.help +0 -11
  24. data/bin/asl-samba-groupmod.help +0 -15
  25. data/bin/asl-samba-useradd.help +0 -13
  26. data/bin/asl-samba-userdel.help +0 -11
  27. data/bin/asl-samba-usermod.help +0 -15
  28. data/bin/asl-useradd.help +0 -49
  29. data/bin/asl-userdel.help +0 -18
  30. data/bin/asl-usermod.help +0 -47
  31. data/bin/asl-usershow.help +0 -11
  32. data/data/locale/ja/LC_MESSAGES/active-samba-ldap.mo +0 -0
  33. data/example/asl-admin/README +0 -243
  34. data/example/asl-admin/Rakefile +0 -10
  35. data/example/asl-admin/app/controllers/application_controller.rb +0 -10
  36. data/example/asl-admin/app/controllers/samba_controller.rb +0 -12
  37. data/example/asl-admin/app/helpers/application_helper.rb +0 -3
  38. data/example/asl-admin/app/helpers/samba_helper.rb +0 -2
  39. data/example/asl-admin/app/models/computer.rb +0 -3
  40. data/example/asl-admin/app/models/dc.rb +0 -3
  41. data/example/asl-admin/app/models/group.rb +0 -3
  42. data/example/asl-admin/app/models/idmap.rb +0 -3
  43. data/example/asl-admin/app/models/ou.rb +0 -3
  44. data/example/asl-admin/app/models/unix_id_pool.rb +0 -3
  45. data/example/asl-admin/app/models/user.rb +0 -3
  46. data/example/asl-admin/app/views/samba/index.html.erb +0 -17
  47. data/example/asl-admin/app/views/samba/populate.html.erb +0 -15
  48. data/example/asl-admin/app/views/samba/purge.html.erb +0 -10
  49. data/example/asl-admin/config/boot.rb +0 -110
  50. data/example/asl-admin/config/database.yml +0 -22
  51. data/example/asl-admin/config/environment.rb +0 -48
  52. data/example/asl-admin/config/environments/development.rb +0 -17
  53. data/example/asl-admin/config/environments/production.rb +0 -28
  54. data/example/asl-admin/config/environments/test.rb +0 -28
  55. data/example/asl-admin/config/initializers/backtrace_silencers.rb +0 -7
  56. data/example/asl-admin/config/initializers/inflections.rb +0 -10
  57. data/example/asl-admin/config/initializers/mime_types.rb +0 -5
  58. data/example/asl-admin/config/initializers/new_rails_defaults.rb +0 -19
  59. data/example/asl-admin/config/initializers/session_store.rb +0 -15
  60. data/example/asl-admin/config/ldap.yml.sample +0 -24
  61. data/example/asl-admin/config/locales/en.yml +0 -5
  62. data/example/asl-admin/config/routes.rb +0 -43
  63. data/example/asl-admin/log/test.log +0 -5
  64. data/example/asl-admin/public/404.html +0 -30
  65. data/example/asl-admin/public/422.html +0 -30
  66. data/example/asl-admin/public/500.html +0 -30
  67. data/example/asl-admin/public/favicon.ico +0 -0
  68. data/example/asl-admin/public/images/rails.png +0 -0
  69. data/example/asl-admin/public/index.html +0 -275
  70. data/example/asl-admin/public/javascripts/application.js +0 -2
  71. data/example/asl-admin/public/javascripts/controls.js +0 -963
  72. data/example/asl-admin/public/javascripts/dragdrop.js +0 -973
  73. data/example/asl-admin/public/javascripts/effects.js +0 -1128
  74. data/example/asl-admin/public/javascripts/prototype.js +0 -4320
  75. data/example/asl-admin/public/robots.txt +0 -5
  76. data/example/asl-admin/script/about +0 -4
  77. data/example/asl-admin/script/console +0 -3
  78. data/example/asl-admin/script/dbconsole +0 -3
  79. data/example/asl-admin/script/destroy +0 -3
  80. data/example/asl-admin/script/generate +0 -3
  81. data/example/asl-admin/script/performance/benchmarker +0 -3
  82. data/example/asl-admin/script/performance/profiler +0 -3
  83. data/example/asl-admin/script/plugin +0 -3
  84. data/example/asl-admin/script/runner +0 -3
  85. data/example/asl-admin/script/server +0 -3
  86. data/example/asl-admin/test/performance/browsing_test.rb +0 -9
  87. data/example/asl-admin/test/test_helper.rb +0 -38
  88. data/po/active-samba-ldap.pot +0 -463
  89. data/rails_generators/scaffold_active_samba_ldap/scaffold_active_samba_ldap_generator.rb +0 -28
  90. data/rails_generators/scaffold_active_samba_ldap/templates/computer.rb +0 -3
  91. data/rails_generators/scaffold_active_samba_ldap/templates/dc.rb +0 -3
  92. data/rails_generators/scaffold_active_samba_ldap/templates/group.rb +0 -3
  93. data/rails_generators/scaffold_active_samba_ldap/templates/idmap.rb +0 -3
  94. data/rails_generators/scaffold_active_samba_ldap/templates/ldap.yml +0 -24
  95. data/rails_generators/scaffold_active_samba_ldap/templates/ou.rb +0 -3
  96. data/rails_generators/scaffold_active_samba_ldap/templates/samba_controller.rb +0 -12
  97. data/rails_generators/scaffold_active_samba_ldap/templates/samba_helper.rb +0 -2
  98. data/rails_generators/scaffold_active_samba_ldap/templates/samba_index.html.erb +0 -17
  99. data/rails_generators/scaffold_active_samba_ldap/templates/samba_populate.html.erb +0 -15
  100. data/rails_generators/scaffold_active_samba_ldap/templates/samba_purge.html.erb +0 -10
  101. data/rails_generators/scaffold_active_samba_ldap/templates/unix_id_pool.rb +0 -3
  102. data/rails_generators/scaffold_active_samba_ldap/templates/user.rb +0 -3
  103. data/setup.rb +0 -1585
  104. data/test-unit/History.txt +0 -107
  105. data/test-unit/README.txt +0 -52
  106. data/test-unit/Rakefile +0 -40
  107. data/test-unit/TODO +0 -5
  108. data/test-unit/bin/testrb +0 -5
  109. data/test-unit/lib/test/unit.rb +0 -342
  110. data/test-unit/lib/test/unit/assertionfailederror.rb +0 -14
  111. data/test-unit/lib/test/unit/assertions.rb +0 -1149
  112. data/test-unit/lib/test/unit/attribute.rb +0 -125
  113. data/test-unit/lib/test/unit/autorunner.rb +0 -344
  114. data/test-unit/lib/test/unit/collector.rb +0 -43
  115. data/test-unit/lib/test/unit/collector/descendant.rb +0 -23
  116. data/test-unit/lib/test/unit/collector/dir.rb +0 -108
  117. data/test-unit/lib/test/unit/collector/load.rb +0 -137
  118. data/test-unit/lib/test/unit/collector/objectspace.rb +0 -34
  119. data/test-unit/lib/test/unit/color-scheme.rb +0 -90
  120. data/test-unit/lib/test/unit/color.rb +0 -96
  121. data/test-unit/lib/test/unit/diff.rb +0 -538
  122. data/test-unit/lib/test/unit/error.rb +0 -126
  123. data/test-unit/lib/test/unit/exceptionhandler.rb +0 -39
  124. data/test-unit/lib/test/unit/failure.rb +0 -110
  125. data/test-unit/lib/test/unit/fixture.rb +0 -176
  126. data/test-unit/lib/test/unit/notification.rb +0 -125
  127. data/test-unit/lib/test/unit/omission.rb +0 -143
  128. data/test-unit/lib/test/unit/pending.rb +0 -146
  129. data/test-unit/lib/test/unit/priority.rb +0 -181
  130. data/test-unit/lib/test/unit/runner/console.rb +0 -52
  131. data/test-unit/lib/test/unit/runner/emacs.rb +0 -8
  132. data/test-unit/lib/test/unit/runner/tap.rb +0 -8
  133. data/test-unit/lib/test/unit/testcase.rb +0 -425
  134. data/test-unit/lib/test/unit/testresult.rb +0 -89
  135. data/test-unit/lib/test/unit/testsuite.rb +0 -110
  136. data/test-unit/lib/test/unit/ui/console/outputlevel.rb +0 -14
  137. data/test-unit/lib/test/unit/ui/console/testrunner.rb +0 -278
  138. data/test-unit/lib/test/unit/ui/emacs/testrunner.rb +0 -49
  139. data/test-unit/lib/test/unit/ui/tap/testrunner.rb +0 -92
  140. data/test-unit/lib/test/unit/ui/testrunner.rb +0 -20
  141. data/test-unit/lib/test/unit/ui/testrunnermediator.rb +0 -77
  142. data/test-unit/lib/test/unit/ui/testrunnerutilities.rb +0 -41
  143. data/test-unit/lib/test/unit/util/backtracefilter.rb +0 -41
  144. data/test-unit/lib/test/unit/util/method-owner-finder.rb +0 -28
  145. data/test-unit/lib/test/unit/util/observable.rb +0 -90
  146. data/test-unit/lib/test/unit/util/procwrapper.rb +0 -48
  147. data/test-unit/lib/test/unit/version.rb +0 -7
  148. data/test-unit/sample/adder.rb +0 -13
  149. data/test-unit/sample/subtracter.rb +0 -12
  150. data/test-unit/sample/tc_adder.rb +0 -18
  151. data/test-unit/sample/tc_subtracter.rb +0 -18
  152. data/test-unit/sample/test_user.rb +0 -22
  153. data/test-unit/sample/ts_examples.rb +0 -7
  154. data/test-unit/test/collector/test-descendant.rb +0 -135
  155. data/test-unit/test/collector/test-load.rb +0 -329
  156. data/test-unit/test/collector/test_dir.rb +0 -406
  157. data/test-unit/test/collector/test_objectspace.rb +0 -98
  158. data/test-unit/test/run-test.rb +0 -13
  159. data/test-unit/test/test-attribute.rb +0 -86
  160. data/test-unit/test/test-color-scheme.rb +0 -60
  161. data/test-unit/test/test-color.rb +0 -47
  162. data/test-unit/test/test-diff.rb +0 -477
  163. data/test-unit/test/test-emacs-runner.rb +0 -60
  164. data/test-unit/test/test-fixture.rb +0 -287
  165. data/test-unit/test/test-notification.rb +0 -33
  166. data/test-unit/test/test-omission.rb +0 -81
  167. data/test-unit/test/test-pending.rb +0 -70
  168. data/test-unit/test/test-priority.rb +0 -119
  169. data/test-unit/test/test-testcase.rb +0 -507
  170. data/test-unit/test/test_assertions.rb +0 -1082
  171. data/test-unit/test/test_error.rb +0 -26
  172. data/test-unit/test/test_failure.rb +0 -33
  173. data/test-unit/test/test_testresult.rb +0 -113
  174. data/test-unit/test/test_testsuite.rb +0 -129
  175. data/test-unit/test/testunit-test-util.rb +0 -14
  176. data/test-unit/test/ui/test_testrunmediator.rb +0 -20
  177. data/test-unit/test/util/test-method-owner-finder.rb +0 -38
  178. data/test-unit/test/util/test_backtracefilter.rb +0 -41
  179. data/test-unit/test/util/test_observable.rb +0 -102
  180. data/test-unit/test/util/test_procwrapper.rb +0 -36
@@ -1,49 +0,0 @@
1
- require 'test/unit/ui/console/testrunner'
2
-
3
- module Test
4
- module Unit
5
- module UI
6
- module Emacs
7
- class TestRunner < Console::TestRunner
8
- private
9
- def output_setup_end
10
- end
11
-
12
- def output_started
13
- end
14
-
15
- def format_fault(fault)
16
- return super unless fault.respond_to?(:label)
17
- format_method_name = "format_fault_#{fault.label.downcase}"
18
- if respond_to?(format_method_name, true)
19
- send(format_method_name, fault)
20
- else
21
- super
22
- end
23
- end
24
-
25
- def format_fault_failure(failure)
26
- if failure.location.size == 1
27
- location = failure.location[0]
28
- location_display = location.sub(/\A(.+:\d+).*/, ' [\\1]')
29
- else
30
- location_display = "\n" + failure.location.join("\n")
31
- end
32
- result = "#{failure.label}:\n"
33
- result << "#{failure.test_name}#{location_display}:\n"
34
- result << failure.message
35
- result
36
- end
37
-
38
- def format_fault_error(error)
39
- result = "#{error.label}:\n"
40
- result << "#{error.test_name}:\n"
41
- result << "#{error.message}\n"
42
- result << error.backtrace.join("\n")
43
- result
44
- end
45
- end
46
- end
47
- end
48
- end
49
- end
@@ -1,92 +0,0 @@
1
- #--
2
- #
3
- # Author:: Kouhei Sutou.
4
- # Copyright:: Copyright (c) 2009 Kouhei Sutou <kou@clear-code.com>.
5
- # License:: Ruby license.
6
-
7
- require 'test/unit/ui/testrunner'
8
- require 'test/unit/ui/testrunnermediator'
9
-
10
- module Test
11
- module Unit
12
- module UI
13
- module Tap
14
-
15
- # Runs a Test::Unit::TestSuite and outputs result
16
- # as TAP format.
17
- class TestRunner < UI::TestRunner
18
- def initialize(suite, options={})
19
- super
20
- @output = @options[:output] || STDOUT
21
- @n_tests = 0
22
- @already_outputted = false
23
- end
24
-
25
- # Begins the test run.
26
- def start
27
- setup_mediator
28
- result = start_mediator
29
- def result.passed?
30
- true # for prove commend :<
31
- end
32
- result
33
- end
34
-
35
- private
36
- def setup_mediator
37
- @mediator = TestRunnerMediator.new(@suite)
38
- attach_to_mediator
39
- end
40
-
41
- def attach_to_mediator
42
- @mediator.add_listener(TestResult::FAULT, &method(:add_fault))
43
- @mediator.add_listener(TestRunnerMediator::STARTED, &method(:started))
44
- @mediator.add_listener(TestRunnerMediator::FINISHED, &method(:finished))
45
- @mediator.add_listener(TestCase::STARTED, &method(:test_started))
46
- @mediator.add_listener(TestCase::FINISHED, &method(:test_finished))
47
- end
48
-
49
- def start_mediator
50
- @mediator.run_suite
51
- end
52
-
53
- def add_fault(fault)
54
- puts("not ok #{@n_tests} - #{fault.short_display}")
55
- fault.long_display.each_line do |line|
56
- puts("# #{line}")
57
- end
58
- @already_outputted = true
59
- end
60
-
61
- def started(result)
62
- @result = result
63
- puts("1..#{@suite.size}")
64
- end
65
-
66
- def finished(elapsed_time)
67
- puts("# Finished in #{elapsed_time} seconds.")
68
- @result.to_s.each_line do |line|
69
- puts("# #{line}")
70
- end
71
- end
72
-
73
- def test_started(name)
74
- @n_tests += 1
75
- end
76
-
77
- def test_finished(name)
78
- unless @already_outputted
79
- puts("ok #{@n_tests} - #{name}")
80
- end
81
- @already_outputted = false
82
- end
83
-
84
- def puts(*args)
85
- @output.puts(*args)
86
- @output.flush
87
- end
88
- end
89
- end
90
- end
91
- end
92
- end
@@ -1,20 +0,0 @@
1
- require 'test/unit/ui/testrunnerutilities'
2
-
3
- module Test
4
- module Unit
5
- module UI
6
- class TestRunner
7
- extend TestRunnerUtilities
8
-
9
- def initialize(suite, options={})
10
- if suite.respond_to?(:suite)
11
- @suite = suite.suite
12
- else
13
- @suite = suite
14
- end
15
- @options = options
16
- end
17
- end
18
- end
19
- end
20
- end
@@ -1,77 +0,0 @@
1
- #--
2
- #
3
- # Author:: Nathaniel Talbott.
4
- # Copyright:: Copyright (c) 2000-2002 Nathaniel Talbott. All rights reserved.
5
- # License:: Ruby license.
6
-
7
- require 'test/unit'
8
- require 'test/unit/util/observable'
9
- require 'test/unit/testresult'
10
-
11
- module Test
12
- module Unit
13
- module UI
14
-
15
- # Provides an interface to write any given UI against,
16
- # hopefully making it easy to write new UIs.
17
- class TestRunnerMediator
18
- RESET = name + "::RESET"
19
- STARTED = name + "::STARTED"
20
- FINISHED = name + "::FINISHED"
21
-
22
- include Util::Observable
23
-
24
- # Creates a new TestRunnerMediator initialized to run
25
- # the passed suite.
26
- def initialize(suite)
27
- @suite = suite
28
- end
29
-
30
- # Runs the suite the TestRunnerMediator was created
31
- # with.
32
- def run_suite
33
- Unit.run = true
34
-
35
- result = create_result
36
- result_listener = result.add_listener(TestResult::CHANGED) do |*args|
37
- notify_listeners(TestResult::CHANGED, *args)
38
- end
39
- fault_listener = result.add_listener(TestResult::FAULT) do |*args|
40
- notify_listeners(TestResult::FAULT, *args)
41
- end
42
-
43
- start_time = Time.now
44
- begin
45
- notify_listeners(RESET, @suite.size)
46
- notify_listeners(STARTED, result)
47
-
48
- @suite.run(result) do |channel, value|
49
- notify_listeners(channel, value)
50
- end
51
- ensure
52
- elapsed_time = Time.now - start_time
53
- result.remove_listener(TestResult::FAULT, fault_listener)
54
- result.remove_listener(TestResult::CHANGED, result_listener)
55
- notify_listeners(FINISHED, elapsed_time)
56
- end
57
-
58
- result
59
- end
60
-
61
- private
62
- # A factory method to create the result the mediator
63
- # should run with. Can be overridden by subclasses if
64
- # one wants to use a different result.
65
- def create_result
66
- TestResult.new
67
- end
68
-
69
- def measure_time
70
- begin_time = Time.now
71
- yield
72
- Time.now - begin_time
73
- end
74
- end
75
- end
76
- end
77
- end
@@ -1,41 +0,0 @@
1
- #--
2
- #
3
- # Author:: Nathaniel Talbott.
4
- # Copyright:: Copyright (c) 2000-2002 Nathaniel Talbott. All rights reserved.
5
- # License:: Ruby license.
6
-
7
- module Test
8
- module Unit
9
- module UI
10
-
11
- # Provides some utilities common to most, if not all,
12
- # TestRunners.
13
- #
14
- #--
15
- #
16
- # Perhaps there ought to be a TestRunner superclass? There
17
- # seems to be a decent amount of shared code between test
18
- # runners.
19
-
20
- module TestRunnerUtilities
21
-
22
- # Creates a new TestRunner and runs the suite.
23
- def run(suite, options={})
24
- return new(suite, options).start
25
- end
26
-
27
- # Takes care of the ARGV parsing and suite
28
- # determination necessary for running one of the
29
- # TestRunners from the command line.
30
- def start_command_line_test
31
- if ARGV.empty?
32
- puts "You should supply the name of a test suite file to the runner"
33
- exit
34
- end
35
- require ARGV[0].gsub(/.+::/, '')
36
- new(eval(ARGV[0])).start
37
- end
38
- end
39
- end
40
- end
41
- end
@@ -1,41 +0,0 @@
1
- module Test
2
- module Unit
3
- module Util
4
- module BacktraceFilter
5
- TESTUNIT_FILE_SEPARATORS = %r{[\\/:]}
6
- TESTUNIT_PREFIX = __FILE__.split(TESTUNIT_FILE_SEPARATORS)[0..-3]
7
- TESTUNIT_RB_FILE = /\.rb\Z/
8
-
9
- module_function
10
- def filter_backtrace(backtrace, prefix=nil)
11
- return ["No backtrace"] unless(backtrace)
12
- split_p = if(prefix)
13
- prefix.split(TESTUNIT_FILE_SEPARATORS)
14
- else
15
- TESTUNIT_PREFIX
16
- end
17
- match = proc do |e|
18
- split_e = e.split(TESTUNIT_FILE_SEPARATORS)[0, split_p.size]
19
- next false unless(split_e[0..-2] == split_p[0..-2])
20
- split_e[-1].sub(TESTUNIT_RB_FILE, '') == split_p[-1]
21
- end
22
- return backtrace unless(backtrace.detect(&match))
23
- found_prefix = false
24
- new_backtrace = backtrace.reverse.reject do |e|
25
- if(match[e])
26
- found_prefix = true
27
- true
28
- elsif(found_prefix)
29
- false
30
- else
31
- true
32
- end
33
- end.reverse
34
- new_backtrace = (new_backtrace.empty? ? backtrace : new_backtrace)
35
- new_backtrace = new_backtrace.reject(&match)
36
- new_backtrace.empty? ? backtrace : new_backtrace
37
- end
38
- end
39
- end
40
- end
41
- end
@@ -1,28 +0,0 @@
1
- module Test
2
- module Unit
3
- module Util
4
- module MethodOwnerFinder
5
- module_function
6
- def find(object, method_name)
7
- method = object.method(method_name)
8
- return method.owner if method.respond_to?(:owner)
9
-
10
- if /\((.+?)\)\#/ =~ method.to_s
11
- owner_name = $1
12
- if /\A#</ =~ owner_name
13
- ObjectSpace.each_object(Module) do |mod|
14
- return mod if mod.to_s == owner_name
15
- end
16
- else
17
- owner_name.split(/::/).inject(Object) do |parent, name|
18
- parent.const_get(name)
19
- end
20
- end
21
- else
22
- object.class
23
- end
24
- end
25
- end
26
- end
27
- end
28
- end
@@ -1,90 +0,0 @@
1
- #--
2
- #
3
- # Author:: Nathaniel Talbott.
4
- # Copyright:: Copyright (c) 2000-2002 Nathaniel Talbott. All rights reserved.
5
- # License:: Ruby license.
6
-
7
- require 'test/unit/util/procwrapper'
8
-
9
- module Test
10
- module Unit
11
- module Util
12
-
13
- # This is a utility class that allows anything mixing
14
- # it in to notify a set of listeners about interesting
15
- # events.
16
- module Observable
17
- # We use this for defaults since nil might mean something
18
- NOTHING = "NOTHING/#{__id__}"
19
-
20
- # Adds the passed proc as a listener on the
21
- # channel indicated by channel_name. listener_key
22
- # is used to remove the listener later; if none is
23
- # specified, the proc itself is used.
24
- #
25
- # Whatever is used as the listener_key is
26
- # returned, making it very easy to use the proc
27
- # itself as the listener_key:
28
- #
29
- # listener = add_listener("Channel") { ... }
30
- # remove_listener("Channel", listener)
31
- def add_listener(channel_name, listener_key=NOTHING, &listener) # :yields: value
32
- unless(block_given?)
33
- raise ArgumentError.new("No callback was passed as a listener")
34
- end
35
-
36
- key = listener_key
37
- if (listener_key == NOTHING)
38
- listener_key = listener
39
- key = ProcWrapper.new(listener)
40
- end
41
-
42
- channels[channel_name] ||= {}
43
- channels[channel_name][key] = listener
44
- return listener_key
45
- end
46
-
47
- # Removes the listener indicated by listener_key
48
- # from the channel indicated by
49
- # channel_name. Returns the registered proc, or
50
- # nil if none was found.
51
- def remove_listener(channel_name, listener_key)
52
- channel = channels[channel_name]
53
- return nil unless (channel)
54
- key = listener_key
55
- if (listener_key.instance_of?(Proc))
56
- key = ProcWrapper.new(listener_key)
57
- end
58
- if (channel.has_key?(key))
59
- return channel.delete(key)
60
- end
61
- return nil
62
- end
63
-
64
- # Calls all the procs registered on the channel
65
- # indicated by channel_name. If value is
66
- # specified, it is passed in to the procs,
67
- # otherwise they are called with no arguments.
68
- #
69
- #--
70
- #
71
- # Perhaps this should be private? Would it ever
72
- # make sense for an external class to call this
73
- # method directly?
74
- def notify_listeners(channel_name, *arguments)
75
- channel = channels[channel_name]
76
- return 0 unless (channel)
77
- listeners = channel.values
78
- listeners.each { |listener| listener.call(*arguments) }
79
- return listeners.size
80
- end
81
-
82
- private
83
- def channels
84
- @channels ||= {}
85
- return @channels
86
- end
87
- end
88
- end
89
- end
90
- end