// Copyright 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_BROWSER_OMNIBOX_OMNIBOX_LOG_H_ #define CHROME_BROWSER_OMNIBOX_OMNIBOX_LOG_H_ #include <stddef.h> #include "base/strings/string16.h" #include "base/time/time.h" #include "chrome/browser/autocomplete/autocomplete_provider.h" #include "chrome/browser/sessions/session_id.h" #include "components/metrics/proto/omnibox_event.pb.h" #include "components/metrics/proto/omnibox_input_type.pb.h" class AutocompleteResult; // The data to log (via the metrics service) when the user selects an item from // the omnibox popup. struct OmniboxLog { OmniboxLog( const base::string16& text, bool just_deleted_text, metrics::OmniboxInputType::Type input_type, bool is_popup_open, size_t selected_index, bool is_paste_and_go, SessionID::id_type tab_id, metrics::OmniboxEventProto::PageClassification current_page_classification, base::TimeDelta elapsed_time_since_user_first_modified_omnibox, size_t completed_length, base::TimeDelta elapsed_time_since_last_change_to_default_match, const AutocompleteResult& result); ~OmniboxLog(); // The user's input text in the omnibox. base::string16 text; // Whether the user deleted text immediately before selecting an omnibox // suggestion. This is usually the result of pressing backspace or delete. bool just_deleted_text; // The detected type of the user's input. metrics::OmniboxInputType::Type input_type; // True if the popup is open. bool is_popup_open; // The index of the item selected in the dropdown list. Set to 0 if the // dropdown is closed (and therefore there is only one implicit suggestion). size_t selected_index; // True if this is a paste-and-search or paste-and-go omnibox interaction. // (The codebase refers to both these types as paste-and-go.) bool is_paste_and_go; // ID of the tab the selected autocomplete suggestion was opened in. // Set to -1 if we haven't yet determined the destination tab. SessionID::id_type tab_id; // The type of page (e.g., new tab page, regular web page) that the // user was viewing before going somewhere with the omnibox. metrics::OmniboxEventProto::PageClassification current_page_classification; // The amount of time since the user first began modifying the text // in the omnibox. If at some point after modifying the text, the // user reverts the modifications (thus seeing the current web // page's URL again), then writes in the omnibox again, this time // delta should be computed starting from the second series of // modifications. If we somehow skipped the logic to record // the time the user began typing (this should only happen in // unit tests), this elapsed time is set to -1 milliseconds. base::TimeDelta elapsed_time_since_user_first_modified_omnibox; // The number of extra characters the user would have to manually type // if she/he were not given the opportunity to select this match. Only // set for matches that are allowed to be the default match (i.e., are // inlineable). Set to base::string16::npos if the match is not allowed // to be the default match. size_t completed_length; // The amount of time since the last time the default (i.e., inline) // match changed. This will certainly be less than // elapsed_time_since_user_first_modified_omnibox. Measuring this // may be inappropriate in some cases (e.g., if editing is not in // progress). In such cases, it's set to -1 milliseconds. base::TimeDelta elapsed_time_since_last_change_to_default_match; // Result set. const AutocompleteResult& result; // Diagnostic information from providers. See // AutocompleteController::AddProvidersInfo() and // AutocompleteProvider::AddProviderInfo() above. ProvidersInfo providers_info; }; #endif // CHROME_BROWSER_OMNIBOX_OMNIBOX_LOG_H_