KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > apache > bsf > debug > util > DebugLog


1 /*
2  * The Apache Software License, Version 1.1
3  *
4  * Copyright (c) 2002 The Apache Software Foundation. All rights
5  * reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright
15  * notice, this list of conditions and the following disclaimer in
16  * the documentation and/or other materials provided with the
17  * distribution.
18  *
19  * 3. The end-user documentation included with the redistribution, if
20  * any, must include the following acknowlegement:
21  * "This product includes software developed by the
22  * Apache Software Foundation (http://www.apache.org/)."
23  * Alternately, this acknowlegement may appear in the software itself,
24  * if and wherever such third-party acknowlegements normally appear.
25  *
26  * 4. The names "Apache BSF", "Apache", and "Apache Software Foundation"
27  * must not be used to endorse or promote products derived from
28  * this software without prior written permission. For written
29  * permission, please contact apache@apache.org.
30  *
31  * 5. Products derived from this software may not be called "Apache"
32  * nor may "Apache" appear in their names without prior written
33  * permission of the Apache Group.
34  *
35  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46  * SUCH DAMAGE.
47  * ====================================================================
48  *
49  * This software consists of voluntary contributions made by many individuals
50  * on behalf of the Apache Software Foundation and was originally created by
51  * Sanjiva Weerawarana and others at International Business Machines
52  * Corporation. For more information on the Apache Software Foundation,
53  * please see <http://www.apache.org/>.
54  */

55
56 package org.apache.bsf.debug.util;
57
58 import java.security.*;
59 import java.io.OutputStream JavaDoc;
60 import java.io.PrintStream JavaDoc;
61 import java.lang.String JavaDoc;
62 import java.lang.Integer JavaDoc;
63 import java.util.Hashtable JavaDoc;
64
65 public class DebugLog {
66     public static final int BSF_LOG_L0 = 0;
67     public static final int BSF_LOG_L1 = 1;
68     public static final int BSF_LOG_L2 = 2;
69     public static final int BSF_LOG_L3 = 3;
70     public static Hashtable JavaDoc logLevels;
71     
72     private static int loglevel = 0;
73     private static PrintStream JavaDoc debugStream = System.err;
74
75     static {
76         Integer JavaDoc logprop = Integer.getInteger("org.apache.bsf.debug.logLevel", 0);
77         setLogLevel(logprop.intValue());
78
79         logLevels = new Hashtable JavaDoc();
80         logLevels.put("BSF_LOG_L0", new Integer JavaDoc(BSF_LOG_L0));
81         logLevels.put("BSF_LOG_L1", new Integer JavaDoc(BSF_LOG_L1));
82         logLevels.put("BSF_LOG_L2", new Integer JavaDoc(BSF_LOG_L2));
83         logLevels.put("BSF_LOG_L3", new Integer JavaDoc(BSF_LOG_L3));
84     }
85
86     public static void stdoutPrint(Object JavaDoc obj, int prio) {
87         streamPrint(obj, System.out, prio);
88     }
89
90     public static void stdoutPrintln(Object JavaDoc obj, int prio) {
91         streamPrintln(obj, System.out, prio);
92     }
93
94     public static void stderrPrint(Object JavaDoc obj, int prio) {
95         streamPrint(obj, System.err, prio);
96     }
97
98     public static void stderrPrintln(Object JavaDoc obj, int prio) {
99         streamPrintln(obj, System.err, prio);
100     }
101
102     public static void debugPrint(Object JavaDoc obj, int prio) {
103         streamPrint(obj, debugStream, prio);
104     }
105
106     public static void debugPrintln(Object JavaDoc obj, int prio) {
107         streamPrintln(obj, debugStream, prio);
108     }
109
110     public static void setDebugStream(PrintStream JavaDoc dbgStream) {
111         debugStream = dbgStream;
112     }
113
114     public static PrintStream JavaDoc getDebugStream() {
115         return debugStream;
116     }
117
118     public static void setLogLevel(int loglvl) {
119         if (loglvl != loglevel) {
120             if (loglvl >= 0) {
121                 try {
122                     final int loglvlf = loglvl;
123                     AccessController.doPrivileged(new PrivilegedExceptionAction() {
124                             public Object JavaDoc run() throws Exception JavaDoc {
125                                 System.setProperty("org.apache.bsf.debug.logLevel", String.valueOf(loglvlf));
126                                 return null;
127                             }
128                         });
129                     loglevel = loglvlf;
130                 }
131                 catch (PrivilegedActionException prive) {
132                     Exception JavaDoc e = prive.getException();
133                     System.err.println("Unable to set loglevel: "
134                                        + e.getMessage());
135                     e.printStackTrace();
136                 }
137             }
138         }
139     }
140
141     public static int getLogLevel() {
142         return loglevel;
143     }
144
145     public static void streamPrint(Object JavaDoc obj,
146                                    OutputStream JavaDoc ostrm,
147                                    int prio) {
148         if (loglevel >= prio) {
149             PrintStream JavaDoc prs =
150                 (ostrm instanceof PrintStream JavaDoc) ? (PrintStream JavaDoc) ostrm
151                 : new PrintStream JavaDoc (ostrm, true);
152             prs.print(obj);
153         }
154     }
155
156     public static void streamPrintln(Object JavaDoc obj,
157                                      OutputStream JavaDoc ostrm,
158                                      int prio) {
159         if (loglevel >= prio) {
160             PrintStream JavaDoc prs =
161                 (ostrm instanceof PrintStream JavaDoc) ? (PrintStream JavaDoc) ostrm
162                 : new PrintStream JavaDoc (ostrm, true);
163             prs.println(obj);
164         }
165     }
166 }
167
Popular Tags