Chromium Code Reviews| Index: components/password_manager/core/browser/login_database.cc |
| diff --git a/components/password_manager/core/browser/login_database.cc b/components/password_manager/core/browser/login_database.cc |
| index ab8d18f5a08b279dfd95b4a08286d4bc69219b30..6bfd9f222f71837f24a8d07a61e5035c2484d32a 100644 |
| --- a/components/password_manager/core/browser/login_database.cc |
| +++ b/components/password_manager/core/browser/login_database.cc |
| @@ -504,6 +504,19 @@ void LoginDatabase::ReportMetrics(const std::string& sync_username, |
| UMA_HISTOGRAM_COUNTS_100("PasswordManager.EmptyUsernames.CountInDatabase", |
| empty_forms); |
| } |
| + |
| + sql::Statement standalone_empty_usernames_statement(db_.GetCachedStatement( |
| + SQL_FROM_HERE, "SELECT COUNT(*) FROM logins a " |
| + "WHERE a.blacklisted_by_user=0 AND a.username_value='' " |
| + "AND NOT EXISTS (SELECT * FROM logins b " |
|
vasilii
2015/04/15 15:51:55
I'd reverse the condition as "There is a correspon
msramek
2015/04/16 14:34:26
Well, that was my original intention. But then I r
|
| + "WHERE b.blacklisted_by_user=0 AND b.username_value!='' " |
| + "AND a.signon_realm = b.signon_realm)")); |
| + if (standalone_empty_usernames_statement.Step()) { |
| + int num_entries = standalone_empty_usernames_statement.ColumnInt(0); |
| + UMA_HISTOGRAM_COUNTS_100("PasswordManager.EmptyUsernames." |
| + "NotPairedWithNonempty", |
|
Ilya Sherman
2015/04/15 22:56:05
nit: Rather than splitting this string across mult
msramek
2015/04/16 14:34:26
Done.
|
| + num_entries); |
| + } |
| } |
| PasswordStoreChangeList LoginDatabase::AddLogin(const PasswordForm& form) { |