blob: 83b19820cc3944449a871ef2416fbb0a82c855e3 [file] [log] [blame]
// Copyright (c) 2009 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Version: MPL 1.1/GPL 2.0/LGPL 2.1
// The contents of this file are subject to the Mozilla Public License Version
// 1.1 (the "License"); you may not use this file except in compliance with
// the License. You may obtain a copy of the License at
// http://www.mozilla.org/MPL/
// Software distributed under the License is distributed on an "AS IS" basis,
// WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
// for the specific language governing rights and limitations under the
// License.
//
// The Original Code is mozilla.org Code.
//
// The Initial Developer of the Original Code is
// Cyrus Patel <cyp@fb14.uni-mainz.de>.
// Portions created by the Initial Developer are Copyright (C) 2002
// the Initial Developer. All Rights Reserved.
//
// Contributor(s):
// Doug Turner <dougt@netscape.com>
//
// Alternatively, the contents of this file may be used under the terms of
// either the GNU General Public License Version 2 or later (the "GPL"), or
// the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
// in which case the provisions of the GPL or the LGPL are applicable instead
// of those above. If you wish to allow use of your version of this file only
// under the terms of either the GPL or the LGPL, and not to allow others to
// use your version of this file under the terms of the MPL, indicate your
// decision by deleting the provisions above and replace them with the notice
// and other provisions required by the GPL or the LGPL. If you do not delete
// the provisions above, a recipient may use your version of this file under
// the terms of any one of the MPL, the GPL or the LGPL.
// Derived from:
// mozilla/netwerk/streamconv/converters/ParseFTPList.h revision 1.3
#ifndef NET_FTP_FTP_DIRECTORY_PARSER_H_
#define NET_FTP_FTP_DIRECTORY_PARSER_H_
#include <time.h>
#include "base/basictypes.h"
namespace net {
struct ListState {
void* magic; // to determine if previously initialized
int64 now_time; // needed for year determination.
struct tm now_tm; // needed for year determination.
int lstyle; // LISTing style.
int parsed_one; // returned anything yet?
char carry_buf[84]; // for VMS multiline.
unsigned int carry_buf_len; // length of name in carry_buf.
unsigned int numlines; // number of lines seen.
};
enum LineType {
FTP_TYPE_DIRECTORY, // LIST line is a directory entry ('result' is valid).
FTP_TYPE_FILE, // LIST line is a file's entry ('result' is valid).
FTP_TYPE_SYMLINK, // LIST line is a symlink's entry ('result' is valid).
FTP_TYPE_JUNK, // LIST line is junk. (cwd, non-file/dir/link, etc).
FTP_TYPE_COMMENT // Its not a LIST line (its a "comment").
};
struct ListResult {
LineType fe_type;
const char* fe_fname; // pointer to filename
unsigned int fe_fnlen; // length of filename
const char* fe_lname; // pointer to symlink name
unsigned int fe_lnlen; // length of symlink name
char fe_size[40]; // size of file in bytes (<= (2^128 - 1))
int fe_cinfs; // file system is definitely case insensitive
// TODO(ibrar): We should use "base::Time::Exploded" instead of "tm"
struct tm fe_time; // last-modified time
};
// ParseFTPLine() parses line from an FTP LIST command.
//
// Written July 2002 by Cyrus Patel <cyp@fb14.uni-mainz.de>
// with acknowledgements to squid, lynx, wget and ftpmirror.
//
// Arguments:
// 'line': line of FTP data connection output. The line is assumed
// to end at the first '\0' or '\n' or '\r\n'.
// 'state': a structure used internally to track state between
// lines. Needs to be bzero()'d at LIST begin.
// 'result': where ParseFTPList will store the results of the parse
// if 'line' is not a comment and is not junk.
//
// Returns one of the following:
// 'd' - LIST line is a directory entry ('result' is valid)
// 'f' - LIST line is a file's entry ('result' is valid)
// 'l' - LIST line is a symlink's entry ('result' is valid)
// '?' - LIST line is junk. (cwd, non-file/dir/link, etc)
// '"' - its not a LIST line (its a "comment")
//
// It may be advisable to let the end-user see "comments" (particularly when
// the listing results in ONLY such lines) because such a listing may be:
// - an unknown LIST format (NLST or "custom" format for example)
// - an error msg (EPERM,ENOENT,ENFILE,EMFILE,ENOTDIR,ENOTBLK,EEXDEV etc).
// - an empty directory and the 'comment' is a "total 0" line or similar.
// (warning: a "total 0" can also mean the total size is unknown).
//
// ParseFTPList() supports all known FTP LISTing formats:
// - '/bin/ls -l' and all variants (including Hellsoft FTP for NetWare);
// - EPLF (Easily Parsable List Format);
// - Windows NT's default "DOS-dirstyle";
// - OS/2 basic server format LIST format;
// - VMS (MultiNet, UCX, and CMU) LIST format (including multi-line format);
// - IBM VM/CMS, VM/ESA LIST format (two known variants);
// - SuperTCP FTP Server for Win16 LIST format;
// - NetManage Chameleon (NEWT) for Win16 LIST format;
// - '/bin/dls' (two known variants, plus multi-line) LIST format;
// If there are others, then I'd like to hear about them (send me a sample).
//
// NLSTings are not supported explicitely because they cannot be machine
// parsed consistently: NLSTings do not have unique characteristics - even
// the assumption that there won't be whitespace on the line does not hold
// because some nlistings have more than one filename per line and/or
// may have filenames that have spaces in them. Moreover, distinguishing
// between an error message and an NLST line would require ParseList() to
// recognize all the possible strerror() messages in the world.
LineType ParseFTPLine(const char *line,
struct ListState *state,
struct ListResult *result);
} // namespace net
#endif // NET_FTP_FTP_DIRECTORY_PARSER_H_