Skip to content

Commit

Permalink
(feat) Enhanced orientation breadcrumbs with explicit "from" and "to"
Browse files Browse the repository at this point in the history
  • Loading branch information
Robin Macharg committed Mar 18, 2020
1 parent 7f86293 commit 109acd2
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 9 deletions.
34 changes: 25 additions & 9 deletions Source/BugsnagClient.m
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,10 @@
static NSUInteger handledCount;
static NSUInteger unhandledCount;
static bool hasRecordedSessions;
#if TARGET_IPHONE_SIMULATOR || TARGET_OS_IPHONE
// The previous device orientation - iOS only
static NSString *lastOrientation = NULL;
#endif

/**
* Handler executed when the application crashes. Writes information about the
Expand Down Expand Up @@ -376,7 +380,7 @@ - (void)start {
selector:@selector(orientationChanged:)
name:UIDeviceOrientationDidChangeNotification
object:nil];

[center addObserver:self
selector:@selector(lowMemoryWarning:)
name:UIApplicationDidReceiveMemoryWarningNotification
Expand Down Expand Up @@ -776,10 +780,10 @@ - (void)batteryChanged:(NSNotification *)notif {

- (void)orientationChanged:(NSNotification *)notif {
NSString *orientation;
UIDeviceOrientation deviceOrientation =
[UIDevice currentDevice].orientation;

UIDeviceOrientation currentDeviceOrientation = [UIDevice currentDevice].orientation;

switch (deviceOrientation) {
switch (currentDeviceOrientation) {
case UIDeviceOrientationPortraitUpsideDown:
orientation = @"portraitupsidedown";
break;
Expand Down Expand Up @@ -811,14 +815,26 @@ - (void)orientationChanged:(NSNotification *)notif {
[orientationNotifName isEqualToString:lastBreadcrumb[BSGKeyName]]) {
NSDictionary *metadata = lastBreadcrumb[BSGKeyMetadata];

if ([orientation isEqualToString:metadata[BSGKeyOrientation]]) {
if ([orientation isEqualToString:metadata[BSGKeyOrientation]])
return; // ignore duplicate orientation event
}
}

[[self state] addAttribute:BSGKeyOrientation
withValue:orientation
toTabWithName:BSGKeyDeviceState];
// It's not a change
if ([orientation isEqualToString:lastOrientation])
return;

// We previously had an orientation
if (lastOrientation) {
[[self state] addAttribute:BSGKeyOrientationChange
withValue:@{@"from" : lastOrientation,
@"to" : orientation}
toTabWithName:BSGKeyDeviceState];
}

// We shouldn't get here without orientation being set, but to be on the safe side:
if (orientation)
// Preserve the orientation
lastOrientation = orientation;
}

- (void)lowMemoryWarning:(NSNotification *)notif {
Expand Down
1 change: 1 addition & 0 deletions Source/BugsnagKeys.h
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ static NSString *const BSGKeyLabel = @"label";
static NSString *const BSGKeySeverityReason = @"severityReason";
static NSString *const BSGKeyLogLevel = @"logLevel";
static NSString *const BSGKeyOrientation = @"orientation";
static NSString *const BSGKeyOrientationChange = @"Orientation change";
static NSString *const BSGKeySimulatorModelId = @"SIMULATOR_MODEL_IDENTIFIER";
static NSString *const BSGKeyFrameAddrFormat = @"0x%lx";
static NSString *const BSGKeySymbolAddr = @"symbolAddress";
Expand Down

0 comments on commit 109acd2

Please sign in to comment.