⇒ Index (Frames) |  ⇒ Index (No Frames) |  ⇒ Package |  ⇒ Package Tree |  ⇒ Full Tree 
org.apache.commons.net.ftp.parser

Class VMSFTPEntryParser

java.lang.Object
|
+--org.apache.commons.net.ftp.FTPFileEntryParserImpl
   |
   +--org.apache.commons.net.ftp.parser.RegexFTPFileEntryParserImpl
      |
      +--org.apache.commons.net.ftp.parser.VMSFTPEntryParser

Known Direct Subclasses:
VMSVersioningFTPEntryParser


public class VMSFTPEntryParser
extends RegexFTPFileEntryParserImpl

Implementation FTPFileEntryParser and FTPFileListParser for VMS Systems. This is a sample of VMS LIST output "1-JUN.LIS;1 9/9 2-JUN-1998 07:32:04 [GROUP,OWNER] (RWED,RWED,RWED,RE)", "1-JUN.LIS;2 9/9 2-JUN-1998 07:32:04 [GROUP,OWNER] (RWED,RWED,RWED,RE)", "DATA.DIR;1 1/9 2-JUN-1998 07:32:04 [GROUP,OWNER] (RWED,RWED,RWED,RE)",

Note: VMSFTPEntryParser can only be instantiated through the DefaultFTPParserFactory by classname. It will not be chosen by the autodetection scheme.

Authors:
See Also:
org.apache.commons.net.ftp.FTPFileEntryParser FTPFileEntryParser (for usage instructions)
org.apache.commons.net.ftp.parser.DefaultFTPFileEntryParserFactory

Constructor Summary

VMSFTPEntryParser()

Constructor for a VMSFTPEntryParser object.

Method Summary

boolean

isVersioning()

FTPFile

parseFTPEntry(String entry)

Parses a line of a VMS FTP server file listing and converts it into a usable format in the form of an FTPFile instance.

FTPFile[]

parseFileList(InputStream listStream)

Parses an FTP server file listing and converts it into a usable format in the form of an array of FTPFile instances.

String

readNextEntry(BufferedReader reader)

Reads the next entry using the supplied BufferedReader object up to whatever delemits one entry from the next.

Constructor Details

VMSFTPEntryParser

public VMSFTPEntryParser()

Constructor for a VMSFTPEntryParser object.

Throws:
- Thrown if the regular expression is unparseable.

Method Details

isVersioning

protected boolean isVersioning()


parseFTPEntry

public FTPFile parseFTPEntry(String entry)

Parses a line of a VMS FTP server file listing and converts it into a usable format in the form of an FTPFile instance. If the file listing line doesn't describe a file, null is returned, otherwise a FTPFile instance representing the files in the directory is returned.

Parameters:
entry - A line of text from the file listing
Returns:
An FTPFile instance corresponding to the supplied entry

parseFileList

public FTPFile[] parseFileList(InputStream listStream)

Parses an FTP server file listing and converts it into a usable format in the form of an array of FTPFile instances. If the file list contains no files, null should be returned, otherwise an array of FTPFile instances representing the files in the directory is returned.

Parameters:
listStream - The InputStream from which the file list should be read.
Returns:
The list of file information contained in the given path. null if the list could not be obtained or if there are no files in the directory.
Throws:
- If an I/O error occurs reading the listStream.

readNextEntry

public String readNextEntry(BufferedReader reader)

Reads the next entry using the supplied BufferedReader object up to whatever delemits one entry from the next. This parser cannot use the default implementation of simply calling BufferedReader.readLine(), because one entry may span multiple lines.

Parameters:
reader - The BufferedReader object from which entries are to be read.
Returns:
A string representing the next ftp entry or null if none found.
Throws:
- thrown on any IO Error reading from the reader.