blob: b23d20abecfd367e7de0cc94edc39939bffda72e [file] [log] [blame]
/*
* 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();
}
}
}