Wieners, Brats, Franks, we've got 'em all.
0 Members and 1 Guest are viewing this topic.
"EasyReader"?
// package com.skylit.io;import java.io.*;/** * Written by Gary Litvin as part of * <i>Java Methods: * An Introduction to Object-Oriented Programming</i> * (Skylight Publishing 2001, ISBN 0-9654853-7-4). * * Rev 1.0, 05/15/01 *//** * EasyReader provides simple methods for reading the console and * for opening and reading text files. All exceptions are handled * inside the class and are hidden from the user. * * <xmp> * Example: * ======= * * EasyReader console = new EasyReader(); * System.out.print("Enter input file name: "); * String fileName = console.readLine(); * * EasyReader inFile = new EasyReader(fileName); * if (inFile.bad()) * { * System.err.println("Can't open " + fileName); * System.exit(1); * } * * String firstLine = inFile.readLine(); * if (!inFile.eof()) // or: if (firstLine != null) * System.out.println("The first line is : " + firstLine); * * System.out.print("Enter the maximum number of integers to read: "); * int maxCount = console.readInt(); * int k, count = 0; * * while (count < maxCount && !inFile.eof()) * { * k = inFile.readInt(); * if (!inFile.eof()) * { * // process or store this number * count++; * } * } * * inFile.close(); // optional * System.out.println(count + " numbers read"); * </xmp> * * @author Gary Litvin * @version 1.1 * */public class EasyReader{ protected String myFileName; protected BufferedReader myInFile; protected int myErrorFlags = 0; protected static final int OPENERROR = 0x0001; protected static final int CLOSEERROR = 0x0002; protected static final int READERROR = 0x0004; protected static final int EOF = 0x0100; /** * Constructor. Prepares console (System.in) for reading */ public EasyReader() { myFileName = null; myErrorFlags = 0; myInFile = new BufferedReader( new InputStreamReader(System.in), 128); } /** * Constructor. opens a file for reading * @param fileName the name or pathname of the file */ public EasyReader(String fileName) { myFileName = fileName; myErrorFlags = 0; try { myInFile = new BufferedReader(new FileReader(fileName), 1024); } catch (FileNotFoundException e) { myErrorFlags |= OPENERROR; myFileName = null; } } /** * Closes the file */ public void close() { if (myFileName == null) return; try { myInFile.close(); } catch (IOException e) { System.err.println("Error closing " + myFileName + "\n"); myErrorFlags |= CLOSEERROR; } } /** * Checks the status of the file * @return true if en error occurred opening or reading the file, * false otherwise */ public boolean bad() { return myErrorFlags != 0; } /** * Checks the EOF status of the file * @return true if EOF was encountered in the previous read * operation, false otherwise */ public boolean eof() { return (myErrorFlags & EOF) != 0; } private boolean ready() throws IOException { return myFileName == null || myInFile.ready(); } /** * Reads the next character from a file (any character including * a space or a newline character). * @return character read or <code>null</code> character * (unicode 0) if trying to read beyond the EOF */ public char readChar() { char ch = '\u0000'; try { if (ready()) { ch = (char)myInFile.read(); } } catch (IOException e) { if (myFileName != null) System.err.println("Error reading " + myFileName + "\n"); myErrorFlags |= READERROR; } if (ch == '\u0000') myErrorFlags |= EOF; return ch; } /** * Reads from the current position in the file up to and including * the next newline character. The newline character is thrown away * @return the read string (excluding the newline character) or * null if trying to read beyond the EOF */ public String readLine() { String s = null; try { s = myInFile.readLine(); } catch (IOException e) { if (myFileName != null) System.err.println("Error reading " + myFileName + "\n"); myErrorFlags |= READERROR; } if (s == null) myErrorFlags |= EOF; return s; } /** * Skips whitespace and reads the next word (a string of consecutive * non-whitespace characters (up to but excluding the next space, * newline, etc.) * @return the read string or null if trying to read beyond the EOF */ public String readWord() { StringBuffer buffer = new StringBuffer(128); char ch = ' '; int count = 0; String s = null; try { while (ready() && Character.isWhitespace(ch)) ch = (char)myInFile.read(); while (ready() && !Character.isWhitespace(ch)) { count++; buffer.append(ch); myInFile.mark(1); ch = (char)myInFile.read(); }; if (count > 0) { myInFile.reset(); s = buffer.toString(); } else { myErrorFlags |= EOF; } } catch (IOException e) { if (myFileName != null) System.err.println("Error reading " + myFileName + "\n"); myErrorFlags |= READERROR; } return s; } /** * Reads the next integer (without validating its format) * @return the integer read or 0 if trying to read beyond the EOF */ public int readInt() { String s = readWord(); if (s != null) return Integer.parseInt(s); else return 0; } /** * Reads the next double (without validating its format) * @return the number read or 0 if trying to read beyond the EOF */ public double readDouble() { String s = readWord(); if (s != null) return Double.parseDouble(s); else return 0.; }}
I'd personally do as Joe suggests
You might be right about that, Joe.
Quote from: iago on February 14, 2006, 08:38:16 pm"EasyReader"? Something we use in our class at school all the time, so we don't have to put up with IOExceptions that rarely occur, etc.Code: [Select]// package com.skylit.io;import java.io.*;/** * Written by Gary Litvin as part of * <i>Java Methods: * An Introduction to Object-Oriented Programming</i> * (Skylight Publishing 2001, ISBN 0-9654853-7-4). * * Rev 1.0, 05/15/01 */[.........]}
// package com.skylit.io;import java.io.*;/** * Written by Gary Litvin as part of * <i>Java Methods: * An Introduction to Object-Oriented Programming</i> * (Skylight Publishing 2001, ISBN 0-9654853-7-4). * * Rev 1.0, 05/15/01 */[.........]}
Quote from: Joe[e2] on February 15, 2006, 07:52:26 amQuote from: iago on February 14, 2006, 08:38:16 pm"EasyReader"? Something we use in our class at school all the time, so we don't have to put up with IOExceptions that rarely occur, etc.Code: [Select]// package com.skylit.io;import java.io.*;/** * Written by Gary Litvin as part of * <i>Java Methods: * An Introduction to Object-Oriented Programming</i> * (Skylight Publishing 2001, ISBN 0-9654853-7-4). * * Rev 1.0, 05/15/01 */[.........]}Returning 0 on an error seems like a bad idea, because you never check for 0. I'd recommend changing it so that it dies with an error message if the read fails.