1adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/*
2adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  Licensed to the Apache Software Foundation (ASF) under one or more
3adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  contributor license agreements.  See the NOTICE file distributed with
4adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  this work for additional information regarding copyright ownership.
5adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  The ASF licenses this file to You under the Apache License, Version 2.0
6adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  (the "License"); you may not use this file except in compliance with
7adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  the License.  You may obtain a copy of the License at
8adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
9adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *     http://www.apache.org/licenses/LICENSE-2.0
10adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *
11adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  Unless required by applicable law or agreed to in writing, software
12adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  distributed under the License is distributed on an "AS IS" BASIS,
13adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  See the License for the specific language governing permissions and
15adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project *  limitations under the License.
16adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
17adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
18adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpackage java.io;
19adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
20adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project/**
21adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * The base class for all writers. A writer is a means of writing data to a
22adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * target in a character-wise manner. Most output streams expect the
23adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * {@link #flush()} method to be called before closing the stream, to ensure all
24adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * data is actually written out.
25adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * <p>
26adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * This abstract class does not provide a fully working implementation, so it
27adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * needs to be subclassed, and at least the {@link #write(char[], int, int)},
28adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * {@link #close()} and {@link #flush()} methods needs to be overridden.
29adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Overriding some of the non-abstract methods is also often advised, since it
30adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * might result in higher efficiency.
31adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * <p>
32adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * Many specialized readers for purposes like reading from a file already exist
33adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * in this package.
34f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson *
35adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project * @see Reader
36adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project */
37adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Projectpublic abstract class Writer implements Appendable, Closeable, Flushable {
38adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
39adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * The object used to synchronize access to the writer.
40adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
41adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    protected Object lock;
42adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
43adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
44adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code Writer} with {@code this} as the object used to
45adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * synchronize critical sections.
46adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
47adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    protected Writer() {
48adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        lock = this;
49adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
50adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
51adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
52adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Constructs a new {@code Writer} with {@code lock} used to synchronize
53adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * critical sections.
54f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
55adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param lock
56adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the {@code Object} used to synchronize critical sections.
57adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws NullPointerException
58adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if {@code lock} is {@code null}.
59adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
60adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    protected Writer(Object lock) {
61adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        if (lock == null) {
6286acc043d3334651ee26c65467d78d6cefedd397Kenny Root            throw new NullPointerException("lock == null");
63adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        }
64adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        this.lock = lock;
65adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
66adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
67adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
68adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Closes this writer. Implementations of this method should free any
69adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * resources associated with the writer.
70f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
71adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
72adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if an error occurs while closing this writer.
73adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
74adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public abstract void close() throws IOException;
75adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
76adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
77adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Flushes this writer. Implementations of this method should ensure that
78adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * all buffered characters are written to the target.
79f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
80adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
81adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if an error occurs while flushing this writer.
82adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
83adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public abstract void flush() throws IOException;
84adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
85adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
86adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Writes the entire character buffer {@code buf} to the target.
87f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
88adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param buf
89adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the non-null array containing characters to write.
90adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
91adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
92adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
93adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public void write(char[] buf) throws IOException {
94adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        write(buf, 0, buf.length);
95adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
96adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
97adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
98adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Writes {@code count} characters starting at {@code offset} in {@code buf}
99adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * to the target.
100f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
101adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param buf
102adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the non-null character array to write.
103adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param offset
104adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the index of the first character in {@code buf} to write.
105adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param count
106adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the maximum number of characters to write.
107adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IndexOutOfBoundsException
108adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if {@code offset < 0} or {@code count < 0}, or if {@code
109adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             offset + count} is greater than the size of {@code buf}.
110adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
111adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
112adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
113fb0ec0e650bf8be35acb0d47da0311a7c446aa33Elliott Hughes    public abstract void write(char[] buf, int offset, int count) throws IOException;
114adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
115adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
116adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Writes one character to the target. Only the two least significant bytes
117adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * of the integer {@code oneChar} are written.
118f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
119adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param oneChar
120adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the character to write to the target.
121adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
122adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
123adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
124adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public void write(int oneChar) throws IOException {
125adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        synchronized (lock) {
126171dc20afe5071d5cbfad7103903bfa2c1f8d00fElliott Hughes            char[] oneCharArray = new char[1];
127adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project            oneCharArray[0] = (char) oneChar;
128adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project            write(oneCharArray);
129adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        }
130adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
131adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
132adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
133adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Writes the characters from the specified string to the target.
134f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
135adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param str
136adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the non-null string containing the characters to write.
137adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
138adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
139adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
140adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public void write(String str) throws IOException {
14155392539fea537abfb6581b474918f9d611fba27Jesse Wilson        write(str, 0, str.length());
142adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
143adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
144adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
145adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Writes {@code count} characters from {@code str} starting at {@code
146adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * offset} to the target.
147f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
148adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param str
149adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the non-null string containing the characters to write.
150adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param offset
151adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the index of the first character in {@code str} to write.
152adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param count
153adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the number of characters from {@code str} to write.
154adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
155adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
156adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IndexOutOfBoundsException
157adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if {@code offset < 0} or {@code count < 0}, or if {@code
158adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             offset + count} is greater than the length of {@code str}.
159adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
160adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public void write(String str, int offset, int count) throws IOException {
16144a9f03a2d602c7179112284d878b0db9284eb30Elliott Hughes        if ((offset | count) < 0 || offset > str.length() - count) {
16244a9f03a2d602c7179112284d878b0db9284eb30Elliott Hughes            throw new StringIndexOutOfBoundsException(str, offset, count);
163adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        }
164171dc20afe5071d5cbfad7103903bfa2c1f8d00fElliott Hughes        char[] buf = new char[count];
165adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        str.getChars(offset, offset + count, buf, 0);
166adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        synchronized (lock) {
16755392539fea537abfb6581b474918f9d611fba27Jesse Wilson            write(buf, 0, buf.length);
168adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        }
169adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
170adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
171adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
172adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Appends the character {@code c} to the target. This method works the same
173adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * way as {@link #write(int)}.
174f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
175adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param c
176adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the character to append to the target stream.
177adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @return this writer.
178adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
179adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
180adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
181adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public Writer append(char c) throws IOException {
182adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        write(c);
183adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        return this;
184adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
185adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
186adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
187adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Appends the character sequence {@code csq} to the target. This method
188adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * works the same way as {@code Writer.write(csq.toString())}. If {@code
189adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * csq} is {@code null}, then the string "null" is written to the target
190adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * stream.
191f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
192adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param csq
193adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the character sequence appended to the target.
194adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @return this writer.
195adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
196adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
197adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
198adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    public Writer append(CharSequence csq) throws IOException {
199b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes        if (csq == null) {
200b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes            csq = "null";
201adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        }
202b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes        write(csq.toString());
203adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        return this;
204adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
205adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project
206adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    /**
207adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Appends a subsequence of the character sequence {@code csq} to the
208adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * target. This method works the same way as {@code
209adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * Writer.writer(csq.subsequence(start, end).toString())}. If {@code
210adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * csq} is {@code null}, then the specified subsequence of the string "null"
211adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * will be written to the target.
212f5597e626ecf7949d249dea08c1a2964d890ec11Jesse Wilson     *
213adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param csq
214adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the character sequence appended to the target.
215adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param start
216adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the index of the first char in the character sequence appended
217adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            to the target.
218adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @param end
219adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            the index of the character following the last character of the
220adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *            subsequence appended to the target.
221adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @return this writer.
222adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IOException
223adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if this writer is closed or another I/O error occurs.
224adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     * @throws IndexOutOfBoundsException
225adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             if {@code start > end}, {@code start < 0}, {@code end < 0} or
226adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             either {@code start} or {@code end} are greater or equal than
227adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     *             the length of {@code csq}.
228adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project     */
229b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes    public Writer append(CharSequence csq, int start, int end) throws IOException {
230b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes        if (csq == null) {
231b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes            csq = "null";
232adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        }
233b46dab348e2007bc08abaf7ecae34d89a2474e50Elliott Hughes        write(csq.subSequence(start, end).toString());
234adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project        return this;
235adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project    }
23655392539fea537abfb6581b474918f9d611fba27Jesse Wilson
23755392539fea537abfb6581b474918f9d611fba27Jesse Wilson    /**
23855392539fea537abfb6581b474918f9d611fba27Jesse Wilson     * Returns true if this writer has encountered and suppressed an error. Used
23955392539fea537abfb6581b474918f9d611fba27Jesse Wilson     * by PrintWriters as an alternative to checked exceptions.
24055392539fea537abfb6581b474918f9d611fba27Jesse Wilson     */
24155392539fea537abfb6581b474918f9d611fba27Jesse Wilson    boolean checkError() {
24255392539fea537abfb6581b474918f9d611fba27Jesse Wilson        return false;
24355392539fea537abfb6581b474918f9d611fba27Jesse Wilson    }
244adc854b798c1cfe3bfd4c27d68d5cee38ca617daThe Android Open Source Project}
245