<div class="gmail_quote">Hey Denis. These are definitely questions worth asking and I&#39;ll consider incorporating the answers I&#39;ve included inline into the refdoc or an FAQ.</div><div class="gmail_quote"><br></div><div class="gmail_quote">

On Sun, Mar 20, 2011 at 11:32, Denis Forveille <span dir="ltr">&lt;<a href="mailto:denis.forveille@gmail.com">denis.forveille@gmail.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">



  
    
    
  
  <div text="#000000" bgcolor="#ffffff"><font face="Liberation Sans">Q and remarks about logging in Seam 3 and about your answer:<br>
    </font><font face="Liberation Sans">- I tough that slf4j was a
      &quot;logging back-end&quot;. I thought it was only another abstraction
      layer similar to commons-logging and JBoss-Logging. It seems over
      complicated that JBoss-logging (abstract layer) delegates to
      another abstract layer(slf4j) that delegates to a concrete
      implementation (log4j, JBoss-LogManager or JDK). You surely
      already discussed this before but it sounds strange for a newcomer
      in the world of Seam 3<br></font></div></blockquote><div><br></div><div>It depends on how you define logging backend. SLF4j is somewhat of a hybrid, as it offers it&#39;s own simpler logger, yet can also delegate to Log4j and JDK14. In a sense, it&#39;s like commons-logging.</div>

<div><br></div><div>When we say logging backend, we mean &quot;the concrete logging framework to which JBoss logging delegates&quot;. JBoss Logging does not have it&#39;s own logger. Really, it&#39;s not a logging framework, but rather a tool that introduces new features to the logging ecosystem. Those features are:</div>

<div><br></div><div>- typed message bundles and loggers</div><div>- internationalization support</div><div>- pluggable formatting for messages</div><div>- message codes</div><div>- serializable loggers</div><div>- injectable loggers (as provided by solder)</div>

<div><br></div><div>Thus, I would describe it as a programming model for logging, rather than a logging framework. The logger you use is up to you. If you provide no logging library, it just uses JDK14 logging, which is the leanest approach.</div>

<div><br></div><div>We didn&#39;t just settle on slf4j because it provides none of the features in the list above (or not sufficient for our vision).</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div text="#000000" bgcolor="#ffffff"><font face="Liberation Sans">
      <br>
      - The Seam 3 CR2 distributes one concrete log implementation
      (log4j) and JDK logger is implicitly there too. Why distribute
      log4j.jar and not JBoss LogManager.jar? It seems not consistent
      here. IMHO, either distribute both (as optional libs) or none and
      default to jdk, the &quot;default common log backend&quot; to all
      application servers<br></font></div></blockquote><div><br></div><div>That&#39;s a bug in the distribution then -&gt; jira. We should not be bundling any concrete log implementation. It should default to JDK14 unless you provide one of your own.</div>

<div><br></div><div>(Btw, there is a known problem with the reflection code that JBoss Logging uses to select a provider, and that needs to be fixed: JBLOGGING-57).</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div text="#000000" bgcolor="#ffffff"><font face="Liberation Sans">
      <br>
      - the way slf4j configure the logger backend is great and can not
      be simpler. I hope JBoss-logging will be as simple as slf4j in the
      future (just drop a jar that contains the binder and the backend
      impl jar)<br></font></div></blockquote><div><br></div><div>Yep, I agree it should be. It&#39;s nearly there, except for JBLOGGING-57. I&#39;d also like there to be way to select the provider explicitly JBLOGGING-58. Certainly room for improvement.</div>

<div><br></div><div>(I&#39;ll mention again for clarity, don&#39;t confuse JBoss Logging 3 with JBoss Log Manager, though the confusion is mostly on us).</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div text="#000000" bgcolor="#ffffff"><font face="Liberation Sans">
      <br>
      - I don&#39;t use maven yet and assemble the booking app in RSA v8.0
      by hand in a tentative to better understand what is needed to
      deploy. I try here to use as much as possible what is provided by
      WAS (JPA, JSF, CDI etc.) and so not to include &quot;alien
      implementation&quot; jars (hibernate, jsf-ri, weld, jboss-AS-loggers
      etc.) . </font>That not that easy considering that  WAS v8.0 is
    also a beta version.. Similar to what you had to live with JBoss-AS
    v6..<br></div></blockquote><div><br></div><div>You shouldn&#39;t have to include any such alien jars. In the case you do, there is a bug somewhere, either in Seam or in Websphere. Let&#39;s identify it and squash it when it happens.</div>

<div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"><div text="#000000" bgcolor="#ffffff">
    <br>
    <font face="Liberation Sans">I included </font>jboss-logmanager.jar
    in my app and was able to go a little further (slf4j complains about
    &quot;Class path contains multiple SLF4J bindings&quot;. i will sort this out
    later).<br></div></blockquote><div><br></div><div>Ignore SLF4J&#39;s lamenting. It whines too much.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div text="#000000" bgcolor="#ffffff">
    <br>
    I then had a problem with an illegal acces to the constructor of
    org.jboss.seam.servlet.ServletExtension. Declaring it &quot;public&quot;
    solved the problem. I didn&#39;t investigated to know if is is a bug of
    seam-servlet or in WAS<br></div></blockquote><div><br></div><div>That&#39;s fixed in the CR3 stack. We&#39;ve decide to make extensions public now because it was causing problems otherwise.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

<div text="#000000" bgcolor="#ffffff">
    <br>
    And now I&#39;m stuck wit the following exception at startup also
    related to logging:<br>
    Caused by: java.lang.IllegalArgumentException: Invalid bundle
    interface org.jboss.seam.servlet.messages.ServletMessages
    (implementation not found)<br>
        at
    org.jboss.seam.solder.logging.Messages.getBundle(Messages.java:92)<br>
        at
    org.jboss.seam.solder.logging.Messages.getBundle(Messages.java:54)<br>
        at
org.jboss.seam.servlet.ServletExtension.&lt;init&gt;(ServletExtension.java:70)<br></div></blockquote><div><br></div><div>You need the CR3 stack [1]. The version of Solder you have shipped without the typed logger implementation classes (see Solder documentation [2] or my blog entry [3] for details).</div>

<div><br></div><div>-Dan</div><div><br></div><div>[1] <a href="http://sourceforge.net/projects/jboss/files/Seam/3/3.0.0.CR3/">http://sourceforge.net/projects/jboss/files/Seam/3/3.0.0.CR3/</a></div><div>[2] <a href="http://docs.jboss.org/seam/3/solder/latest/reference/en-US/html/">http://docs.jboss.org/seam/3/solder/latest/reference/en-US/html/</a></div>

<div>[3] <a href="http://in.relation.to/Bloggers/IsSeam3GoingToBePortableOrWhat">http://in.relation.to/Bloggers/IsSeam3GoingToBePortableOrWhat</a></div><div><br></div></div>-- <br><div>Dan Allen</div>Principal Software Engineer, Red Hat | Author of Seam in Action<br>

Registered Linux User #231597<br><br><div><a href="http://www.google.com/profiles/dan.j.allen#about" target="_blank">http://www.google.com/profiles/dan.j.allen#about</a><br><a href="http://mojavelinux.com" target="_blank">http://mojavelinux.com</a><br>

<a href="http://mojavelinux.com/seaminaction" target="_blank">http://mojavelinux.com/seaminaction</a><br></div><br>