| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 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 | 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 #include "net/ftp/ftp_util.h" | 5 #include "net/ftp/ftp_util.h" |
| 6 | 6 |
| 7 #include <map> | 7 #include <map> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/i18n/case_conversion.h" | 10 #include "base/i18n/case_conversion.h" |
| (...skipping 268 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 279 if (time_exploded.month > current_exploded.month || | 279 if (time_exploded.month > current_exploded.month || |
| 280 (time_exploded.month == current_exploded.month && | 280 (time_exploded.month == current_exploded.month && |
| 281 time_exploded.day_of_month > current_exploded.day_of_month)) { | 281 time_exploded.day_of_month > current_exploded.day_of_month)) { |
| 282 time_exploded.year = current_exploded.year - 1; | 282 time_exploded.year = current_exploded.year - 1; |
| 283 } else { | 283 } else { |
| 284 time_exploded.year = current_exploded.year; | 284 time_exploded.year = current_exploded.year; |
| 285 } | 285 } |
| 286 } | 286 } |
| 287 | 287 |
| 288 // We don't know the time zone of the listing, so just use UTC. | 288 // We don't know the time zone of the listing, so just use UTC. |
| 289 *result = base::Time::FromUTCExploded(time_exploded); | 289 return base::Time::FromUTCExploded(time_exploded, result); |
| 290 return true; | |
| 291 } | 290 } |
| 292 | 291 |
| 293 // static | 292 // static |
| 294 bool FtpUtil::WindowsDateListingToTime(const base::string16& date, | 293 bool FtpUtil::WindowsDateListingToTime(const base::string16& date, |
| 295 const base::string16& time, | 294 const base::string16& time, |
| 296 base::Time* result) { | 295 base::Time* result) { |
| 297 base::Time::Exploded time_exploded = { 0 }; | 296 base::Time::Exploded time_exploded = { 0 }; |
| 298 | 297 |
| 299 // Date should be in format MM-DD-YY[YY]. | 298 // Date should be in format MM-DD-YY[YY]. |
| 300 std::vector<base::StringPiece16> date_parts = | 299 std::vector<base::StringPiece16> date_parts = |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 342 time_exploded.hour += 12; | 341 time_exploded.hour += 12; |
| 343 } else if (base::EqualsASCII(am_or_pm, "AM")) { | 342 } else if (base::EqualsASCII(am_or_pm, "AM")) { |
| 344 if (time_exploded.hour == 12) | 343 if (time_exploded.hour == 12) |
| 345 time_exploded.hour = 0; | 344 time_exploded.hour = 0; |
| 346 } else { | 345 } else { |
| 347 return false; | 346 return false; |
| 348 } | 347 } |
| 349 } | 348 } |
| 350 | 349 |
| 351 // We don't know the time zone of the server, so just use UTC. | 350 // We don't know the time zone of the server, so just use UTC. |
| 352 *result = base::Time::FromUTCExploded(time_exploded); | 351 return base::Time::FromUTCExploded(time_exploded, result); |
| 353 return true; | |
| 354 } | 352 } |
| 355 | 353 |
| 356 // static | 354 // static |
| 357 base::string16 FtpUtil::GetStringPartAfterColumns(const base::string16& text, | 355 base::string16 FtpUtil::GetStringPartAfterColumns(const base::string16& text, |
| 358 int columns) { | 356 int columns) { |
| 359 base::i18n::UTF16CharIterator iter(&text); | 357 base::i18n::UTF16CharIterator iter(&text); |
| 360 | 358 |
| 361 for (int i = 0; i < columns; i++) { | 359 for (int i = 0; i < columns; i++) { |
| 362 // Skip the leading whitespace. | 360 // Skip the leading whitespace. |
| 363 while (!iter.end() && u_isspace(iter.get())) | 361 while (!iter.end() && u_isspace(iter.get())) |
| 364 iter.Advance(); | 362 iter.Advance(); |
| 365 | 363 |
| 366 // Skip the actual text of i-th column. | 364 // Skip the actual text of i-th column. |
| 367 while (!iter.end() && !u_isspace(iter.get())) | 365 while (!iter.end() && !u_isspace(iter.get())) |
| 368 iter.Advance(); | 366 iter.Advance(); |
| 369 } | 367 } |
| 370 | 368 |
| 371 base::string16 result(text.substr(iter.array_pos())); | 369 base::string16 result(text.substr(iter.array_pos())); |
| 372 base::TrimWhitespace(result, base::TRIM_ALL, &result); | 370 base::TrimWhitespace(result, base::TRIM_ALL, &result); |
| 373 return result; | 371 return result; |
| 374 } | 372 } |
| 375 | 373 |
| 376 } // namespace net | 374 } // namespace net |
| OLD | NEW |