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) { |