Class FileFactory
- java.lang.Object
-
- com.ibm.jzos.FileFactory
-
public class FileFactory extends java.lang.ObjectA class with static methods for building a BufferedReader, BufferedWriter, InputStream, or OutputStream on a text file or MVS dataset.If the file name given starts with "//", then the underlying file stream will be constructed using a ZFile on an MVS dataset, otherwise the file will be constructed using java.io.
The default encoding for BufferedReaders and BufferedWriters is the ZUtil.defaultPlatformEncoding for ZFiles, and the default JVM file.encoding property for other files.
This class may be used on non-z/OS platforms so long as MVS filenames are not used, so as to allow for portable text-based IO applications.
see:
ZFilefor more information on specifying MVS dataset names
-
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method and Description static java.lang.StringgetDefaultEncoding(java.lang.String filename)Answer the default encoding assumed for a given filenamestatic java.lang.StringgetDefaultJavaIoEncoding()Answer the default encoding for a java.io file encoding, which defaults to the Java System property "file.encoding".static java.lang.StringgetDefaultZFileEncoding()Answer the default (EBCDIC) encoding for a ZFilestatic java.io.BufferedInputStreamnewBufferedInputStream(java.lang.String filename)Open a new BufferedInputStream on a file with the given name.static java.io.BufferedInputStreamnewBufferedInputStream(java.lang.String filename, int bsize)Open a new BufferedInputStream on a file with the given name.static java.io.BufferedOutputStreamnewBufferedOutputStream(java.lang.String filename)Open a new BufferedOutputStream on a file with the given name.static java.io.BufferedOutputStreamnewBufferedOutputStream(java.lang.String filename, int bsize)Open a new BufferedOutputStream on a file with the given name and buffer size.static java.io.BufferedReadernewBufferedReader(java.lang.String filename)Open a new BufferedReader on a file with the given name, default encoding, and a default buffersize.static java.io.BufferedReadernewBufferedReader(java.lang.String filename, java.lang.String encoding)Open a new BufferedReader on a file with the given name, encoding, and a default buffersize.static java.io.BufferedReadernewBufferedReader(java.lang.String filename, java.lang.String encoding, int bsize)Open a new BufferedReader on a file with the given name, encoding, and buffersize.static java.io.BufferedWriternewBufferedWriter(java.lang.String filename)Open a new BufferedWriter on a file with the given name, default encoding, and default buffersize.static java.io.BufferedWriternewBufferedWriter(java.lang.String filename, java.lang.String encoding)Open a new BufferedWriter on a file with the given name, encoding, and default buffersize.static java.io.BufferedWriternewBufferedWriter(java.lang.String filename, java.lang.String encoding, int bsize)Open a new BufferedWriter on a file with the given name, encoding, and buffersize.static java.io.InputStreamnewInputStream(java.lang.String filename)Open a new unbuffered InputStream on a file with the given name.static java.io.OutputStreamnewOutputStream(java.lang.String filename)Open a new unbuffered OutputStream on a file with the given name.
-
-
-
Method Detail
-
newInputStream
public static java.io.InputStream newInputStream(java.lang.String filename) throws java.io.IOExceptionOpen a new unbuffered InputStream on a file with the given name.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this InputStream.
- Throws:
java.io.IOException
-
newBufferedInputStream
public static java.io.BufferedInputStream newBufferedInputStream(java.lang.String filename, int bsize) throws java.io.IOExceptionOpen a new BufferedInputStream on a file with the given name.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this InputStream.
- Throws:
java.io.IOException
-
newBufferedInputStream
public static java.io.BufferedInputStream newBufferedInputStream(java.lang.String filename) throws java.io.IOExceptionOpen a new BufferedInputStream on a file with the given name.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this InputStream.
- Throws:
java.io.IOException
-
newOutputStream
public static java.io.OutputStream newOutputStream(java.lang.String filename) throws java.io.IOExceptionOpen a new unbuffered OutputStream on a file with the given name.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this OutputStream.
- Throws:
java.io.IOException
-
newBufferedOutputStream
public static java.io.BufferedOutputStream newBufferedOutputStream(java.lang.String filename, int bsize) throws java.io.IOExceptionOpen a new BufferedOutputStream on a file with the given name and buffer size.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this OutputStream.
- Throws:
java.io.IOException
-
newBufferedOutputStream
public static java.io.BufferedOutputStream newBufferedOutputStream(java.lang.String filename) throws java.io.IOExceptionOpen a new BufferedOutputStream on a file with the given name.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this OutputStream.
- Throws:
java.io.IOException
-
newBufferedReader
public static java.io.BufferedReader newBufferedReader(java.lang.String filename, java.lang.String encoding, int bsize) throws java.io.IOExceptionOpen a new BufferedReader on a file with the given name, encoding, and buffersize.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this reader.
- Throws:
java.io.IOException
-
newBufferedReader
public static java.io.BufferedReader newBufferedReader(java.lang.String filename, java.lang.String encoding) throws java.io.IOExceptionOpen a new BufferedReader on a file with the given name, encoding, and a default buffersize.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this reader.
- Throws:
java.io.IOException
-
newBufferedReader
public static java.io.BufferedReader newBufferedReader(java.lang.String filename) throws java.io.IOExceptionOpen a new BufferedReader on a file with the given name, default encoding, and a default buffersize.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this reader.
- Throws:
java.io.IOException
-
newBufferedWriter
public static java.io.BufferedWriter newBufferedWriter(java.lang.String filename, java.lang.String encoding, int bsize) throws java.io.IOExceptionOpen a new BufferedWriter on a file with the given name, encoding, and buffersize.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this reader.
- Throws:
java.io.IOException
-
newBufferedWriter
public static java.io.BufferedWriter newBufferedWriter(java.lang.String filename, java.lang.String encoding) throws java.io.IOExceptionOpen a new BufferedWriter on a file with the given name, encoding, and default buffersize.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this reader.
- Throws:
java.io.IOException
-
newBufferedWriter
public static java.io.BufferedWriter newBufferedWriter(java.lang.String filename) throws java.io.IOExceptionOpen a new BufferedWriter on a file with the given name, default encoding, and default buffersize.File names starting with "//" are assumed to be MVS datasets and are opened using ZFile. Others are opened with regular java.io files.
NB: the client is responsible for closing this reader.
- Throws:
java.io.IOException
-
getDefaultEncoding
public static java.lang.String getDefaultEncoding(java.lang.String filename)
Answer the default encoding assumed for a given filename
-
getDefaultZFileEncoding
public static java.lang.String getDefaultZFileEncoding()
Answer the default (EBCDIC) encoding for a ZFile
-
getDefaultJavaIoEncoding
public static java.lang.String getDefaultJavaIoEncoding()
Answer the default encoding for a java.io file encoding, which defaults to the Java System property "file.encoding".
-
-