corba/src/share/classes/com/sun/corba/se/spi/logging/LogWrapperBase.java
author ohair
Tue, 25 May 2010 15:52:11 -0700
changeset 5555 b2b5ed3f0d0d
parent 4 02bb8761fcce
permissions -rw-r--r--
6943119: Rebrand source copyright notices Reviewed-by: darcy
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4
02bb8761fcce Initial load
duke
parents:
diff changeset
     1
/*
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
     2
 * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved.
4
02bb8761fcce Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
02bb8761fcce Initial load
duke
parents:
diff changeset
     4
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
02bb8761fcce Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
4
02bb8761fcce Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
4
02bb8761fcce Initial load
duke
parents:
diff changeset
    10
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
02bb8761fcce Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
02bb8761fcce Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
02bb8761fcce Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
02bb8761fcce Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
02bb8761fcce Initial load
duke
parents:
diff changeset
    16
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
02bb8761fcce Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
02bb8761fcce Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
02bb8761fcce Initial load
duke
parents:
diff changeset
    20
 *
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
    23
 * questions.
4
02bb8761fcce Initial load
duke
parents:
diff changeset
    24
 */
02bb8761fcce Initial load
duke
parents:
diff changeset
    25
02bb8761fcce Initial load
duke
parents:
diff changeset
    26
package com.sun.corba.se.spi.logging ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    27
02bb8761fcce Initial load
duke
parents:
diff changeset
    28
import java.util.logging.Level ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    29
import java.util.logging.Logger ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    30
import java.util.logging.LogRecord ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    31
02bb8761fcce Initial load
duke
parents:
diff changeset
    32
public abstract class LogWrapperBase {
02bb8761fcce Initial load
duke
parents:
diff changeset
    33
    protected Logger logger ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    34
02bb8761fcce Initial load
duke
parents:
diff changeset
    35
    protected String loggerName ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    36
02bb8761fcce Initial load
duke
parents:
diff changeset
    37
    protected LogWrapperBase( Logger logger )
02bb8761fcce Initial load
duke
parents:
diff changeset
    38
    {
02bb8761fcce Initial load
duke
parents:
diff changeset
    39
        this.logger = logger ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    40
        this.loggerName = logger.getName( );
02bb8761fcce Initial load
duke
parents:
diff changeset
    41
    }
02bb8761fcce Initial load
duke
parents:
diff changeset
    42
02bb8761fcce Initial load
duke
parents:
diff changeset
    43
    protected void doLog( Level level, String key, Object[] params, Class wrapperClass,
02bb8761fcce Initial load
duke
parents:
diff changeset
    44
        Throwable thr )
02bb8761fcce Initial load
duke
parents:
diff changeset
    45
    {
02bb8761fcce Initial load
duke
parents:
diff changeset
    46
        LogRecord lrec = new LogRecord( level, key ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    47
        if (params != null)
02bb8761fcce Initial load
duke
parents:
diff changeset
    48
            lrec.setParameters( params ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    49
        inferCaller( wrapperClass, lrec ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    50
        lrec.setThrown( thr ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    51
        lrec.setLoggerName( loggerName );
02bb8761fcce Initial load
duke
parents:
diff changeset
    52
        lrec.setResourceBundle( logger.getResourceBundle() ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    53
        logger.log( lrec ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    54
    }
02bb8761fcce Initial load
duke
parents:
diff changeset
    55
02bb8761fcce Initial load
duke
parents:
diff changeset
    56
    private void inferCaller( Class wrapperClass, LogRecord lrec )
02bb8761fcce Initial load
duke
parents:
diff changeset
    57
    {
02bb8761fcce Initial load
duke
parents:
diff changeset
    58
        // Private method to infer the caller's class and method names
02bb8761fcce Initial load
duke
parents:
diff changeset
    59
02bb8761fcce Initial load
duke
parents:
diff changeset
    60
        // Get the stack trace.
02bb8761fcce Initial load
duke
parents:
diff changeset
    61
        StackTraceElement stack[] = (new Throwable()).getStackTrace();
02bb8761fcce Initial load
duke
parents:
diff changeset
    62
        StackTraceElement frame = null ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    63
        String wcname = wrapperClass.getName() ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    64
        String baseName = LogWrapperBase.class.getName() ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    65
02bb8761fcce Initial load
duke
parents:
diff changeset
    66
        // The top of the stack should always be a method in the wrapper class,
02bb8761fcce Initial load
duke
parents:
diff changeset
    67
        // or in this base class.
02bb8761fcce Initial load
duke
parents:
diff changeset
    68
        // Search back to the first method not in the wrapper class or this class.
02bb8761fcce Initial load
duke
parents:
diff changeset
    69
        int ix = 0;
02bb8761fcce Initial load
duke
parents:
diff changeset
    70
        while (ix < stack.length) {
02bb8761fcce Initial load
duke
parents:
diff changeset
    71
            frame = stack[ix];
02bb8761fcce Initial load
duke
parents:
diff changeset
    72
            String cname = frame.getClassName();
02bb8761fcce Initial load
duke
parents:
diff changeset
    73
            if (!cname.equals(wcname) && !cname.equals(baseName))  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    74
                break;
02bb8761fcce Initial load
duke
parents:
diff changeset
    75
            }
02bb8761fcce Initial load
duke
parents:
diff changeset
    76
02bb8761fcce Initial load
duke
parents:
diff changeset
    77
            ix++;
02bb8761fcce Initial load
duke
parents:
diff changeset
    78
        }
02bb8761fcce Initial load
duke
parents:
diff changeset
    79
02bb8761fcce Initial load
duke
parents:
diff changeset
    80
        // Set the class and method if we are not past the end of the stack
02bb8761fcce Initial load
duke
parents:
diff changeset
    81
        // trace
02bb8761fcce Initial load
duke
parents:
diff changeset
    82
        if (ix < stack.length) {
02bb8761fcce Initial load
duke
parents:
diff changeset
    83
            lrec.setSourceClassName(frame.getClassName());
02bb8761fcce Initial load
duke
parents:
diff changeset
    84
            lrec.setSourceMethodName(frame.getMethodName());
02bb8761fcce Initial load
duke
parents:
diff changeset
    85
        }
02bb8761fcce Initial load
duke
parents:
diff changeset
    86
    }
02bb8761fcce Initial load
duke
parents:
diff changeset
    87
02bb8761fcce Initial load
duke
parents:
diff changeset
    88
    protected void doLog( Level level, String key, Class wrapperClass, Throwable thr )
02bb8761fcce Initial load
duke
parents:
diff changeset
    89
    {
02bb8761fcce Initial load
duke
parents:
diff changeset
    90
        doLog( level, key, null, wrapperClass, thr ) ;
02bb8761fcce Initial load
duke
parents:
diff changeset
    91
    }
02bb8761fcce Initial load
duke
parents:
diff changeset
    92
}