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

Side by Side Diff: components/translate/core/browser/language_model.h

Issue 2449873003: [NTP Snippets] Another round of clang-tidy cleanups (Closed)
Patch Set: review Created 4 years, 1 month 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 #ifndef COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_MODEL_H_ 5 #ifndef COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_MODEL_H_
6 #define COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_MODEL_H_ 6 #define COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_MODEL_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "components/keyed_service/core/keyed_service.h" 12 #include "components/keyed_service/core/keyed_service.h"
13 13
14 class PrefRegistrySimple; 14 class PrefRegistrySimple;
15 class PrefService; 15 class PrefService;
16 16
17 namespace translate { 17 namespace translate {
18 18
19 // Collects data about languages in which the user reads the web and provides 19 // Collects data about languages in which the user reads the web and provides
20 // access to current estimated language preferences. The past behaviour is 20 // access to current estimated language preferences. The past behaviour is
21 // discounted so that this model reflects changes in browsing habits. This model 21 // discounted so that this model reflects changes in browsing habits. This model
22 // does not have to contain all languages that ever appeared in user's browsing, 22 // does not have to contain all languages that ever appeared in user's browsing,
23 // languages with insignificant frequency are removed, eventually. 23 // languages with insignificant frequency are removed, eventually.
24 class LanguageModel : public KeyedService { 24 class LanguageModel : public KeyedService {
25 public: 25 public:
26 struct LanguageInfo { 26 struct LanguageInfo {
27 LanguageInfo() = default;
Bernhard Bauer 2016/10/26 09:24:02 So, is there a rule for when to use {} and when to
Marc Treib 2016/10/26 09:29:40 I don't know of any "official" rule - my personal
28 LanguageInfo(const std::string& language_code, float frequency)
29 : language_code(language_code), frequency(frequency) {}
30
27 // The ISO 639 language code. 31 // The ISO 639 language code.
28 std::string language_code; 32 std::string language_code;
29 33
30 // The current estimated frequency of the language share, a number between 0 34 // The current estimated frequency of the language share, a number between 0
31 // and 1 (can be understood as the probability that the next page the user 35 // and 1 (can be understood as the probability that the next page the user
32 // opens is in this language). Frequencies over all LanguageInfos from 36 // opens is in this language). Frequencies over all LanguageInfos from
33 // GetTopLanguages() sum to 1 (unless there are no top languages, yet). 37 // GetTopLanguages() sum to 1 (unless there are no top languages, yet).
34 float frequency; 38 float frequency = 0.0f;
Marc Treib 2016/10/26 09:21:05 Uninitialized values are Teh Evilz! :) Unfortunate
35 39
36 bool operator==(const LanguageInfo& m) const { 40 bool operator==(const LanguageInfo& m) const {
37 return language_code == m.language_code; 41 return language_code == m.language_code;
38 } 42 }
39 }; 43 };
40 44
41 explicit LanguageModel(PrefService* pref_service); 45 explicit LanguageModel(PrefService* pref_service);
42 ~LanguageModel() override; 46 ~LanguageModel() override;
43 47
44 // Registers profile prefs for the model. 48 // Registers profile prefs for the model.
(...skipping 13 matching lines...) Expand all
58 62
59 private: 63 private:
60 PrefService* pref_service_; 64 PrefService* pref_service_;
61 65
62 DISALLOW_COPY_AND_ASSIGN(LanguageModel); 66 DISALLOW_COPY_AND_ASSIGN(LanguageModel);
63 }; 67 };
64 68
65 } // namespace translate 69 } // namespace translate
66 70
67 #endif // COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_MODEL_H_ 71 #endif // COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_MODEL_H_
OLDNEW
« no previous file with comments | « components/ntp_snippets/remote/ntp_snippets_fetcher.cc ('k') | components/translate/core/browser/language_model.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698