1 <?xml version="1.0" encoding="utf-8"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
4 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
6 <meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
8 <title>Class: MCollective::Logger::Base</title>
10 <link rel="stylesheet" href="../../rdoc.css" type="text/css" media="screen" />
12 <script src="../../js/jquery.js" type="text/javascript"
13 charset="utf-8"></script>
14 <script src="../../js/thickbox-compressed.js" type="text/javascript"
15 charset="utf-8"></script>
16 <script src="../../js/quicksearch.js" type="text/javascript"
17 charset="utf-8"></script>
18 <script src="../../js/darkfish.js" type="text/javascript"
19 charset="utf-8"></script>
25 <div id="file-metadata">
26 <div id="file-list-section" class="section">
27 <h3 class="section-header">In Files</h3>
28 <div class="section-body">
31 <li><a href="../../lib/mcollective/logger/base_rb.html?TB_iframe=true&height=550&width=785"
32 class="thickbox" title="lib/mcollective/logger/base.rb">lib/mcollective/logger/base.rb</a></li>
41 <div id="class-metadata">
45 <div id="parent-class-section" class="section">
46 <h3 class="section-header">Parent</h3>
48 <p class="link"><a href="../../Object.html">Object</a></p>
53 <!-- Namespace Contents -->
56 <!-- Method Quickref -->
58 <div id="method-list-section" class="section">
59 <h3 class="section-header">Methods</h3>
60 <ul class="link-list">
62 <li><a href="#M000166">::new</a></li>
64 <li><a href="#M000168">#cycle_level</a></li>
66 <li><a href="#M000171">#get_next_level</a></li>
68 <li><a href="#M000173">#log</a></li>
70 <li><a href="#M000170">#map_level</a></li>
72 <li><a href="#M000169">#set_level</a></li>
74 <li><a href="#M000167">#should_log?</a></li>
76 <li><a href="#M000174">#start</a></li>
78 <li><a href="#M000172">#valid_levels</a></li>
84 <!-- Included Modules -->
88 <div id="project-metadata">
91 <div id="fileindex-section" class="section project-section">
92 <h3 class="section-header">Files</h3>
95 <li class="file"><a href="../../COPYING.html">COPYING</a></li>
97 <li class="file"><a href="../../Gemfile.html">Gemfile</a></li>
99 <li class="file"><a href="../../README.html">README</a></li>
101 <li class="file"><a href="../../Rakefile.html">Rakefile</a></li>
103 <li class="file"><a href="../../etc/client_cfg_dist.html">client.cfg.dist</a></li>
105 <li class="file"><a href="../../etc/data-help_erb.html">data-help.erb</a></li>
107 <li class="file"><a href="../../etc/discovery-help_erb.html">discovery-help.erb</a></li>
109 <li class="file"><a href="../../etc/facts_yaml_dist.html">facts.yaml.dist</a></li>
111 <li class="file"><a href="../../etc/metadata-help_erb.html">metadata-help.erb</a></li>
113 <li class="file"><a href="../../etc/msg-help_erb.html">msg-help.erb</a></li>
115 <li class="file"><a href="../../etc/rpc-help_erb.html">rpc-help.erb</a></li>
117 <li class="file"><a href="../../etc/server_cfg_dist.html">server.cfg.dist</a></li>
119 <li class="file"><a href="../../etc/ssl/PLACEHOLDER.html">PLACEHOLDER</a></li>
121 <li class="file"><a href="../../etc/ssl/clients/PLACEHOLDER.html">PLACEHOLDER</a></li>
123 <li class="file"><a href="../../lib/mcollective/generators/templates/action_snippet_erb.html">action_snippet.erb</a></li>
125 <li class="file"><a href="../../lib/mcollective/generators/templates/data_input_snippet_erb.html">data_input_snippet.erb</a></li>
127 <li class="file"><a href="../../lib/mcollective/generators/templates/ddl_erb.html">ddl.erb</a></li>
129 <li class="file"><a href="../../lib/mcollective/generators/templates/plugin_erb.html">plugin.erb</a></li>
131 <li class="file"><a href="../../lib/mcollective/locales/en_yml.html">en.yml</a></li>
133 <li class="file"><a href="../../mcollective_init.html">mcollective.init</a></li>
139 <div id="classindex-section" class="section project-section">
140 <h3 class="section-header">Class Index
141 <span class="search-toggle"><img src="../../images/find.png"
142 height="16" width="16" alt="[+]"
143 title="show/hide quicksearch" /></span></h3>
144 <form action="#" method="get" accept-charset="utf-8" class="initially-hidden">
146 <legend>Quicksearch</legend>
147 <input type="text" name="quicksearch" value=""
148 class="quicksearch-field" />
152 <ul class="link-list">
154 <li><a href="../../MCollective.html">MCollective</a></li>
156 <li><a href="../../MCollective/Agent.html">MCollective::Agent</a></li>
158 <li><a href="../../MCollective/Agents.html">MCollective::Agents</a></li>
160 <li><a href="../../MCollective/Aggregate.html">MCollective::Aggregate</a></li>
162 <li><a href="../../MCollective/Aggregate/Base.html">MCollective::Aggregate::Base</a></li>
164 <li><a href="../../MCollective/Aggregate/Result.html">MCollective::Aggregate::Result</a></li>
166 <li><a href="../../MCollective/Aggregate/Result/Base.html">MCollective::Aggregate::Result::Base</a></li>
168 <li><a href="../../MCollective/Aggregate/Result/CollectionResult.html">MCollective::Aggregate::Result::CollectionResult</a></li>
170 <li><a href="../../MCollective/Aggregate/Result/NumericResult.html">MCollective::Aggregate::Result::NumericResult</a></li>
172 <li><a href="../../MCollective/Application.html">MCollective::Application</a></li>
174 <li><a href="../../MCollective/Applications.html">MCollective::Applications</a></li>
176 <li><a href="../../MCollective/Cache.html">MCollective::Cache</a></li>
178 <li><a href="../../MCollective/Client.html">MCollective::Client</a></li>
180 <li><a href="../../MCollective/CodedError.html">MCollective::CodedError</a></li>
182 <li><a href="../../MCollective/Config.html">MCollective::Config</a></li>
184 <li><a href="../../MCollective/Connector.html">MCollective::Connector</a></li>
186 <li><a href="../../MCollective/Connector/Base.html">MCollective::Connector::Base</a></li>
188 <li><a href="../../MCollective/DDL.html">MCollective::DDL</a></li>
190 <li><a href="../../MCollective/DDL/AgentDDL.html">MCollective::DDL::AgentDDL</a></li>
192 <li><a href="../../MCollective/DDL/Base.html">MCollective::DDL::Base</a></li>
194 <li><a href="../../MCollective/DDL/DataDDL.html">MCollective::DDL::DataDDL</a></li>
196 <li><a href="../../MCollective/DDL/DiscoveryDDL.html">MCollective::DDL::DiscoveryDDL</a></li>
198 <li><a href="../../MCollective/DDL/ValidatorDDL.html">MCollective::DDL::ValidatorDDL</a></li>
200 <li><a href="../../MCollective/DDLValidationError.html">MCollective::DDLValidationError</a></li>
202 <li><a href="../../MCollective/Data.html">MCollective::Data</a></li>
204 <li><a href="../../MCollective/Data/Base.html">MCollective::Data::Base</a></li>
206 <li><a href="../../MCollective/Data/Result.html">MCollective::Data::Result</a></li>
208 <li><a href="../../MCollective/Discovery.html">MCollective::Discovery</a></li>
210 <li><a href="../../MCollective/Facts.html">MCollective::Facts</a></li>
212 <li><a href="../../MCollective/Facts/Base.html">MCollective::Facts::Base</a></li>
214 <li><a href="../../MCollective/Generators.html">MCollective::Generators</a></li>
216 <li><a href="../../MCollective/Generators/AgentGenerator.html">MCollective::Generators::AgentGenerator</a></li>
218 <li><a href="../../MCollective/Generators/Base.html">MCollective::Generators::Base</a></li>
220 <li><a href="../../MCollective/Generators/DataGenerator.html">MCollective::Generators::DataGenerator</a></li>
222 <li><a href="../../MCollective/InvalidRPCData.html">MCollective::InvalidRPCData</a></li>
224 <li><a href="../../MCollective/Log.html">MCollective::Log</a></li>
226 <li><a href="../../MCollective/Logger.html">MCollective::Logger</a></li>
228 <li><a href="../../MCollective/Logger/Base.html">MCollective::Logger::Base</a></li>
230 <li><a href="../../MCollective/Logger/Console_logger.html">MCollective::Logger::Console_logger</a></li>
232 <li><a href="../../MCollective/Logger/File_logger.html">MCollective::Logger::File_logger</a></li>
234 <li><a href="../../MCollective/Logger/Syslog_logger.html">MCollective::Logger::Syslog_logger</a></li>
236 <li><a href="../../MCollective/Matcher.html">MCollective::Matcher</a></li>
238 <li><a href="../../MCollective/Matcher/Parser.html">MCollective::Matcher::Parser</a></li>
240 <li><a href="../../MCollective/Matcher/Scanner.html">MCollective::Matcher::Scanner</a></li>
242 <li><a href="../../MCollective/Message.html">MCollective::Message</a></li>
244 <li><a href="../../MCollective/MissingRPCData.html">MCollective::MissingRPCData</a></li>
246 <li><a href="../../MCollective/MsgDoesNotMatchRequestID.html">MCollective::MsgDoesNotMatchRequestID</a></li>
248 <li><a href="../../MCollective/MsgTTLExpired.html">MCollective::MsgTTLExpired</a></li>
250 <li><a href="../../MCollective/NotTargettedAtUs.html">MCollective::NotTargettedAtUs</a></li>
252 <li><a href="../../MCollective/Optionparser.html">MCollective::Optionparser</a></li>
254 <li><a href="../../MCollective/PluginManager.html">MCollective::PluginManager</a></li>
256 <li><a href="../../MCollective/PluginPackager.html">MCollective::PluginPackager</a></li>
258 <li><a href="../../MCollective/PluginPackager/AgentDefinition.html">MCollective::PluginPackager::AgentDefinition</a></li>
260 <li><a href="../../MCollective/PluginPackager/StandardDefinition.html">MCollective::PluginPackager::StandardDefinition</a></li>
262 <li><a href="../../MCollective/RPC.html">MCollective::RPC</a></li>
264 <li><a href="../../MCollective/RPC/ActionRunner.html">MCollective::RPC::ActionRunner</a></li>
266 <li><a href="../../MCollective/RPC/Agent.html">MCollective::RPC::Agent</a></li>
268 <li><a href="../../MCollective/RPC/Audit.html">MCollective::RPC::Audit</a></li>
270 <li><a href="../../MCollective/RPC/Client.html">MCollective::RPC::Client</a></li>
272 <li><a href="../../MCollective/RPC/Helpers.html">MCollective::RPC::Helpers</a></li>
274 <li><a href="../../MCollective/RPC/Progress.html">MCollective::RPC::Progress</a></li>
276 <li><a href="../../MCollective/RPC/Reply.html">MCollective::RPC::Reply</a></li>
278 <li><a href="../../MCollective/RPC/Request.html">MCollective::RPC::Request</a></li>
280 <li><a href="../../MCollective/RPC/Result.html">MCollective::RPC::Result</a></li>
282 <li><a href="../../MCollective/RPC/Stats.html">MCollective::RPC::Stats</a></li>
284 <li><a href="../../MCollective/RPCAborted.html">MCollective::RPCAborted</a></li>
286 <li><a href="../../MCollective/RPCError.html">MCollective::RPCError</a></li>
288 <li><a href="../../MCollective/Registration.html">MCollective::Registration</a></li>
290 <li><a href="../../MCollective/Registration/Base.html">MCollective::Registration::Base</a></li>
292 <li><a href="../../MCollective/Runner.html">MCollective::Runner</a></li>
294 <li><a href="../../MCollective/RunnerStats.html">MCollective::RunnerStats</a></li>
296 <li><a href="../../MCollective/SSL.html">MCollective::SSL</a></li>
298 <li><a href="../../MCollective/Security.html">MCollective::Security</a></li>
300 <li><a href="../../MCollective/Security/Base.html">MCollective::Security::Base</a></li>
302 <li><a href="../../MCollective/SecurityValidationFailed.html">MCollective::SecurityValidationFailed</a></li>
304 <li><a href="../../MCollective/Shell.html">MCollective::Shell</a></li>
306 <li><a href="../../MCollective/Translatable.html">MCollective::Translatable</a></li>
308 <li><a href="../../MCollective/UnixDaemon.html">MCollective::UnixDaemon</a></li>
310 <li><a href="../../MCollective/UnknownRPCAction.html">MCollective::UnknownRPCAction</a></li>
312 <li><a href="../../MCollective/UnknownRPCError.html">MCollective::UnknownRPCError</a></li>
314 <li><a href="../../MCollective/Util.html">MCollective::Util</a></li>
316 <li><a href="../../MCollective/Validator.html">MCollective::Validator</a></li>
318 <li><a href="../../MCollective/ValidatorError.html">MCollective::ValidatorError</a></li>
320 <li><a href="../../MCollective/WindowsDaemon.html">MCollective::WindowsDaemon</a></li>
322 <li><a href="../../Array.html">Array</a></li>
324 <li><a href="../../Dir.html">Dir</a></li>
326 <li><a href="../../Object.html">Object</a></li>
328 <li><a href="../../String.html">String</a></li>
330 <li><a href="../../Symbol.html">Symbol</a></li>
333 <div id="no-class-search-results" style="display: none;">No matching classes.</div>
340 <div id="documentation">
341 <h1 class="class">MCollective::Logger::Base</h1>
343 <div id="description">
345 A base class for logging providers.
348 Logging providers should provide the following:
351 * start - all you need to do to setup your logging
352 * set_logging_level - set your logging to :info, :warn, etc
353 * valid_levels - a hash of maps from :info to your internal level name
354 * log - what needs to be done to log a specific message
364 <div id="attribute-method-details" class="method-section section">
365 <h3 class="section-header">Attributes</h3>
368 <div id="active-level-attribute-method" class="method-detail">
369 <a name="active_level"></a>
371 <div class="method-heading attribute-method-heading">
372 <span class="method-name">active_level</span><span
373 class="attribute-access-type">[R]</span>
376 <div class="method-description">
378 <p class="missing-docs">(Not documented)</p>
388 <div id="public-class-method-details" class="method-section section">
389 <h3 class="section-header">Public Class Methods</h3>
392 <div id="new-method" class="method-detail ">
393 <a name="M000166"></a>
395 <div class="method-heading">
397 <span class="method-name">new</span><span
398 class="method-args">()</span>
399 <span class="method-click-advice">click to toggle source</span>
403 <div class="method-description">
405 <p class="missing-docs">(Not documented)</p>
409 <div class="method-source-code"
412 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 14</span>
413 14: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">initialize</span>
414 15: <span class="ruby-ivar">@known_levels</span> = [<span class="ruby-identifier">:debug</span>, <span class="ruby-identifier">:info</span>, <span class="ruby-identifier">:warn</span>, <span class="ruby-identifier">:error</span>, <span class="ruby-identifier">:fatal</span>]
416 17: <span class="ruby-comment cmt"># Sanity check the class that impliments the logging</span>
417 18: <span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">lvl</span><span class="ruby-operator">|</span>
418 19: <span class="ruby-identifier">raise</span> <span class="ruby-node">"Logger class did not specify a map for #{lvl}"</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">valid_levels</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">lvl</span>)
419 20: <span class="ruby-keyword kw">end</span>
420 21: <span class="ruby-keyword kw">end</span></pre>
431 <div id="public-instance-method-details" class="method-section section">
432 <h3 class="section-header">Public Instance Methods</h3>
435 <div id="cycle-level-method" class="method-detail ">
436 <a name="M000168"></a>
438 <div class="method-heading">
440 <span class="method-name">cycle_level</span><span
441 class="method-args">()</span>
442 <span class="method-click-advice">click to toggle source</span>
446 <div class="method-description">
449 Figures out the next level and sets it
454 <div class="method-source-code"
455 id="cycle-level-source">
457 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 28</span>
458 28: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">cycle_level</span>
459 29: <span class="ruby-identifier">lvl</span> = <span class="ruby-identifier">get_next_level</span>
460 30: <span class="ruby-identifier">set_level</span>(<span class="ruby-identifier">lvl</span>)
462 32: <span class="ruby-identifier">log</span>(<span class="ruby-identifier">lvl</span>, <span class="ruby-value str">""</span>, <span class="ruby-node">"Logging level is now #{lvl.to_s.upcase}"</span>)
463 33: <span class="ruby-keyword kw">end</span></pre>
472 <div id="set-level-method" class="method-detail ">
473 <a name="M000169"></a>
475 <div class="method-heading">
477 <span class="method-name">set_level</span><span
478 class="method-args">(level)</span>
479 <span class="method-click-advice">click to toggle source</span>
483 <div class="method-description">
486 Sets a new level and record it in @<a
487 href="Base.html#active_level">active_level</a>
492 <div class="method-source-code"
493 id="set-level-source">
495 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 36</span>
496 36: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">set_level</span>(<span class="ruby-identifier">level</span>)
497 37: <span class="ruby-identifier">set_logging_level</span>(<span class="ruby-identifier">level</span>)
498 38: <span class="ruby-ivar">@active_level</span> = <span class="ruby-identifier">level</span>.<span class="ruby-identifier">to_sym</span>
499 39: <span class="ruby-keyword kw">end</span></pre>
508 <div id="should-log--method" class="method-detail ">
509 <a name="M000167"></a>
511 <div class="method-heading">
513 <span class="method-name">should_log?</span><span
514 class="method-args">(level)</span>
515 <span class="method-click-advice">click to toggle source</span>
519 <div class="method-description">
521 <p class="missing-docs">(Not documented)</p>
525 <div class="method-source-code"
526 id="should-log--source">
528 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 23</span>
529 23: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">should_log?</span>(<span class="ruby-identifier">level</span>)
530 24: <span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">index</span>(<span class="ruby-identifier">level</span>) <span class="ruby-operator">>=</span> <span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">index</span>(<span class="ruby-ivar">@active_level</span>)
531 25: <span class="ruby-keyword kw">end</span></pre>
542 <div id="private-instance-method-details" class="method-section section">
543 <h3 class="section-header">Private Instance Methods</h3>
546 <div id="get-next-level-method" class="method-detail ">
547 <a name="M000171"></a>
549 <div class="method-heading">
551 <span class="method-name">get_next_level</span><span
552 class="method-args">()</span>
553 <span class="method-click-advice">click to toggle source</span>
557 <div class="method-description">
560 Gets the next level in the list, cycles down to the firt once it reaches
566 <div class="method-source-code"
567 id="get-next-level-source">
569 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 49</span>
570 49: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">get_next_level</span>
571 50: <span class="ruby-comment cmt"># if all else fails, always go to debug mode</span>
572 51: <span class="ruby-identifier">nextlvl</span> = <span class="ruby-identifier">:debug</span>
574 53: <span class="ruby-keyword kw">if</span> <span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">index</span>(<span class="ruby-ivar">@active_level</span>) <span class="ruby-operator">==</span> (<span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">size</span> <span class="ruby-operator">-</span> <span class="ruby-value">1</span>)
575 54: <span class="ruby-identifier">nextlvl</span> = <span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">first</span>
576 55: <span class="ruby-keyword kw">else</span>
577 56: <span class="ruby-identifier">idx</span> = <span class="ruby-ivar">@known_levels</span>.<span class="ruby-identifier">index</span>(<span class="ruby-ivar">@active_level</span>) <span class="ruby-operator">+</span> <span class="ruby-value">1</span>
578 57: <span class="ruby-identifier">nextlvl</span> = <span class="ruby-ivar">@known_levels</span>[<span class="ruby-identifier">idx</span>]
579 58: <span class="ruby-keyword kw">end</span>
581 60: <span class="ruby-identifier">nextlvl</span>
582 61: <span class="ruby-keyword kw">end</span></pre>
591 <div id="log-method" class="method-detail ">
592 <a name="M000173"></a>
594 <div class="method-heading">
596 <span class="method-name">log</span><span
597 class="method-args">(level, from, msg)</span>
598 <span class="method-click-advice">click to toggle source</span>
602 <div class="method-description">
604 <p class="missing-docs">(Not documented)</p>
608 <div class="method-source-code"
611 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 68</span>
612 68: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">log</span>(<span class="ruby-identifier">level</span>, <span class="ruby-identifier">from</span>, <span class="ruby-identifier">msg</span>)
613 69: <span class="ruby-identifier">raise</span> <span class="ruby-value str">"The logging class did not supply a log method"</span>
614 70: <span class="ruby-keyword kw">end</span></pre>
623 <div id="map-level-method" class="method-detail ">
624 <a name="M000170"></a>
626 <div class="method-heading">
628 <span class="method-name">map_level</span><span
629 class="method-args">(level)</span>
630 <span class="method-click-advice">click to toggle source</span>
634 <div class="method-description">
636 <p class="missing-docs">(Not documented)</p>
640 <div class="method-source-code"
641 id="map-level-source">
643 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 42</span>
644 42: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">map_level</span>(<span class="ruby-identifier">level</span>)
645 43: <span class="ruby-identifier">raise</span> <span class="ruby-node">"Logger class do not know how to handle #{level} messages"</span> <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">valid_levels</span>.<span class="ruby-identifier">include?</span>(<span class="ruby-identifier">level</span>.<span class="ruby-identifier">to_sym</span>)
647 45: <span class="ruby-identifier">valid_levels</span>[<span class="ruby-identifier">level</span>.<span class="ruby-identifier">to_sym</span>]
648 46: <span class="ruby-keyword kw">end</span></pre>
657 <div id="start-method" class="method-detail ">
658 <a name="M000174"></a>
660 <div class="method-heading">
662 <span class="method-name">start</span><span
663 class="method-args">()</span>
664 <span class="method-click-advice">click to toggle source</span>
668 <div class="method-description">
670 <p class="missing-docs">(Not documented)</p>
674 <div class="method-source-code"
677 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 72</span>
678 72: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">start</span>
679 73: <span class="ruby-identifier">raise</span> <span class="ruby-value str">"The logging class did not supply a start method"</span>
680 74: <span class="ruby-keyword kw">end</span></pre>
689 <div id="valid-levels-method" class="method-detail ">
690 <a name="M000172"></a>
692 <div class="method-heading">
694 <span class="method-name">valid_levels</span><span
695 class="method-args">()</span>
696 <span class="method-click-advice">click to toggle source</span>
700 <div class="method-description">
703 Abstract methods to ensure the logging implimentations supply what they
709 <div class="method-source-code"
710 id="valid-levels-source">
712 <span class="ruby-comment cmt"># File lib/mcollective/logger/base.rb, line 64</span>
713 64: <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">valid_levels</span>
714 65: <span class="ruby-identifier">raise</span> <span class="ruby-value str">"The logging class did not supply a valid_levels method"</span>
715 66: <span class="ruby-keyword kw">end</span></pre>
730 <div id="rdoc-debugging-section-dump" class="debugging-section">
732 <p>Disabled; run with --debug to generate this.</p>
736 <div id="validator-badges">
737 <p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
738 <p><small>Generated with the <a href="http://deveiate.org/projects/Darkfish-Rdoc/">Darkfish
739 Rdoc Generator</a> 1.1.6</small>.</p>