Chromium Code Reviews| Index: chrome/browser/metrics/chrome_browser_main_extra_parts_metrics_mac.mm |
| diff --git a/chrome/browser/metrics/chrome_browser_main_extra_parts_metrics_mac.mm b/chrome/browser/metrics/chrome_browser_main_extra_parts_metrics_mac.mm |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..aaf91d664aeaa68d52bb3cc2dc21c182ee14a874 |
| --- /dev/null |
| +++ b/chrome/browser/metrics/chrome_browser_main_extra_parts_metrics_mac.mm |
| @@ -0,0 +1,65 @@ |
| +// Copyright 2014 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. |
| + |
| +#include "chrome/browser/metrics/chrome_browser_main_extra_parts_metrics_mac.h" |
| + |
| +#include <Cocoa/Cocoa.h> |
| + |
| +#include "base/metrics/histogram.h" |
| + |
| +namespace { |
| + |
| +// The maximum number of screens to record in UMA. |
| +NSUInteger kMaxScreens = 10; |
| + |
| +} // namespace |
| + |
| +@interface MetricsBridge : NSObject { |
| + NSUInteger screenCount_; |
| +} |
| +@end |
| + |
| +@implementation MetricsBridge |
|
Robert Sesek
2014/10/08 19:25:20
Could you instead use gfx::Screen::AddObserver(gfx
erikchen
2014/10/08 22:49:19
I went with your suggestion and also switched to G
|
| +- (instancetype)init { |
| + self = [super init]; |
| + if (self) { |
| + screenCount_ = [[NSScreen screens] count]; |
| + [[NSNotificationCenter defaultCenter] |
| + addObserver:self |
| + selector:@selector(didChangeScreenParameters:) |
| + name:NSApplicationDidChangeScreenParametersNotification |
| + object:nil]; |
| + |
| + UMA_HISTOGRAM_ENUMERATION("OSX.DisplayCount.StartUp", |
| + std::min(kMaxScreens, screenCount_), |
| + kMaxScreens + 1); |
| + } |
| + return self; |
| +} |
| + |
| +- (void)dealloc { |
| + [[NSNotificationCenter defaultCenter] removeObserver:self]; |
| + [super dealloc]; |
| +} |
| + |
| +- (void)didChangeScreenParameters:(NSNotification*)notification { |
| + NSUInteger screenCount = [[NSScreen screens] count]; |
| + if (screenCount != screenCount_) { |
| + screenCount_ = screenCount; |
| + UMA_HISTOGRAM_ENUMERATION("OSX.DisplayCount.Changed", |
|
Robert Sesek
2014/10/08 19:25:20
This seems like a _COUNTS instead of an _ENUMERATI
erikchen
2014/10/08 22:49:19
_COUNTS uses an exponential histogram (even _COUNT
|
| + std::min(kMaxScreens, screenCount_), |
| + kMaxScreens + 1); |
| + } |
| +} |
| + |
| +@end |
| + |
| +ChromeBrowserMainExtraPartsMetricsMac::ChromeBrowserMainExtraPartsMetricsMac() { |
| + metrics_bridge_ = static_cast<void*>([[MetricsBridge alloc] init]); |
| +} |
| + |
| +ChromeBrowserMainExtraPartsMetricsMac:: |
| + ~ChromeBrowserMainExtraPartsMetricsMac() { |
| + [static_cast<NSObject*>(metrics_bridge_) release]; |
| +} |