Java tutorial
/* * 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.axiom.om.util; import org.apache.commons.logging.Log; import java.io.IOException; import java.io.OutputStream; /** * LogOutputStream * Writes to log.debug() * Also counts the number of bytes */ public class LogOutputStream extends OutputStream { private byte[] temp = new byte[1]; private boolean isDebugEnabled = false; private long count = 0; private Log log; private int BUFFER_LEN = 4 * 1024; private byte[] buffer = new byte[BUFFER_LEN]; private int bufferIndex = 0; private int limit; public LogOutputStream(Log log, int limit) { isDebugEnabled = log.isDebugEnabled(); this.log = log; this.limit = limit; } public long getLength() { return count; } public void close() throws IOException { if (bufferIndex > 0) { log.debug(new String(buffer, 0, bufferIndex)); bufferIndex = 0; } buffer = null; temp = null; log = null; } public void flush() throws IOException { // noop } public void write(byte[] b, int off, int len) throws IOException { // Adjust total count // Adjust length to write if (count >= limit) { count += len; return; } else if (count + len >= limit) { count += len; len = (int) (len - (limit - count)); // adjust length to write } else { count += len; } if (isDebugEnabled) { if (len + bufferIndex < BUFFER_LEN) { // buffer the text System.arraycopy(b, off, buffer, bufferIndex, len); bufferIndex += len; } else { // write buffered text if (bufferIndex > 0) { log.debug(new String(buffer, 0, bufferIndex)); bufferIndex = 0; } // buffer or write remaining text if (len + bufferIndex < BUFFER_LEN) { System.arraycopy(b, off, buffer, bufferIndex, len); bufferIndex += len; } else { log.debug(new String(b, off, len)); } } } } public void write(byte[] b) throws IOException { this.write(b, 0, b.length); } public void write(int b) throws IOException { temp[0] = (byte) b; this.write(temp, 0, 1); } }