Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(66)

Side by Side Diff: chrome/browser/ui/omnibox/omnibox_edit_model.cc

Issue 229583002: Omnibox Logging Clarifications (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: peter's comments Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 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 "chrome/browser/ui/omnibox/omnibox_edit_model.h" 5 #include "chrome/browser/ui/omnibox/omnibox_edit_model.h"
6 6
7 #include <string> 7 #include <string>
8 8
9 #include "base/auto_reset.h" 9 #include "base/auto_reset.h"
10 #include "base/format_macros.h" 10 #include "base/format_macros.h"
(...skipping 656 matching lines...) Expand 10 before | Expand all | Expand 10 after
667 // When the user pasted in a URL and hit enter, score it like a link click 667 // When the user pasted in a URL and hit enter, score it like a link click
668 // rather than a normal typed URL, so it doesn't get inline autocompleted 668 // rather than a normal typed URL, so it doesn't get inline autocompleted
669 // as aggressively later. 669 // as aggressively later.
670 match.transition = content::PAGE_TRANSITION_LINK; 670 match.transition = content::PAGE_TRANSITION_LINK;
671 } 671 }
672 672
673 const TemplateURL* template_url = match.GetTemplateURL(profile_, false); 673 const TemplateURL* template_url = match.GetTemplateURL(profile_, false);
674 if (template_url && template_url->url_ref().HasGoogleBaseURLs()) 674 if (template_url && template_url->url_ref().HasGoogleBaseURLs())
675 GoogleURLTracker::GoogleURLSearchCommitted(profile_); 675 GoogleURLTracker::GoogleURLSearchCommitted(profile_);
676 676
677 view_->OpenMatch(match, disposition, alternate_nav_url, base::string16(), 677 view_->OpenMatch(
678 OmniboxPopupModel::kNoMatch); 678 match, disposition, alternate_nav_url, base::string16(),
679 popup_model() ?
Peter Kasting 2014/04/08 23:02:20 Can we really have no popup model here? Maybe in
Mark P 2014/04/08 23:05:01 I didn't actually try skipping this test. Do you
Mark P 2014/04/09 00:16:04 Done. Running it through the try servers now. (I
680 popup_model()->selected_line() : OmniboxPopupModel::kNoMatch);
679 } 681 }
680 682
681 void OmniboxEditModel::OpenMatch(AutocompleteMatch match, 683 void OmniboxEditModel::OpenMatch(AutocompleteMatch match,
682 WindowOpenDisposition disposition, 684 WindowOpenDisposition disposition,
683 const GURL& alternate_nav_url, 685 const GURL& alternate_nav_url,
684 const base::string16& pasted_text, 686 const base::string16& pasted_text,
685 size_t index) { 687 size_t index) {
686 const base::TimeTicks& now(base::TimeTicks::Now()); 688 const base::TimeTicks& now(base::TimeTicks::Now());
687 base::TimeDelta elapsed_time_since_user_first_modified_omnibox( 689 base::TimeDelta elapsed_time_since_user_first_modified_omnibox(
688 now - time_user_first_modified_omnibox_); 690 now - time_user_first_modified_omnibox_);
(...skipping 19 matching lines...) Expand all
708 // (because the user does not modify the omnibox for ZeroSuggest), so for 710 // (because the user does not modify the omnibox for ZeroSuggest), so for
709 // those we set the elapsed times to something that will be ignored by 711 // those we set the elapsed times to something that will be ignored by
710 // metrics_log.cc. 712 // metrics_log.cc.
711 if (match.provider && 713 if (match.provider &&
712 (match.provider->type() == AutocompleteProvider::TYPE_ZERO_SUGGEST)) { 714 (match.provider->type() == AutocompleteProvider::TYPE_ZERO_SUGGEST)) {
713 elapsed_time_since_user_first_modified_omnibox = 715 elapsed_time_since_user_first_modified_omnibox =
714 base::TimeDelta::FromMilliseconds(-1); 716 base::TimeDelta::FromMilliseconds(-1);
715 elapsed_time_since_last_change_to_default_match = 717 elapsed_time_since_last_change_to_default_match =
716 base::TimeDelta::FromMilliseconds(-1); 718 base::TimeDelta::FromMilliseconds(-1);
717 } 719 }
720 DCHECK_NE(OmniboxPopupModel::kNoMatch, index);
718 OmniboxLog log( 721 OmniboxLog log(
719 input_text, 722 input_text,
720 just_deleted_text_, 723 just_deleted_text_,
721 autocomplete_controller()->input().type(), 724 autocomplete_controller()->input().type(),
722 popup_model()->selected_line(), 725 index,
723 -1, // don't yet know tab ID; set later if appropriate 726 -1, // don't yet know tab ID; set later if appropriate
724 ClassifyPage(), 727 ClassifyPage(),
725 elapsed_time_since_user_first_modified_omnibox, 728 elapsed_time_since_user_first_modified_omnibox,
726 match.inline_autocompletion.length(), 729 match.inline_autocompletion.length(),
727 elapsed_time_since_last_change_to_default_match, 730 elapsed_time_since_last_change_to_default_match,
728 result()); 731 result());
729 732
730 DCHECK(user_input_in_progress_ || (match.provider && 733 DCHECK(user_input_in_progress_ || (match.provider &&
731 (match.provider->type() == AutocompleteProvider::TYPE_ZERO_SUGGEST))) 734 (match.provider->type() == AutocompleteProvider::TYPE_ZERO_SUGGEST)))
732 << "We didn't get here through the expected series of calls. " 735 << "We didn't get here through the expected series of calls. "
733 << "time_user_first_modified_omnibox_ is not set correctly and other " 736 << "time_user_first_modified_omnibox_ is not set correctly and other "
734 << "things may be wrong. Match provider: " 737 << "things may be wrong. Match provider: "
735 << (match.provider ? match.provider->GetName() : "NULL"); 738 << (match.provider ? match.provider->GetName() : "NULL");
736 DCHECK(log.elapsed_time_since_user_first_modified_omnibox >= 739 DCHECK(log.elapsed_time_since_user_first_modified_omnibox >=
737 log.elapsed_time_since_last_change_to_default_match) 740 log.elapsed_time_since_last_change_to_default_match)
738 << "We should've got the notification that the user modified the " 741 << "We should've got the notification that the user modified the "
739 << "omnibox text at same time or before the most recent time the " 742 << "omnibox text at same time or before the most recent time the "
740 << "default match changed."; 743 << "default match changed.";
741 744
742 if (index != OmniboxPopupModel::kNoMatch)
743 log.selected_index = index;
744
745 if ((disposition == CURRENT_TAB) && delegate_->CurrentPageExists()) { 745 if ((disposition == CURRENT_TAB) && delegate_->CurrentPageExists()) {
746 // If we know the destination is being opened in the current tab, 746 // If we know the destination is being opened in the current tab,
747 // we can easily get the tab ID. (If it's being opened in a new 747 // we can easily get the tab ID. (If it's being opened in a new
748 // tab, we don't know the tab ID yet.) 748 // tab, we don't know the tab ID yet.)
749 log.tab_id = delegate_->GetSessionID().id(); 749 log.tab_id = delegate_->GetSessionID().id();
750 } 750 }
751 autocomplete_controller()->AddProvidersInfo(&log.providers_info); 751 autocomplete_controller()->AddProvidersInfo(&log.providers_info);
752 content::NotificationService::current()->Notify( 752 content::NotificationService::current()->Notify(
753 chrome::NOTIFICATION_OMNIBOX_OPENED_URL, 753 chrome::NOTIFICATION_OMNIBOX_OPENED_URL,
754 content::Source<Profile>(profile_), 754 content::Source<Profile>(profile_),
(...skipping 687 matching lines...) Expand 10 before | Expand all | Expand 10 after
1442 // Update state and notify view if the omnibox has focus and the caret 1442 // Update state and notify view if the omnibox has focus and the caret
1443 // visibility changed. 1443 // visibility changed.
1444 const bool was_caret_visible = is_caret_visible(); 1444 const bool was_caret_visible = is_caret_visible();
1445 focus_state_ = state; 1445 focus_state_ = state;
1446 if (focus_state_ != OMNIBOX_FOCUS_NONE && 1446 if (focus_state_ != OMNIBOX_FOCUS_NONE &&
1447 is_caret_visible() != was_caret_visible) 1447 is_caret_visible() != was_caret_visible)
1448 view_->ApplyCaretVisibility(); 1448 view_->ApplyCaretVisibility();
1449 1449
1450 delegate_->OnFocusChanged(focus_state_, reason); 1450 delegate_->OnFocusChanged(focus_state_, reason);
1451 } 1451 }
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698