OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Version: MPL 1.1/GPL 2.0/LGPL 2.1 | 5 // Version: MPL 1.1/GPL 2.0/LGPL 2.1 |
6 // The contents of this file are subject to the Mozilla Public License Version | 6 // The contents of this file are subject to the Mozilla Public License Version |
7 // 1.1 (the "License"); you may not use this file except in compliance with | 7 // 1.1 (the "License"); you may not use this file except in compliance with |
8 // the License. You may obtain a copy of the License at | 8 // the License. You may obtain a copy of the License at |
9 // http://www.mozilla.org/MPL/ | 9 // http://www.mozilla.org/MPL/ |
10 // Software distributed under the License is distributed on an "AS IS" basis, | 10 // Software distributed under the License is distributed on an "AS IS" basis, |
(...skipping 23 matching lines...) Expand all Loading... |
34 // the provisions above, a recipient may use your version of this file under | 34 // the provisions above, a recipient may use your version of this file under |
35 // the terms of any one of the MPL, the GPL or the LGPL. | 35 // the terms of any one of the MPL, the GPL or the LGPL. |
36 | 36 |
37 // Derived from: | 37 // Derived from: |
38 // mozilla/netwerk/streamconv/converters/ParseFTPList.h revision 1.3 | 38 // mozilla/netwerk/streamconv/converters/ParseFTPList.h revision 1.3 |
39 | 39 |
40 | 40 |
41 #ifndef NET_FTP_FTP_DIRECTORY_PARSER_H_ | 41 #ifndef NET_FTP_FTP_DIRECTORY_PARSER_H_ |
42 #define NET_FTP_FTP_DIRECTORY_PARSER_H_ | 42 #define NET_FTP_FTP_DIRECTORY_PARSER_H_ |
43 | 43 |
44 #include <time.h> | 44 #include "base/time.h" |
45 | |
46 #include "base/basictypes.h" | |
47 | 45 |
48 namespace net { | 46 namespace net { |
49 | 47 |
50 struct ListState { | 48 struct ListState { |
51 void* magic; // to determine if previously initialized | 49 void* magic; // to determine if previously |
52 int64 now_time; // needed for year determination. | 50 // initialized. |
53 struct tm now_tm; // needed for year determination. | 51 int now_tm_valid; // now_tm contains a valid time? |
54 int lstyle; // LISTing style. | 52 base::Time::Exploded now_tm; // needed for year determination. |
55 int parsed_one; // returned anything yet? | 53 int lstyle; // LISTing style. |
56 char carry_buf[84]; // for VMS multiline. | 54 int parsed_one; // returned anything yet? |
57 unsigned int carry_buf_len; // length of name in carry_buf. | 55 char carry_buf[84]; // for VMS multiline. |
58 unsigned int numlines; // number of lines seen. | 56 unsigned int carry_buf_len; // length of name in carry_buf. |
| 57 unsigned int numlines; // number of lines seen. |
59 }; | 58 }; |
60 | 59 |
61 enum LineType { | 60 enum LineType { |
62 FTP_TYPE_DIRECTORY, // LIST line is a directory entry ('result' is valid). | 61 FTP_TYPE_DIRECTORY, // LIST line is a directory entry ('result' is valid). |
63 FTP_TYPE_FILE, // LIST line is a file's entry ('result' is valid). | 62 FTP_TYPE_FILE, // LIST line is a file's entry ('result' is valid). |
64 FTP_TYPE_SYMLINK, // LIST line is a symlink's entry ('result' is valid). | 63 FTP_TYPE_SYMLINK, // LIST line is a symlink's entry ('result' is valid). |
65 FTP_TYPE_JUNK, // LIST line is junk. (cwd, non-file/dir/link, etc). | 64 FTP_TYPE_JUNK, // LIST line is junk. (cwd, non-file/dir/link, etc). |
66 FTP_TYPE_COMMENT // Its not a LIST line (its a "comment"). | 65 FTP_TYPE_COMMENT // Its not a LIST line (its a "comment"). |
67 }; | 66 }; |
68 | 67 |
69 struct ListResult { | 68 struct ListResult { |
70 LineType fe_type; | 69 LineType fe_type; |
71 const char* fe_fname; // pointer to filename | 70 const char* fe_fname; // pointer to filename |
72 unsigned int fe_fnlen; // length of filename | 71 unsigned int fe_fnlen; // length of filename |
73 const char* fe_lname; // pointer to symlink name | 72 const char* fe_lname; // pointer to symlink name |
74 unsigned int fe_lnlen; // length of symlink name | 73 unsigned int fe_lnlen; // length of symlink name |
75 char fe_size[40]; // size of file in bytes (<= (2^128 - 1)) | 74 char fe_size[40]; // size of file in bytes |
76 int fe_cinfs; // file system is definitely case insensitive | 75 // (<= (2^128 - 1)) |
77 // TODO(ibrar): We should use "base::Time::Exploded" instead of "tm" | 76 base::Time::Exploded fe_time; // last-modified time |
78 struct tm fe_time; // last-modified time | 77 int fe_cinfs; // file system is definitely |
| 78 // case insensitive |
79 }; | 79 }; |
80 | 80 |
81 // ParseFTPLine() parses line from an FTP LIST command. | 81 // ParseFTPLine() parses line from an FTP LIST command. |
82 // | 82 // |
83 // Written July 2002 by Cyrus Patel <cyp@fb14.uni-mainz.de> | 83 // Written July 2002 by Cyrus Patel <cyp@fb14.uni-mainz.de> |
84 // with acknowledgements to squid, lynx, wget and ftpmirror. | 84 // with acknowledgements to squid, lynx, wget and ftpmirror. |
85 // | 85 // |
86 // Arguments: | 86 // Arguments: |
87 // 'line': line of FTP data connection output. The line is assumed | 87 // 'line': line of FTP data connection output. The line is assumed |
88 // to end at the first '\0' or '\n' or '\r\n'. | 88 // to end at the first '\0' or '\n' or '\r\n'. |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 // between an error message and an NLST line would require ParseList() to | 125 // between an error message and an NLST line would require ParseList() to |
126 // recognize all the possible strerror() messages in the world. | 126 // recognize all the possible strerror() messages in the world. |
127 | 127 |
128 LineType ParseFTPLine(const char *line, | 128 LineType ParseFTPLine(const char *line, |
129 struct ListState *state, | 129 struct ListState *state, |
130 struct ListResult *result); | 130 struct ListResult *result); |
131 | 131 |
132 } // namespace net | 132 } // namespace net |
133 | 133 |
134 #endif // NET_FTP_FTP_DIRECTORY_PARSER_H_ | 134 #endif // NET_FTP_FTP_DIRECTORY_PARSER_H_ |
OLD | NEW |