| Index: net/ftp/ftp_directory_listing_parser.cc | 
| diff --git a/net/ftp/ftp_directory_listing_parser.cc b/net/ftp/ftp_directory_listing_parser.cc | 
| index d7c7c7d3b281cb84b6c271d926868a8588271392..3cacee07619e59d93bc0e9f286811226ac9ba30c 100644 | 
| --- a/net/ftp/ftp_directory_listing_parser.cc | 
| +++ b/net/ftp/ftp_directory_listing_parser.cc | 
| @@ -11,6 +11,7 @@ | 
| #include "base/stl_util.h" | 
| #include "base/string_split.h" | 
| #include "base/string_util.h" | 
| +#include "base/utf_string_conversions.h" | 
| #include "net/base/net_errors.h" | 
| #include "net/ftp/ftp_directory_listing_parser_ls.h" | 
| #include "net/ftp/ftp_directory_listing_parser_netware.h" | 
| @@ -41,12 +42,13 @@ int FillInRawName(const std::string& encoding, | 
| // Parses |text| as an FTP directory listing. Fills in |entries| | 
| // and |server_type| and returns network error code. | 
| int ParseListing(const string16& text, | 
| +                 const string16& newline_separator, | 
| const std::string& encoding, | 
| const base::Time& current_time, | 
| std::vector<FtpDirectoryListingEntry>* entries, | 
| FtpServerType* server_type) { | 
| std::vector<string16> lines; | 
| -  base::SplitString(text, '\n', &lines); | 
| +  base::SplitStringUsingSubstr(text, newline_separator, &lines); | 
|  | 
| struct { | 
| base::Callback<bool(void)> callback; | 
| @@ -93,6 +95,8 @@ int DecodeAndParse(const std::string& text, | 
| const base::Time& current_time, | 
| std::vector<FtpDirectoryListingEntry>* entries, | 
| FtpServerType* server_type) { | 
| +  const char* kNewlineSeparators[] = { "\n", "\r\n" }; | 
| + | 
| std::vector<std::string> encodings; | 
| if (!base::DetectAllEncodings(text, &encodings)) | 
| return ERR_ENCODING_DETECTION_FAILED; | 
| @@ -104,13 +108,16 @@ int DecodeAndParse(const std::string& text, | 
| encodings[i].c_str(), | 
| base::OnStringConversionError::FAIL, | 
| &converted_text)) { | 
| -      int rv = ParseListing(converted_text, | 
| -                            encodings[i], | 
| -                            current_time, | 
| -                            entries, | 
| -                            server_type); | 
| -      if (rv == OK) | 
| -        return rv; | 
| +      for (size_t j = 0; j < arraysize(kNewlineSeparators); j++) { | 
| +        int rv = ParseListing(converted_text, | 
| +                              ASCIIToUTF16(kNewlineSeparators[j]), | 
| +                              encodings[i], | 
| +                              current_time, | 
| +                              entries, | 
| +                              server_type); | 
| +        if (rv == OK) | 
| +          return rv; | 
| +      } | 
| } | 
| } | 
|  | 
|  |