Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "components/history/core/browser/visit_database.h" | 5 #include "components/history/core/browser/visit_database.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <limits> | 8 #include <limits> |
| 9 #include <map> | 9 #include <map> |
| 10 #include <set> | 10 #include <set> |
| (...skipping 519 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 530 } | 530 } |
| 531 | 531 |
| 532 if (!statement.Succeeded()) | 532 if (!statement.Succeeded()) |
| 533 return false; | 533 return false; |
| 534 | 534 |
| 535 *first_visit = base::Time::FromInternalValue(statement.ColumnInt64(0)); | 535 *first_visit = base::Time::FromInternalValue(statement.ColumnInt64(0)); |
| 536 *count = statement.ColumnInt(1); | 536 *count = statement.ColumnInt(1); |
| 537 return true; | 537 return true; |
| 538 } | 538 } |
| 539 | 539 |
| 540 bool VisitDatabase::GetHistoryCount(int* count) { | 540 bool VisitDatabase::GetHistoryCount(const base::Time& begin_time, |
| 541 const base::Time& end_time, | |
| 542 int* count) { | |
| 541 sql::Statement statement(GetDB().GetCachedStatement(SQL_FROM_HERE, | 543 sql::Statement statement(GetDB().GetCachedStatement(SQL_FROM_HERE, |
| 542 "SELECT COUNT(*) FROM (" | 544 "SELECT COUNT(*) FROM (" |
| 543 "SELECT DISTINCT url, " | 545 "SELECT DISTINCT url, " |
| 544 // Convert unit of timestamp from the numbers of microseconds since | 546 // Convert unit of timestamp from the numbers of microseconds since |
| 545 // Windows Epoch to the number of seconds from Unix Epoch. Leap seconds | 547 // Windows Epoch to the number of seconds from Unix Epoch. Leap seconds |
| 546 // are not handled in both timestamp units, so a linear conversion is | 548 // are not handled in both timestamp units, so a linear conversion is |
| 547 // valid here. | 549 // valid here. |
| 548 "DATE((visit_time - ?) / ?, 'unixepoch', 'localtime') " | 550 "DATE((visit_time - ?) / ?, 'unixepoch', 'localtime')" |
| 549 "FROM visits " | 551 "FROM visits " |
| 550 "WHERE (transition & ?) != 0 " // CHAIN_END | 552 "WHERE (transition & ?) != 0 " // CHAIN_END |
| 551 "AND (transition & ?) NOT IN (?, ?, ?)" // NO SUBFRAME or | 553 "AND (transition & ?) NOT IN (?, ?, ?) " // NO SUBFRAME or |
| 552 // KEYWORD_GENERATED | 554 // KEYWORD_GENERATED |
| 555 "AND visit_time >= ? AND visit_time < ?" | |
| 553 ")")); | 556 ")")); |
| 554 | 557 |
| 555 statement.BindInt64(0, base::Time::kTimeTToMicrosecondsOffset); | 558 statement.BindInt64(0, base::Time::kTimeTToMicrosecondsOffset); |
|
lwchkg
2015/09/25 04:15:02
Just to remind that you have proposed to change th
msramek
2015/09/25 10:44:35
I keep it in mind, but I'll fix this in a separate
| |
| 556 statement.BindInt64(1, base::Time::kMicrosecondsPerSecond); | 559 statement.BindInt64(1, base::Time::kMicrosecondsPerSecond); |
| 557 statement.BindInt(2, ui::PAGE_TRANSITION_CHAIN_END); | 560 statement.BindInt(2, ui::PAGE_TRANSITION_CHAIN_END); |
| 558 statement.BindInt(3, ui::PAGE_TRANSITION_CORE_MASK); | 561 statement.BindInt(3, ui::PAGE_TRANSITION_CORE_MASK); |
| 559 statement.BindInt(4, ui::PAGE_TRANSITION_AUTO_SUBFRAME); | 562 statement.BindInt(4, ui::PAGE_TRANSITION_AUTO_SUBFRAME); |
| 560 statement.BindInt(5, ui::PAGE_TRANSITION_MANUAL_SUBFRAME); | 563 statement.BindInt(5, ui::PAGE_TRANSITION_MANUAL_SUBFRAME); |
| 561 statement.BindInt(6, ui::PAGE_TRANSITION_KEYWORD_GENERATED); | 564 statement.BindInt(6, ui::PAGE_TRANSITION_KEYWORD_GENERATED); |
| 565 statement.BindInt64(7, begin_time.ToInternalValue()); | |
| 566 statement.BindInt64(8, end_time.ToInternalValue()); | |
| 562 | 567 |
| 563 if (!statement.Step()) | 568 if (!statement.Step()) |
| 564 return false; | 569 return false; |
| 565 | 570 |
| 566 *count = statement.ColumnInt(0); | 571 *count = statement.ColumnInt(0); |
| 567 return true; | 572 return true; |
| 568 } | 573 } |
| 569 | 574 |
| 570 bool VisitDatabase::GetStartDate(base::Time* first_visit) { | 575 bool VisitDatabase::GetStartDate(base::Time* first_visit) { |
| 571 sql::Statement statement(GetDB().GetCachedStatement(SQL_FROM_HERE, | 576 sql::Statement statement(GetDB().GetCachedStatement(SQL_FROM_HERE, |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 624 // Old versions don't have the visit_duration column, we modify the table | 629 // Old versions don't have the visit_duration column, we modify the table |
| 625 // to add that field. | 630 // to add that field. |
| 626 if (!GetDB().Execute("ALTER TABLE visits " | 631 if (!GetDB().Execute("ALTER TABLE visits " |
| 627 "ADD COLUMN visit_duration INTEGER DEFAULT 0 NOT NULL")) | 632 "ADD COLUMN visit_duration INTEGER DEFAULT 0 NOT NULL")) |
| 628 return false; | 633 return false; |
| 629 } | 634 } |
| 630 return true; | 635 return true; |
| 631 } | 636 } |
| 632 | 637 |
| 633 } // namespace history | 638 } // namespace history |
| OLD | NEW |