BTLogger.m 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. #import "BTLogger_Internal.h"
  2. #define variadicLogLevel(level, format) \
  3. va_list args; \
  4. va_start(args, format); \
  5. [self logLevel:level format:format arguments:args]; \
  6. va_end(args);
  7. @implementation BTLogger
  8. + (instancetype)sharedLogger {
  9. static BTLogger *instance;
  10. static dispatch_once_t onceToken;
  11. dispatch_once(&onceToken, ^{
  12. instance = [self new];
  13. });
  14. return instance;
  15. }
  16. - (instancetype)init {
  17. self = [super init];
  18. if (self) {
  19. _level = BTLogLevelInfo;
  20. }
  21. return self;
  22. }
  23. - (void)log:(NSString *)format, ... {
  24. variadicLogLevel(BTLogLevelInfo, format)
  25. }
  26. - (void)critical:(NSString *)format, ... {
  27. variadicLogLevel(BTLogLevelCritical, format)
  28. }
  29. - (void)error:(NSString *)format, ... {
  30. variadicLogLevel(BTLogLevelError, format)
  31. }
  32. - (void)warning:(NSString *)format, ... {
  33. variadicLogLevel(BTLogLevelWarning, format)
  34. }
  35. - (void)info:(NSString *)format, ... {
  36. variadicLogLevel(BTLogLevelInfo, format)
  37. }
  38. - (void)debug:(NSString *)format, ... {
  39. variadicLogLevel(BTLogLevelDebug, format)
  40. }
  41. - (void)logLevel:(BTLogLevel)level format:(NSString *)format arguments:(va_list)arguments {
  42. if (level <= self.level) {
  43. NSString *message = [[NSString alloc] initWithFormat:format arguments:arguments];
  44. if (self.logBlock) {
  45. self.logBlock(level, message);
  46. } else {
  47. NSString *levelString = [[self class] levelString:level];
  48. NSLog(@"[BraintreeSDK] %@ %@", [levelString uppercaseString], message);
  49. }
  50. }
  51. }
  52. + (NSString *)levelString:(BTLogLevel)level {
  53. switch (level) {
  54. case BTLogLevelCritical:
  55. return @"Critical";
  56. case BTLogLevelError:
  57. return @"Error";
  58. case BTLogLevelWarning:
  59. return @"Warning";
  60. case BTLogLevelInfo:
  61. return @"Info";
  62. case BTLogLevelDebug:
  63. return @"Debug";
  64. default:
  65. return nil;
  66. }
  67. }
  68. @end