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

org.w3c.tidy.OutJavaImpl Maven / Gradle / Ivy

Go to download

JTidy is a Java port of HTML Tidy, a HTML syntax checker and pretty printer. Like its non-Java cousin, JTidy can be used as a tool for cleaning up malformed and faulty HTML. In addition, JTidy provides a DOM interface to the document that is being processed, which effectively makes you able to use JTidy as a DOM parser for real-world HTML.

There is a newer version: 1.0.5
Show newest version
/*
 *  Java HTML Tidy - JTidy
 *  HTML parser and pretty printer
 *
 *  Copyright (c) 1998-2000 World Wide Web Consortium (Massachusetts
 *  Institute of Technology, Institut National de Recherche en
 *  Informatique et en Automatique, Keio University). All Rights
 *  Reserved.
 *
 *  Contributing Author(s):
 *
 *     Dave Raggett 
 *     Andy Quick  (translation to Java)
 *     Gary L Peskin  (Java development)
 *     Sami Lempinen  (release management)
 *     Fabrizio Giustina 
 *
 *  The contributing author(s) would like to thank all those who
 *  helped with testing, bug fixes, and patience.  This wouldn't
 *  have been possible without all of you.
 *
 *  COPYRIGHT NOTICE:
 * 
 *  This software and documentation is provided "as is," and
 *  the copyright holders and contributing author(s) make no
 *  representations or warranties, express or implied, including
 *  but not limited to, warranties of merchantability or fitness
 *  for any particular purpose or that the use of the software or
 *  documentation will not infringe any third party patents,
 *  copyrights, trademarks or other rights. 
 *
 *  The copyright holders and contributing author(s) will not be
 *  liable for any direct, indirect, special or consequential damages
 *  arising out of any use of the software or documentation, even if
 *  advised of the possibility of such damage.
 *
 *  Permission is hereby granted to use, copy, modify, and distribute
 *  this source code, or portions hereof, documentation and executables,
 *  for any purpose, without fee, subject to the following restrictions:
 *
 *  1. The origin of this source code must not be misrepresented.
 *  2. Altered versions must be plainly marked as such and must
 *     not be misrepresented as being the original source.
 *  3. This Copyright notice may not be removed or altered from any
 *     source or altered source distribution.
 * 
 *  The copyright holders and contributing author(s) specifically
 *  permit, without fee, and encourage the use of this source code
 *  as a component for supporting the Hypertext Markup Language in
 *  commercial products. If you use this source code in a product,
 *  acknowledgment is not required but would be appreciated.
 *
 */
package org.w3c.tidy;

import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.io.Writer;


/**
 * Output implementation using java writers.
 * @author Fabrizio Giustina
 * @version $Revision$ ($Author$)
 */
public class OutJavaImpl implements Out
{

    /**
     * Java input stream writer.
     */
    private Writer writer;

    /**
     * Newline string.
     */
    private char[] newline;

    /**
     * Constructor.
     * @param configuration actual configuration instance (needed for newline configuration)
     * @param encoding encoding name
     * @param out output stream
     * @throws UnsupportedEncodingException if the undelining OutputStreamWriter doesn't support the rquested encoding.
     */
    protected OutJavaImpl(Configuration configuration, String encoding, OutputStream out)
        throws UnsupportedEncodingException
    {
        this.writer = new OutputStreamWriter(out, encoding);
        this.newline = configuration.newline;
    }

    /**
     * Constructor.
     * @param configuration actual configuration instance (needed for newline configuration)
     * @param out Writer
     */
    protected OutJavaImpl(Configuration configuration, Writer out)
    {
        this.writer = out;
        this.newline = configuration.newline;
    }

    /**
     * @see org.w3c.tidy.Out#outc(int)
     */
    public void outc(int c)
    {
        try
        {
            writer.write(c);
        }
        catch (IOException e)
        {
            // TODO throws exception
            System.err.println("OutJavaImpl.outc: " + e.getMessage());
        }
    }

    /**
     * @see org.w3c.tidy.Out#outc(byte)
     */
    public void outc(byte c)
    {
        try
        {
            writer.write(c);
        }
        catch (IOException e)
        {
            // TODO throws exception
            System.err.println("OutJavaImpl.outc: " + e.getMessage());
        }
    }

    /**
     * @see org.w3c.tidy.Out#newline()
     */
    public void newline()
    {
        try
        {
            writer.write(this.newline);
        }
        catch (IOException e)
        {
            // TODO throws exception
            System.err.println("OutJavaImpl.newline: " + e.getMessage());
        }
    }

    /**
     * @see org.w3c.tidy.Out#flush()
     */
    public void flush()
    {
        try
        {
            writer.flush();
        }
        catch (IOException e)
        {
            System.err.println("OutJavaImpl.flush: " + e.getMessage());
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy