The version of Apache log4j used by SoundHelix.

[[ 🗃 ^aEp6o apache-log4j ]] :: [📥 Inbox] [📤 Outbox] [🐤 Followers] [🤝 Collaborators] [🛠 Commits]

Clone

HTTPS: git clone https://vervis.peers.community/repos/aEp6o

SSH: git clone USERNAME@vervis.peers.community:aEp6o

Branches

Tags

v_1_1b5 :: contribs / JimMoore /

mail-2001-03-12T1454


Copied from:
http://www.mail-archive.com/log4j-user@jakarta.apache.org/msg00433.html

--------------------------------------------------------------------------------
RE: diverting System.stderr/stdout into log4j
--------------------------------------------------------------------------------

From: Jim Moore 
Subject: RE: diverting System.stderr/stdout into log4j 
Date: Mon, 12 Mar 2001 14:54:13 -0800 

--------------------------------------------------------------------------------

It doesn't.  I haven't worried about it, since log4j doesn't contain any
bugs and therefore it would never happen... :)

Probably the best way to handle it is to add a
LogLog.setPrintStream(PrintStream) method, so you can do something like:

// remember STDERR
PrintStream se = System.err;

// make sure everything sent to System.err is logged
System.setErr(new PrintStream(new LoggingOutputStream(Category.getRoot(),
              Priority.WARN), true));

// make sure everything sent to System.out is also logged
System.setOut(new PrintStream(new LoggingOutputStream(Category.getRoot(),
              Priority.INFO), true));

// prevent infinate recursion in LogLog
LogLog.setPrintStream(se);


I can't think of any other way to do it in the current version besides
getting extremely kludgey by checking the stack to see if it's being called
from LogLog and logging out the the "real" STDERR then in the
LoggingOutputStream.  It can be done on the theory that LogLog wouldn't be
called very often, but still...

-Jim Moore


-----Original Message-----
From: Ceki G�lc� [mailto:cgu@qos.ch]
Sent: Monday, March 12, 2001 5:15 PM
To: LOG4J Users Mailing List
Subject: RE: diverting System.stderr/stdout into log4j 


Jim, Joseph,

Here is a link containing Jim's code:

http://marc.theaimsgroup.com/?l=log4j-user&m=98097669218571&w=2

How does this code handle the infinite recursion problem mentioned by
Joseph? Ceki
 
At 17:03 12.03.2001 -0500, Jim Moore wrote:
>Go to the mailing list archives (theAimsGroup.com is the best) and search
>for the thread with the subject of "Capturing System.err"
>
>-Jim Moore
>"I think so, Brain; but if we gave peas a chance, won't the lima beans get
>jealous?" - Pinky
>
>
>-----Original Message-----
>From: Joseph Panico [mailto:joe_panico@hotmail.com]
>Sent: Monday, March 12, 2001 4:43 PM
>To: log4j-user@jakarta.apache.org
>Subject: diverting System.stderr/stdout into log4j 
>
>
>Folks,
>
>We use a number of third-party packages that do stderr.print... at various 
>random places in their code. I'm finding it quite useful to divert these 
>messages into our log4j heirarchy. I do this by replacing stderr/stdout
with
>
>my own PrintStreams that log the lines to a special log4j Category-- as 
>suggested on this list a while back. The only fly-in-the-ointment with this

>scheme is LogLog. If there is a problem with log4j such that it cannot log 
>for some reason, then log4j internals use LogLog to attempt to print an 
>error message. This obviously leads to an infinite recursion. Has anyone 
>else been bothered by this? Would it make sense to add interface to LogLog 
>which would set the PrintStream it uses to log its error messages to?
>
>thanks for any ideas
>
>joe

I hope to see you at my ApacheCon 2001 presentation 
entitled "Log4j, A Logging Package for Java".

See http://ApacheCon.Com/2001/US/ for more details.

----
Ceki G�lc�          Web:   http://qos.ch     
av. de Rumine 5     email: cgu@qos.ch (preferred)
CH-1005 Lausanne           ceki_gulcu@yahoo.com
Switzerland         Tel: ++41 21 351 23 15

---------------------------------------------------------------------
To unsubscribe, e-mail: log4j-user-unsubscribe@jakarta.apache.org
For additional commands, e-mail: log4j-user-help@jakarta.apache.org



[See repo JSON]