Home | History | Annotate | Download | only in ftp
      1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #include "net/ftp/ftp_directory_listing_parser_windows.h"
      6 
      7 #include <vector>
      8 
      9 #include "base/strings/string_number_conversions.h"
     10 #include "base/strings/string_split.h"
     11 #include "base/strings/string_util.h"
     12 #include "base/time/time.h"
     13 #include "net/ftp/ftp_directory_listing_parser.h"
     14 #include "net/ftp/ftp_util.h"
     15 
     16 namespace net {
     17 
     18 bool ParseFtpDirectoryListingWindows(
     19     const std::vector<base::string16>& lines,
     20     std::vector<FtpDirectoryListingEntry>* entries) {
     21   for (size_t i = 0; i < lines.size(); i++) {
     22     if (lines[i].empty())
     23       continue;
     24 
     25     std::vector<base::string16> columns;
     26     base::SplitString(CollapseWhitespace(lines[i], false), ' ', &columns);
     27 
     28     // Every line of the listing consists of the following:
     29     //
     30     //   1. date
     31     //   2. time
     32     //   3. size in bytes (or "<DIR>" for directories)
     33     //   4. filename (may be empty or contain spaces)
     34     //
     35     // For now, make sure we have 1-3, and handle 4 later.
     36     if (columns.size() < 3)
     37       return false;
     38 
     39     FtpDirectoryListingEntry entry;
     40     if (EqualsASCII(columns[2], "<DIR>")) {
     41       entry.type = FtpDirectoryListingEntry::DIRECTORY;
     42       entry.size = -1;
     43     } else {
     44       entry.type = FtpDirectoryListingEntry::FILE;
     45       if (!base::StringToInt64(columns[2], &entry.size))
     46         return false;
     47       if (entry.size < 0)
     48         return false;
     49     }
     50 
     51     if (!FtpUtil::WindowsDateListingToTime(columns[0],
     52                                            columns[1],
     53                                            &entry.last_modified)) {
     54       return false;
     55     }
     56 
     57     entry.name = FtpUtil::GetStringPartAfterColumns(lines[i], 3);
     58     if (entry.name.empty()) {
     59       // Some FTP servers send listing entries with empty names.
     60       // It's not obvious how to display such an entry, so ignore them.
     61       // We don't want to make the parsing fail at this point though.
     62       // Other entries can still be useful.
     63       continue;
     64     }
     65 
     66     entries->push_back(entry);
     67   }
     68 
     69   return true;
     70 }
     71 
     72 }  // namespace net
     73