CFLogUtilities.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*
  2. * Copyright (c) 2014 Apple Inc. All rights reserved.
  3. *
  4. * @APPLE_LICENSE_HEADER_START@
  5. *
  6. * This file contains Original Code and/or Modifications of Original Code
  7. * as defined in and that are subject to the Apple Public Source License
  8. * Version 2.0 (the 'License'). You may not use this file except in
  9. * compliance with the License. Please obtain a copy of the License at
  10. * http://www.opensource.apple.com/apsl/ and read it before using this
  11. * file.
  12. *
  13. * The Original Code and all software distributed under the License are
  14. * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  15. * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
  16. * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
  17. * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  18. * Please see the License for the specific language governing rights and
  19. * limitations under the License.
  20. *
  21. * @APPLE_LICENSE_HEADER_END@
  22. */
  23. /* CFLogUtilities.h
  24. Copyright (c) 2004-2014, Apple Inc. All rights reserved.
  25. */
  26. /*
  27. APPLE SPI: NOT TO BE USED OUTSIDE APPLE!
  28. */
  29. #if !defined(__COREFOUNDATION_CFLOGUTILITIES__)
  30. #define __COREFOUNDATION_CFLOGUTILITIES__ 1
  31. #include <CoreFoundation/CFBase.h>
  32. #include <CoreFoundation/CFString.h>
  33. CF_EXTERN_C_BEGIN
  34. enum { // Legal level values for CFLog()
  35. kCFLogLevelEmergency = 0,
  36. kCFLogLevelAlert = 1,
  37. kCFLogLevelCritical = 2,
  38. kCFLogLevelError = 3,
  39. kCFLogLevelWarning = 4,
  40. kCFLogLevelNotice = 5,
  41. kCFLogLevelInfo = 6,
  42. kCFLogLevelDebug = 7,
  43. };
  44. CF_EXPORT void CFLog(int32_t level, CFStringRef format, ...);
  45. /* Passing in a level value which is outside the range of 0-7 will cause the the call to do nothing.
  46. CFLog() logs the message using the asl.h API, and uses the level parameter as the log level.
  47. Note that the asl subsystem ignores some log levels by default.
  48. CFLog() is not fast, and is not going to be guaranteed to be fast.
  49. Even "no-op" CFLogs are not necessarily fast.
  50. If you care about performance, you shouldn't be logging.
  51. */
  52. CF_EXTERN_C_END
  53. #endif /* ! __COREFOUNDATION_CFLOGUTILITIES__ */