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 267 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
278 // use the previous year. | 278 // use the previous year. |
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 local time. | 288 // We don't know the time zone of the listing, so just use local time. |
maksims (do not use this acc)
2016/10/05 12:59:02
Problem is with this one. The guess is bad, actual
| |
289 *result = base::Time::FromLocalExploded(time_exploded); | 289 return base::Time::FromLocalExploded(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 local time. | 350 // We don't know the time zone of the server, so just use local time. |
352 *result = base::Time::FromLocalExploded(time_exploded); | 351 return base::Time::FromLocalExploded(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 |