org.apache.axis2.context.externalize.DebugObjectInput.java Source code

Java tutorial

Introduction

Here is the source code for org.apache.axis2.context.externalize.DebugObjectInput.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership. The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied. See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */

package org.apache.axis2.context.externalize;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectStreamConstants;

/**
 * DebugObjectInput delegates to an ObjectInput object.
 * Each method logs in/out trace information.
 */
public class DebugObjectInput implements ObjectInput, ObjectStreamConstants {

    private static final Log log = LogFactory.getLog(DebugObjectInput.class);
    private static final boolean isDebug = log.isDebugEnabled();
    ObjectInput oi; // delegate

    public DebugObjectInput(ObjectInput oi) {
        super();
        this.oi = oi;
    }

    public int available() throws IOException {
        trace("start available()");
        int value = oi.available();
        trace("end available() =" + value);
        return value;
    }

    public void close() throws IOException {
        trace("start close()");
        oi.close();
        trace("end close()");
    }

    public int read() throws IOException {
        trace("start read()");
        int value = oi.read();
        trace("end read()=" + value);
        return value;
    }

    public int read(byte[] b, int off, int len) throws IOException {
        trace("start read(b, off, len) off=" + off + " len=" + len);
        int value = oi.read(b, off, len);
        trace("end read(b,off,len)=" + value);
        return value;
    }

    public int read(byte[] b) throws IOException {
        trace("start read(b) b.length=" + b.length);
        int value = oi.read(b);
        trace("end read(b)=" + value);
        return value;
    }

    public boolean readBoolean() throws IOException {
        trace("start readBoolean()");
        boolean value = oi.readBoolean();
        trace("end readBoolean()=" + value);
        return value;
    }

    public byte readByte() throws IOException {
        trace("start readByte");
        byte value = oi.readByte();
        trace("end readByte()=" + value);
        return value;
    }

    public char readChar() throws IOException {
        trace("start readChar");
        char value = oi.readChar();
        trace("end readChar()=" + value);
        return value;
    }

    public double readDouble() throws IOException {
        trace("start readDouble");
        double value = oi.readDouble();
        trace("end readDouble()=" + value);
        return value;
    }

    public float readFloat() throws IOException {
        trace("start readFloat");
        float value = oi.readFloat();
        trace("end readFloat()=" + value);
        return value;
    }

    public void readFully(byte[] b, int off, int len) throws IOException {
        trace("start readFully(b,off,len) off=" + off + " len=" + len);
        oi.readFully(b, off, len);
        trace("end readFully(b,off,len)");
    }

    public void readFully(byte[] b) throws IOException {
        trace("start readFully(b) b.length=" + b.length);
        oi.readFully(b);
        trace("end readFully(b)");
    }

    public int readInt() throws IOException {
        trace("start readInt()");
        int value = oi.readInt();
        trace("end readInt()=" + value);
        return value;
    }

    public String readLine() throws IOException {
        trace("start readLine()");
        String value = oi.readLine();
        trace("end readLine()=" + value);
        return value;
    }

    public long readLong() throws IOException {
        trace("start readLong()");
        long value = oi.readLong();
        trace("end readLong()=" + value);
        return value;
    }

    public Object readObject() throws ClassNotFoundException, IOException {
        trace("start readObject()");
        Object value = oi.readObject();

        trace("end readObject()=" + valueName(value));
        return value;
    }

    public short readShort() throws IOException {
        trace("start readShort()");
        short value = oi.readShort();
        trace("end readShort()=" + value);
        return value;
    }

    public int readUnsignedByte() throws IOException {
        trace("start readLong()");
        int value = oi.readUnsignedByte();
        trace("end readUnsignedByte()=" + value);
        return value;
    }

    public int readUnsignedShort() throws IOException {
        trace("start readShort()");
        int value = oi.readUnsignedShort();
        trace("end readShort()=" + value);
        return value;
    }

    public String readUTF() throws IOException {
        trace("start readUTF()");
        String value = oi.readUTF();
        trace("end readUTF()=" + value);
        return value;
    }

    public long skip(long n) throws IOException {
        trace("start skip(n) n=" + n);
        long value = oi.skip(n);
        trace("end skip(n)=" + value);
        return value;
    }

    public int skipBytes(int n) throws IOException {
        trace("start skipBytes(n) n=" + n);
        int value = oi.skipBytes(n);
        trace("end skipBytes(n)=" + value);
        return value;
    }

    public void trace(String str) {
        if (isDebug) {
            log.debug(str);
        }
    }

    private String valueName(Object obj) {
        if (obj == null) {
            return "null";
        } else if (obj instanceof String) {
            return (String) obj;
        } else {
            return "Object of class = " + obj.getClass().getName();
        }
    }
}