<?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&amp;height=550&amp;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">&gt;</span> <span class="ruby-identifier">logger</span>,
                                  <span class="ruby-identifier">:timestamp</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-identifier">timestamp</span>,
                                  <span class="ruby-identifier">:level</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-identifier">level</span>,
                                  <span class="ruby-identifier">:thread</span> =<span class="ruby-operator">&gt;</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">&gt;</span> <span class="ruby-value str">''</span>,
                                     <span class="ruby-identifier">:method</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-identifier">method</span>,
                                     <span class="ruby-identifier">:file</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-identifier">file</span>,
                                     <span class="ruby-identifier">:line</span> =<span class="ruby-operator">&gt;</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">&gt;</span> <span class="ruby-identifier">key</span>, <span class="ruby-identifier">:value</span> =<span class="ruby-operator">&gt;</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>