Proyectos de Subversion Iphone Microlearning

Rev

Autoría | Ultima modificación | Ver Log |

// Copyright 2020 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#import "FirebasePerformance/Sources/Common/FPRDiagnostics.h"
#import "FirebasePerformance/Sources/Common/FPRDiagnostics_Private.h"
#import "FirebasePerformance/Sources/Configurations/FPRConfigurations.h"

void __FPRAssert(id object, BOOL condition, const char *func) {
  static BOOL diagnosticsEnabled = NO;
  static dispatch_once_t onceToken;
  NSDictionary<NSString *, NSString *> *environment = [NSProcessInfo processInfo].environment;
  // Enable diagnostics when in test environment
  if (environment[@"XCTestConfigurationFilePath"] != nil) {
    diagnosticsEnabled = [FPRDiagnostics isEnabled];
  } else {
    dispatch_once(&onceToken, ^{
      diagnosticsEnabled = [FPRDiagnostics isEnabled];
    });
  }

  if (__builtin_expect(!condition && diagnosticsEnabled, NO)) {
    FPRLogError(kFPRDiagnosticFailure, @"Failure in %s, information follows:", func);
    FPRLogNotice(kFPRDiagnosticLog, @"Stack for failure in %s:\n%@", func,
                 [NSThread callStackSymbols]);
    if ([[object class] respondsToSelector:@selector(emitDiagnostics)]) {
      [[object class] performSelector:@selector(emitDiagnostics) withObject:nil];
    }
    if ([object respondsToSelector:@selector(emitDiagnostics)]) {
      [object performSelector:@selector(emitDiagnostics) withObject:nil];
    }
    FPRLogNotice(kFPRDiagnosticLog, @"End of diagnostics for %s failure.", func);
  }
}

@implementation FPRDiagnostics

static FPRConfigurations *_configuration;

+ (void)initialize {
  _configuration = [FPRConfigurations sharedInstance];
}

+ (FPRConfigurations *)configuration {
  return _configuration;
}

+ (void)setConfiguration:(FPRConfigurations *)config {
  _configuration = config;
}

+ (BOOL)isEnabled {
  // Check a soft-linked FIRCore class to see if this is running in the app store.
  Class FIRAppEnvironmentUtil = NSClassFromString(@"FIRAppEnvironmentUtil");
  SEL isFromAppStore = NSSelectorFromString(@"isFromAppStore");
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Warc-performSelector-leaks"
  if (FIRAppEnvironmentUtil && [FIRAppEnvironmentUtil respondsToSelector:isFromAppStore] &&
      [FIRAppEnvironmentUtil performSelector:isFromAppStore]) {
    return NO;
  }
#pragma clang diagnostic pop
  BOOL enabled = [FPRDiagnostics.configuration diagnosticsEnabled];
  if (enabled) {
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
      FPRLogNotice(kFPRDiagnosticInfo, @"Firebase Performance Diagnostics have been enabled!");
    });
  }
  return enabled;
}

@end