<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta content="text/html; charset=utf-8" http-equiv="Content-Type" /> <title>Class: Log4r::Log4jXmlFormatter</title> <link rel="stylesheet" href="../rdoc.css" type="text/css" media="screen" /> <script src="../js/jquery.js" type="text/javascript" charset="utf-8"></script> <script src="../js/thickbox-compressed.js" type="text/javascript" charset="utf-8"></script> <script src="../js/quicksearch.js" type="text/javascript" charset="utf-8"></script> <script src="../js/darkfish.js" type="text/javascript" charset="utf-8"></script> </head> <body class="class"> <div id="metadata"> <div id="file-metadata"> <div id="file-list-section" class="section"> <h3 class="section-header">In Files</h3> <div class="section-body"> <ul> <li><a href="../log4r/formatter/log4jxmlformatter_rb.html?TB_iframe=true&height=550&width=785" class="thickbox" title="log4r/formatter/log4jxmlformatter.rb">log4r/formatter/log4jxmlformatter.rb</a></li> </ul> </div> </div> </div> <div id="class-metadata"> <!-- Parent Class --> <div id="parent-class-section" class="section"> <h3 class="section-header">Parent</h3> <p class="link">BasicFormatter</p> </div> <!-- Namespace Contents --> <!-- Method Quickref --> <div id="method-list-section" class="section"> <h3 class="section-header">Methods</h3> <ul class="link-list"> <li><a href="#M000028">#format</a></li> <li><a href="#M000032">#parse_caller</a></li> </ul> </div> <!-- Included Modules --> </div> <div id="project-metadata"> <div id="fileindex-section" class="section project-section"> <h3 class="section-header">Files</h3> <ul> <li class="file"><a href="../log4r/rdoc/GDC.html">GDC</a></li> <li class="file"><a href="../log4r/rdoc/MDC.html">MDC</a></li> <li class="file"><a href="../log4r/rdoc/NDC.html">NDC</a></li> <li class="file"><a href="../log4r/rdoc/configurator.html">configurator</a></li> <li class="file"><a href="../log4r/rdoc/emailoutputter.html">emailoutputter</a></li> <li class="file"><a href="../log4r/rdoc/formatter.html">formatter</a></li> <li class="file"><a href="../log4r/rdoc/log4r.html">log4r</a></li> <li class="file"><a href="../log4r/rdoc/logger.html">logger</a></li> <li class="file"><a href="../log4r/rdoc/logserver.html">logserver</a></li> <li class="file"><a href="../log4r/rdoc/outputter.html">outputter</a></li> <li class="file"><a href="../log4r/rdoc/patternformatter.html">patternformatter</a></li> <li class="file"><a href="../log4r/rdoc/syslogoutputter.html">syslogoutputter</a></li> <li class="file"><a href="../log4r/rdoc/win32eventoutputter.html">win32eventoutputter</a></li> <li class="file"><a href="../log4r/rdoc/yamlconfigurator.html">yamlconfigurator</a></li> </ul> </div> <div id="classindex-section" class="section project-section"> <h3 class="section-header">Class Index <span class="search-toggle"><img src="../images/find.png" height="16" width="16" alt="[+]" title="show/hide quicksearch" /></span></h3> <form action="#" method="get" accept-charset="utf-8" class="initially-hidden"> <fieldset> <legend>Quicksearch</legend> <input type="text" name="quicksearch" value="" class="quicksearch-field" /> </fieldset> </form> <ul class="link-list"> <li><a href="../Log4r.html">Log4r</a></li> <li><a href="../Log4r/BasicFormatter.html">Log4r::BasicFormatter</a></li> <li><a href="../Log4r/ConfigError.html">Log4r::ConfigError</a></li> <li><a href="../Log4r/Configurator.html">Log4r::Configurator</a></li> <li><a href="../Log4r/DateFileOutputter.html">Log4r::DateFileOutputter</a></li> <li><a href="../Log4r/DefaultFormatter.html">Log4r::DefaultFormatter</a></li> <li><a href="../Log4r/EmailOutputter.html">Log4r::EmailOutputter</a></li> <li><a href="../Log4r/FileOutputter.html">Log4r::FileOutputter</a></li> <li><a href="../Log4r/Formatter.html">Log4r::Formatter</a></li> <li><a href="../Log4r/GDC.html">Log4r::GDC</a></li> <li><a href="../Log4r/IOOutputter.html">Log4r::IOOutputter</a></li> <li><a href="../Log4r/Log4jXmlFormatter.html">Log4r::Log4jXmlFormatter</a></li> <li><a href="../Log4r/Log4rTools.html">Log4r::Log4rTools</a></li> <li><a href="../Log4r/LogEvent.html">Log4r::LogEvent</a></li> <li><a href="../Log4r/LogServer.html">Log4r::LogServer</a></li> <li><a href="../Log4r/Logger.html">Log4r::Logger</a></li> <li><a href="../Log4r/MDC.html">Log4r::MDC</a></li> <li><a href="../Log4r/NDC.html">Log4r::NDC</a></li> <li><a href="../Log4r/ObjectFormatter.html">Log4r::ObjectFormatter</a></li> <li><a href="../Log4r/Outputter.html">Log4r::Outputter</a></li> <li><a href="../Log4r/PatternFormatter.html">Log4r::PatternFormatter</a></li> <li><a href="../Log4r/RemoteOutputter.html">Log4r::RemoteOutputter</a></li> <li><a href="../Log4r/RollingFileOutputter.html">Log4r::RollingFileOutputter</a></li> <li><a href="../Log4r/RootLogger.html">Log4r::RootLogger</a></li> <li><a href="../Log4r/SimpleFormatter.html">Log4r::SimpleFormatter</a></li> <li><a href="../Log4r/StderrOutputter.html">Log4r::StderrOutputter</a></li> <li><a href="../Log4r/StdoutOutputter.html">Log4r::StdoutOutputter</a></li> <li><a href="../Log4r/SyslogOutputter.html">Log4r::SyslogOutputter</a></li> <li><a href="../Log4r/UDPOutputter.html">Log4r::UDPOutputter</a></li> <li><a href="../Log4r/YamlConfigurator.html">Log4r::YamlConfigurator</a></li> </ul> <div id="no-class-search-results" style="display: none;">No matching classes.</div> </div> </div> </div> <div id="documentation"> <h1 class="class">Log4r::Log4jXmlFormatter</h1> <div id="description"> </div> <!-- Constants --> <!-- Attributes --> <!-- Methods --> <div id="public-instance-method-details" class="method-section section"> <h3 class="section-header">Public Instance Methods</h3> <div id="format-method" class="method-detail "> <a name="M000028"></a> <div class="method-heading"> <span class="method-name">format</span><span class="method-args">(logevent)</span> <span class="method-click-advice">click to toggle source</span> </div> <div class="method-description"> <p class="missing-docs">(Not documented)</p> <div class="method-source-code" id="format-source"> <pre> <span class="ruby-comment cmt"># File log4r/formatter/log4jxmlformatter.rb, line 16</span> <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">format</span>(<span class="ruby-identifier">logevent</span>) <span class="ruby-identifier">logger</span> = <span class="ruby-identifier">logevent</span>.<span class="ruby-identifier">fullname</span>.<span class="ruby-identifier">gsub</span>(<span class="ruby-value str">'::'</span>, <span class="ruby-value str">'.'</span>) <span class="ruby-identifier">timestamp</span> = (<span class="ruby-constant">Time</span>.<span class="ruby-identifier">now</span>.<span class="ruby-identifier">to_f</span> <span class="ruby-operator">*</span> <span class="ruby-value">1000</span>).<span class="ruby-identifier">to_i</span> <span class="ruby-identifier">level</span> = <span class="ruby-constant">LNAMES</span>[<span class="ruby-identifier">logevent</span>.<span class="ruby-identifier">level</span>] <span class="ruby-identifier">message</span> = <span class="ruby-identifier">format_object</span>(<span class="ruby-identifier">logevent</span>.<span class="ruby-identifier">data</span>) <span class="ruby-identifier">exception</span> = <span class="ruby-identifier">message</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">logevent</span>.<span class="ruby-identifier">data</span>.<span class="ruby-identifier">kind_of?</span> <span class="ruby-constant">Exception</span> <span class="ruby-identifier">file</span>, <span class="ruby-identifier">line</span>, <span class="ruby-identifier">method</span> = <span class="ruby-identifier">parse_caller</span>(<span class="ruby-identifier">logevent</span>.<span class="ruby-identifier">tracer</span>[<span class="ruby-value">0</span>]) <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">logevent</span>.<span class="ruby-identifier">tracer</span> <span class="ruby-identifier">builder</span> = <span class="ruby-constant">Builder</span><span class="ruby-operator">::</span><span class="ruby-constant">XmlMarkup</span>.<span class="ruby-identifier">new</span> <span class="ruby-identifier">xml</span> = <span class="ruby-identifier">builder</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:event</span>, <span class="ruby-identifier">:logger</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">logger</span>, <span class="ruby-identifier">:timestamp</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">timestamp</span>, <span class="ruby-identifier">:level</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">level</span>, <span class="ruby-identifier">:thread</span> =<span class="ruby-operator">></span> <span class="ruby-value str">''</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">e</span><span class="ruby-operator">|</span> <span class="ruby-identifier">e</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:NDC</span>, <span class="ruby-constant">NDC</span>.<span class="ruby-identifier">get</span> <span class="ruby-identifier">e</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:message</span>, <span class="ruby-identifier">message</span> <span class="ruby-identifier">e</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:throwable</span>, <span class="ruby-identifier">exception</span> <span class="ruby-keyword kw">if</span> <span class="ruby-identifier">exception</span> <span class="ruby-identifier">e</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:locationInfo</span>, <span class="ruby-identifier">:class</span> =<span class="ruby-operator">></span> <span class="ruby-value str">''</span>, <span class="ruby-identifier">:method</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">method</span>, <span class="ruby-identifier">:file</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">file</span>, <span class="ruby-identifier">:line</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">line</span> <span class="ruby-identifier">e</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:properties</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">p</span><span class="ruby-operator">|</span> <span class="ruby-constant">MDC</span>.<span class="ruby-identifier">get_context</span>.<span class="ruby-identifier">each</span> <span class="ruby-keyword kw">do</span> <span class="ruby-operator">|</span><span class="ruby-identifier">key</span>, <span class="ruby-identifier">value</span><span class="ruby-operator">|</span> <span class="ruby-identifier">p</span>.<span class="ruby-identifier">log4j</span> <span class="ruby-identifier">:data</span>, <span class="ruby-identifier">:name</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">key</span>, <span class="ruby-identifier">:value</span> =<span class="ruby-operator">></span> <span class="ruby-identifier">value</span> <span class="ruby-keyword kw">end</span> <span class="ruby-keyword kw">end</span> <span class="ruby-keyword kw">end</span> <span class="ruby-identifier">xml</span> <span class="ruby-keyword kw">end</span></pre> </div> </div> </div> </div> <div id="private-instance-method-details" class="method-section section"> <h3 class="section-header">Private Instance Methods</h3> <div id="parse-caller-method" class="method-detail "> <a name="M000032"></a> <div class="method-heading"> <span class="method-name">parse_caller</span><span class="method-args">(line)</span> <span class="method-click-advice">click to toggle source</span> </div> <div class="method-description"> <div class="method-source-code" id="parse-caller-source"> <pre> <span class="ruby-comment cmt"># File log4r/formatter/log4jxmlformatter.rb, line 49</span> <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">parse_caller</span>(<span class="ruby-identifier">line</span>) <span class="ruby-keyword kw">if</span> <span class="ruby-regexp re">/^(.+?):(\d+)(?::in `(.*)')?/</span> <span class="ruby-operator">=~</span> <span class="ruby-identifier">line</span> <span class="ruby-identifier">file</span> = <span class="ruby-constant">Regexp</span>.<span class="ruby-identifier">last_match</span>[<span class="ruby-value">1</span>] <span class="ruby-identifier">line</span> = <span class="ruby-constant">Regexp</span>.<span class="ruby-identifier">last_match</span>[<span class="ruby-value">2</span>].<span class="ruby-identifier">to_i</span> <span class="ruby-identifier">method</span> = <span class="ruby-constant">Regexp</span>.<span class="ruby-identifier">last_match</span>[<span class="ruby-value">3</span>] [<span class="ruby-identifier">file</span>, <span class="ruby-identifier">line</span>, <span class="ruby-identifier">method</span>] <span class="ruby-keyword kw">else</span> [] <span class="ruby-keyword kw">end</span> <span class="ruby-keyword kw">end</span></pre> </div> </div> </div> </div> </div> <div id="rdoc-debugging-section-dump" class="debugging-section"> <p>Disabled; run with --debug to generate this.</p> </div> <div id="validator-badges"> <p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p> <p><small>Generated with the <a href="http://deveiate.org/projects/Darkfish-Rdoc/">Darkfish Rdoc Generator</a> 1.1.6</small>.</p> </div> </body> </html>