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