All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.struts.util.ServletContextWriter Maven / Gradle / Ivy

Go to download

Base project: http://central.maven.org/maven2/struts/struts/1.2.9/ This version of Struts doesn't throw java.io.NotSerializableException when the application server wants to persist sessions and makes renderFocusJavascript return valid xml

The newest version!
/*
 * $Id: ServletContextWriter.java 54929 2004-10-16 16:38:42Z germuska $ 
 *
 * Copyright 2000-2004 The Apache Software Foundation.
 * 
 * Licensed 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.struts.util;

import java.io.PrintWriter;
import java.io.StringWriter;
import javax.servlet.ServletContext;

/**
 * A PrintWriter implementation that uses the logging facilities of a
 * javax.servlet.ServletContext to output its results.  Output
 * will be buffered until a newline character is output, flush()
 * is called, or until one of the println() methods is called.
 * Along the way, carriage return characters are skipped.
 *
 * @version $Rev: 54929 $ $Date: 2004-10-16 17:38:42 +0100 (Sat, 16 Oct 2004) $
 */
public class ServletContextWriter extends PrintWriter {


    // ----------------------------------------------------------- Constructors


    /**
     * Construct a ServletContextWriter associated with the specified
     * ServletContext instance.
     *
     * @param context The associated servlet context
     */
    public ServletContextWriter(ServletContext context) {

        super(new StringWriter());
        this.context = context;

    }


    // ------------------------------------------------------------- Properties


    /**
     * The buffer into which we accumulate lines to be logged.
     */
    protected StringBuffer buffer = new StringBuffer();


    /**
     * The servlet context with which we are associated.
     */
    protected ServletContext context = null;


    /**
     * The error state for this stream.
     */
    protected boolean error = false;


    // --------------------------------------------------------- Public Methods


    /**
     * Flush the stream and check for its error state.  IMPLEMENTATION
     * NOTE - our associated servlet context gives no indication of
     * problems with logging, so the only way this method will return
     * true is if setError() is called.
     */
    public boolean checkError() {

        flush();
        return (error);

    }


    /**
     * Close the stream.
     */
    public void close() {

        flush();

    }


    /**
     * Flush the stream.
     */
    public void flush() {

        if (buffer.length() > 0) {
            context.log(buffer.toString());
            buffer.setLength(0);
        }

    }


    /**
     * Print a boolean value.
     *
     * @param b The value to be printed
     */
    public void print(boolean b) {

        write(String.valueOf(b));

    }


    /**
     * Print a character value.
     *
     * @param c The value to be printed
     */
    public void print(char c) {

        write(c);

    }


    /**
     * Print a character array.
     *
     * @param c The character array to be printed
     */
    public void print(char c[]) {

        for (int i = 0; i < c.length; i++)
            write(c[i]);

    }


    /**
     * Print a double value.
     *
     * @param d The value to be printed
     */
    public void print(double d) {

        write(String.valueOf(d));

    }


    /**
     * Print a float value.
     *
     * @param f The value to be printed
     */
    public void print(float f) {

        write(String.valueOf(f));

    }


    /**
     * Print an integer value.
     *
     * @param i The value to be printed
     */
    public void print(int i) {

        write(String.valueOf(i));

    }


    /**
     * Print a long value.
     *
     * @param l The value to be printed
     */
    public void print(long l) {

        write(String.valueOf(l));

    }


    /**
     * Print an object.
     *
     * @param o The value to be printed
     */
    public void print(Object o) {

        write(o.toString());

    }


    /**
     * Print a String value.
     *
     * @param s The value to be printed
     */
    public void print(String s) {

        int len = s.length();
        for (int i = 0; i < len; i++)
            write(s.charAt(i));

    }


    /**
     * Terminate the current line and flush the buffer.
     */
    public void println() {

        flush();

    }


    /**
     * Print a boolean value and terminate the line.
     *
     * @param b The value to be printed
     */
    public void println(boolean b) {

        println(String.valueOf(b));

    }


    /**
     * Print a character value and terminate the line.
     *
     * @param c The value to be printed
     */
    public void println(char c) {

        write(c);
        println();

    }


    /**
     * Print a character array and terminate the line.
     *
     * @param c The character array to be printed
     */
    public void println(char c[]) {

        for (int i = 0; i < c.length; i++)
            print(c[i]);
        println();

    }


    /**
     * Print a double value and terminate the line.
     *
     * @param d The value to be printed
     */
    public void println(double d) {

        println(String.valueOf(d));

    }


    /**
     * Print a float value and terminate the line.
     *
     * @param f The value to be printed
     */
    public void println(float f) {

        println(String.valueOf(f));

    }


    /**
     * Print an integer value and terminate the line.
     *
     * @param i The value to be printed
     */
    public void println(int i) {

        println(String.valueOf(i));

    }


    /**
     * Print a long value and terminate the line.
     *
     * @param l The value to be printed
     */
    public void println(long l) {

        println(String.valueOf(l));

    }


    /**
     * Print an object and terminate the line.
     *
     * @param o The value to be printed
     */
    public void println(Object o) {

        println(o.toString());

    }


    /**
     * Print a String value and terminate the line.
     *
     * @param s The value to be printed
     */
    public void println(String s) {

        int len = s.length();
        for (int i = 0; i < len; i++)
            print(s.charAt(i));
        println();

    }


    /**
     * Set the error state for this stream.
     */
    public void setError() {

        this.error = true;

    }


    /**
     * Write a single character to this stream.
     *
     * @param c The character to be written
     */
    public void write(char c) {

        if (c == '\n')
            flush();
        else if (c != '\r')
            buffer.append(c);

    }


    /**
     * Write a single character to this stream.
     *
     * @param c The character to be written
     */
    public void write(int c) {

        write((char) c);

    }


    /**
     * Write an array of charaters to this stream.
     *
     * @param buf The character array to be written
     */
    public void write(char buf[]) {

        for (int i = 0; i < buf.length; i++)
            write(buf[i]);

    }


    /**
     * Write the specified subset of an array of characters to this stream.
     *
     * @param buf The character array from which to write
     * @param off The zero-relative starting offset to write
     * @param len The number of characters to write
     */
    public void write(char buf[], int off, int len) {

        for (int i = off; i < len; i++)
            write(buf[i]);

    }


    /**
     * Write a String to this stream.
     *
     * @param s The string to be written
     */
    public void write(String s) {

        int len = s.length();
        for (int i = 0; i < len; i++)
            write(s.charAt(i));

    }


    /**
     * Write the specified portion of a String to this stream.
     *
     * @param s The String from which to write
     * @param off The zero-relative starting offset to write
     * @param len The number of characters to write
     */
    public void write(String s, int off, int len) {

        for (int i = off; i < len; i++)
            write(s.charAt(i));

    }


}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy