| /* |
| * Copyright (c) 1997, 2007, Oracle and/or its affiliates. All rights reserved. |
| * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
| * |
| * This code is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License version 2 only, as |
| * published by the Free Software Foundation. Oracle designates this |
| * particular file as subject to the "Classpath" exception as provided |
| * by Oracle in the LICENSE file that accompanied this code. |
| * |
| * This code is distributed in the hope that it will be useful, but WITHOUT |
| * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
| * version 2 for more details (a copy is included in the LICENSE file that |
| * accompanied this code). |
| * |
| * You should have received a copy of the GNU General Public License version |
| * 2 along with this work; if not, write to the Free Software Foundation, |
| * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
| * |
| * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
| * or visit www.oracle.com if you need additional information or have any |
| * questions. |
| */ |
| |
| /*****************************************************************************/ |
| /* Copyright (c) IBM Corporation 1998 */ |
| /* */ |
| /* (C) Copyright IBM Corp. 1998 */ |
| /* */ |
| /*****************************************************************************/ |
| |
| package sun.rmi.rmic; |
| |
| import java.io.Writer; |
| import java.io.BufferedWriter; |
| import java.io.IOException; |
| |
| /** |
| * IndentingWriter is a BufferedWriter subclass that supports automatic |
| * indentation of lines of text written to the underlying Writer. |
| * |
| * Methods are provided for compact, convenient indenting, writing text, |
| * and writing lines in various combinations. |
| * |
| * WARNING: The contents of this source file are not part of any |
| * supported API. Code that depends on them does so at its own risk: |
| * they are subject to change or removal without notice. |
| */ |
| public class IndentingWriter extends BufferedWriter { |
| |
| /** true if the next character written is the first on a line */ |
| private boolean beginningOfLine = true; |
| |
| /** current number of spaces to prepend to lines */ |
| private int currentIndent = 0; |
| |
| /** number of spaces to change indent when indenting in or out */ |
| private int indentStep = 4; |
| |
| /** number of spaces to convert into tabs. Use MAX_VALUE to disable */ |
| private int tabSize = 8; |
| |
| /** |
| * Create a new IndentingWriter that writes indented text to the |
| * given Writer. Use the default indent step of four spaces. |
| */ |
| public IndentingWriter(Writer out) { |
| super(out); |
| } |
| |
| /** |
| * Create a new IndentingWriter that writes indented text to the |
| * given Writer and uses the supplied indent step. |
| */ |
| public IndentingWriter(Writer out, int step) { |
| this(out); |
| |
| if (indentStep < 0) |
| throw new IllegalArgumentException("negative indent step"); |
| |
| indentStep = step; |
| } |
| |
| /** |
| * Create a new IndentingWriter that writes indented text to the |
| * given Writer and uses the supplied indent step and tab size. |
| */ |
| public IndentingWriter(Writer out, int step, int tabSize) { |
| this(out); |
| |
| if (indentStep < 0) |
| throw new IllegalArgumentException("negative indent step"); |
| |
| indentStep = step; |
| this.tabSize = tabSize; |
| } |
| |
| /** |
| * Write a single character. |
| */ |
| public void write(int c) throws IOException { |
| checkWrite(); |
| super.write(c); |
| } |
| |
| /** |
| * Write a portion of an array of characters. |
| */ |
| public void write(char[] cbuf, int off, int len) throws IOException { |
| if (len > 0) { |
| checkWrite(); |
| } |
| super.write(cbuf, off, len); |
| } |
| |
| /** |
| * Write a portion of a String. |
| */ |
| public void write(String s, int off, int len) throws IOException { |
| if (len > 0) { |
| checkWrite(); |
| } |
| super.write(s, off, len); |
| } |
| |
| /** |
| * Write a line separator. The next character written will be |
| * preceded by an indent. |
| */ |
| public void newLine() throws IOException { |
| super.newLine(); |
| beginningOfLine = true; |
| } |
| |
| /** |
| * Check if an indent needs to be written before writing the next |
| * character. |
| * |
| * The indent generation is optimized (and made consistent with |
| * certain coding conventions) by condensing groups of eight spaces |
| * into tab characters. |
| */ |
| protected void checkWrite() throws IOException { |
| if (beginningOfLine) { |
| beginningOfLine = false; |
| int i = currentIndent; |
| while (i >= tabSize) { |
| super.write('\t'); |
| i -= tabSize; |
| } |
| while (i > 0) { |
| super.write(' '); |
| -- i; |
| } |
| } |
| } |
| |
| /** |
| * Increase the current indent by the indent step. |
| */ |
| protected void indentIn() { |
| currentIndent += indentStep; |
| } |
| |
| /** |
| * Decrease the current indent by the indent step. |
| */ |
| protected void indentOut() { |
| currentIndent -= indentStep; |
| if (currentIndent < 0) |
| currentIndent = 0; |
| } |
| |
| /** |
| * Indent in. |
| */ |
| public void pI() { |
| indentIn(); |
| } |
| |
| /** |
| * Indent out. |
| */ |
| public void pO() { |
| indentOut(); |
| } |
| |
| /** |
| * Write string. |
| */ |
| public void p(String s) throws IOException { |
| write(s); |
| } |
| |
| /** |
| * End current line. |
| */ |
| public void pln() throws IOException { |
| newLine(); |
| } |
| |
| /** |
| * Write string; end current line. |
| */ |
| public void pln(String s) throws IOException { |
| p(s); |
| pln(); |
| } |
| |
| /** |
| * Write string; end current line; indent in. |
| */ |
| public void plnI(String s) throws IOException { |
| p(s); |
| pln(); |
| pI(); |
| } |
| |
| /** |
| * Indent out; write string. |
| */ |
| public void pO(String s) throws IOException { |
| pO(); |
| p(s); |
| } |
| |
| /** |
| * Indent out; write string; end current line. |
| */ |
| public void pOln(String s) throws IOException { |
| pO(s); |
| pln(); |
| } |
| |
| /** |
| * Indent out; write string; end current line; indent in. |
| * |
| * This method is useful for generating lines of code that both |
| * end and begin nested blocks, like "} else {". |
| */ |
| public void pOlnI(String s) throws IOException { |
| pO(s); |
| pln(); |
| pI(); |
| } |
| |
| /** |
| * Write Object. |
| */ |
| public void p(Object o) throws IOException { |
| write(o.toString()); |
| } |
| /** |
| * Write Object; end current line. |
| */ |
| public void pln(Object o) throws IOException { |
| p(o.toString()); |
| pln(); |
| } |
| |
| /** |
| * Write Object; end current line; indent in. |
| */ |
| public void plnI(Object o) throws IOException { |
| p(o.toString()); |
| pln(); |
| pI(); |
| } |
| |
| /** |
| * Indent out; write Object. |
| */ |
| public void pO(Object o) throws IOException { |
| pO(); |
| p(o.toString()); |
| } |
| |
| /** |
| * Indent out; write Object; end current line. |
| */ |
| public void pOln(Object o) throws IOException { |
| pO(o.toString()); |
| pln(); |
| } |
| |
| /** |
| * Indent out; write Object; end current line; indent in. |
| * |
| * This method is useful for generating lines of code that both |
| * end and begin nested blocks, like "} else {". |
| */ |
| public void pOlnI(Object o) throws IOException { |
| pO(o.toString()); |
| pln(); |
| pI(); |
| } |
| |
| } |