| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/bookmarks/bookmark_stats.h" | 5 #include "chrome/browser/bookmarks/bookmark_stats.h" |
| 6 | 6 |
| 7 #include "base/metrics/histogram.h" | 7 #include "base/metrics/histogram.h" |
| 8 #include "chrome/browser/bookmarks/bookmark_model.h" | 8 #include "base/metrics/user_metrics.h" |
| 9 #include "content/public/browser/user_metrics.h" | 9 #include "components/bookmarks/core/browser/bookmark_client.h" |
| 10 #include "components/bookmarks/core/browser/bookmark_node.h" |
| 10 | 11 |
| 11 void RecordBookmarkLaunch(const BookmarkNode* node, | 12 void RecordBookmarkLaunch(BookmarkClient* client, |
| 13 const BookmarkNode* node, |
| 12 BookmarkLaunchLocation location) { | 14 BookmarkLaunchLocation location) { |
| 13 if (location == BOOKMARK_LAUNCH_LOCATION_DETACHED_BAR || | 15 if (location == BOOKMARK_LAUNCH_LOCATION_DETACHED_BAR || |
| 14 location == BOOKMARK_LAUNCH_LOCATION_ATTACHED_BAR) { | 16 location == BOOKMARK_LAUNCH_LOCATION_ATTACHED_BAR) { |
| 15 content::RecordAction( | 17 client->RecordAction( |
| 16 base::UserMetricsAction("ClickedBookmarkBarURLButton")); | 18 base::UserMetricsAction("ClickedBookmarkBarURLButton")); |
| 17 } | 19 } |
| 18 UMA_HISTOGRAM_ENUMERATION( | 20 UMA_HISTOGRAM_ENUMERATION( |
| 19 "Bookmarks.LaunchLocation", location, BOOKMARK_LAUNCH_LOCATION_LIMIT); | 21 "Bookmarks.LaunchLocation", location, BOOKMARK_LAUNCH_LOCATION_LIMIT); |
| 20 | 22 |
| 21 if (!node) | 23 if (!node) |
| 22 return; | 24 return; |
| 23 | 25 |
| 24 // In the cases where a bookmark node is provided, record the depth of the | 26 // In the cases where a bookmark node is provided, record the depth of the |
| 25 // bookmark in the tree. | 27 // bookmark in the tree. |
| 26 int depth = 0; | 28 int depth = 0; |
| 27 for (const BookmarkNode* iter = node; iter != NULL; iter = iter->parent()) { | 29 for (const BookmarkNode* iter = node; iter != NULL; iter = iter->parent()) { |
| 28 depth++; | 30 depth++; |
| 29 } | 31 } |
| 30 // Record |depth - 2| to offset the invisible root node and permanent nodes | 32 // Record |depth - 2| to offset the invisible root node and permanent nodes |
| 31 // (Bookmark Bar, Mobile Bookmarks or Other Bookmarks) | 33 // (Bookmark Bar, Mobile Bookmarks or Other Bookmarks) |
| 32 UMA_HISTOGRAM_COUNTS("Bookmarks.LaunchDepth", depth - 2); | 34 UMA_HISTOGRAM_COUNTS("Bookmarks.LaunchDepth", depth - 2); |
| 33 } | 35 } |
| 34 | 36 |
| 35 void RecordBookmarkFolderOpen(BookmarkLaunchLocation location) { | 37 void RecordBookmarkFolderOpen(BookmarkClient* client, |
| 38 BookmarkLaunchLocation location) { |
| 36 if (location == BOOKMARK_LAUNCH_LOCATION_DETACHED_BAR || | 39 if (location == BOOKMARK_LAUNCH_LOCATION_DETACHED_BAR || |
| 37 location == BOOKMARK_LAUNCH_LOCATION_ATTACHED_BAR) { | 40 location == BOOKMARK_LAUNCH_LOCATION_ATTACHED_BAR) { |
| 38 content::RecordAction( | 41 client->RecordAction(base::UserMetricsAction("ClickedBookmarkBarFolder")); |
| 39 base::UserMetricsAction("ClickedBookmarkBarFolder")); | |
| 40 } | 42 } |
| 41 } | 43 } |
| 42 | 44 |
| 43 void RecordBookmarkAppsPageOpen(BookmarkLaunchLocation location) { | 45 void RecordBookmarkAppsPageOpen(BookmarkClient* client, |
| 46 BookmarkLaunchLocation location) { |
| 44 if (location == BOOKMARK_LAUNCH_LOCATION_DETACHED_BAR || | 47 if (location == BOOKMARK_LAUNCH_LOCATION_DETACHED_BAR || |
| 45 location == BOOKMARK_LAUNCH_LOCATION_ATTACHED_BAR) { | 48 location == BOOKMARK_LAUNCH_LOCATION_ATTACHED_BAR) { |
| 46 content::RecordAction( | 49 client->RecordAction( |
| 47 base::UserMetricsAction("ClickedBookmarkBarAppsShortcutButton")); | 50 base::UserMetricsAction("ClickedBookmarkBarAppsShortcutButton")); |
| 48 } | 51 } |
| 49 } | 52 } |
| OLD | NEW |