TraceLog can be configured with multiple custom log writers who do the job of outputting the log statements to the desired location. By default, it configures itself with a ConsoleWriter
which outputs to stdout. To install the AdaptiveWriter replacing the ConsoleWriter, simply create an instance and pass it along to the configure method of TraceLog.
TraceLog.configure(writers: [AdaptiveWriter()])
AdaptiveWriter uses the default value (the process name) for the subsystem (subsystem in Unified Logging and SYSLOG_IDENTIFIER in systemd journal) to log messages on each platform. That value can be overridden at init time by passing the subsystem parameter. For example:
Since TraceLog’s and the underlying logging systems’ LogLevels may differ, the AdaptiveWriter uses a conversion table to convert from a TraceLog defined level such as TraceLog.LogLevel.info to a platform level such as OSLogType.default in Darwin’s Unified Logging System.
AdaptiveWriter contains a default conversion table for each platform.
Apple Unified Logging System - Conversion Table
TraceLog.LogLevel
OSLogType
.error
->
.error
.warning
->
.default
.info
->
.default
.trace1
->
.debug
.trace2
->
.debug
.trace3
->
.debug
.trace4
->
.debug
Linux Systemd Journal - Conversion Table
TraceLog.LogLevel
PRIORITY
.error
->
LOG_ERR
.warning
->
LOG_WARNING
.info
->
LOG_INFO
.trace1
->
LOG_DEBUG
.trace2
->
LOG_DEBUG
.trace3
->
LOG_DEBUG
.trace4
->
LOG_DEBUG
If the default table does not work for your particular use-case, AdaptiveWriter allows you to override the default conversion table at creation time. Here are some examples:
Setting an empty table will convert all TraceLog levels to the default level of the platform in use. On Darwin that is OSLogType.default and on Linux the value is LOG_INFO.
///
/// Linux/Darwin
///
let adaptiveWriter = AdaptiveWriter(logLevelConversion: [:])
Setting one or more levels will set the levels specified and all non-specified levels will be converted to the platform default. To set a value you must wrap the system defined value in AdaptiveWriter’s Platform.LogLevel type. This will translate to the proper type on each platform.
///
/// Darwin Example
///
let adaptiveWriter = AdaptiveWriter(logLevelConversion: [.error: Platform.LogLevel(OSLogType.error.rawValue)])
You may also specify a full conversion table to change all values.
///
/// Darwin Example
///
let darwinLogConversionTable: [TraceLog.LogLevel: Platform.LogLevel] = [
.error: Platform.LogLevel(OSLogType.default.rawValue),
.warning: Platform.LogLevel(OSLogType.default.rawValue),
.info: Platform.LogLevel(OSLogType.default.rawValue),
.trace1: Platform.LogLevel(OSLogType.debug.rawValue),
.trace2: Platform.LogLevel(OSLogType.debug.rawValue),
.trace3: Platform.LogLevel(OSLogType.debug.rawValue),
.trace4: Platform.LogLevel(OSLogType.debug.rawValue)
]
let adaptiveWriter = AdaptiveWriter(logLevelConversion: darwinLogConversionTable)
///
/// Linux Example
///
let linuxLogConversionTable: [TraceLog.LogLevel: Platform.LogLevel] = [
.error: Platform.LogLevel(LOG_INFO),
.warning: Platform.LogLevel(LOG_INFO),
.info: Platform.LogLevel(LOG_INFO),
.trace1: Platform.LogLevel(LOG_DEBUG),
.trace2: Platform.LogLevel(LOG_DEBUG),
.trace3: Platform.LogLevel(LOG_DEBUG),
.trace4: Platform.LogLevel(LOG_DEBUG)
]
let adaptiveWriter = AdaptiveWriter(logLevelConversion: linuxLogConversionTable)
Minimum Requirements
Build Environment
Platform
Swift
Swift Build
Xcode
Linux
5.0
✔
✘
OSX
5.0
✔
Xcode 10.x
Note: Compiling on Linux requires libsystemd-dev be installed on the build system. Use apt-get install libsystemd-dev to install it.
Minimum Runtime Version
iOS
OS X
tvOS
watchOS
Linux
10.0
10.12
10.0
3.0
Ubuntu 14.04, 16.04, 16.10
Installation (Swift Package Manager)
TraceLogAdaptiveWriter supports dependency management via Swift Package Manager on All Apple OS variants as well as Linux.
TraceLog AdaptiveWriterdata:image/s3,"s3://crabby-images/78c07/78c07fb656809e3a9a4afe4922815ce116a67fe2" alt="License: Apache 2.0"
Overview
A
Writer
implementation for the TraceLog logging system that logs to the system logging facility on the platform that it is running on.See TraceLog (https://github.com/tonystone/tracelog) for more details.
Usage
TraceLog can be configured with multiple custom log writers who do the job of outputting the log statements to the desired location. By default, it configures itself with a
ConsoleWriter
which outputs tostdout
. To install theAdaptiveWriter
replacing theConsoleWriter
, simply create an instance and pass it along to the configure method of TraceLog.AdaptiveWriter uses the default value (the process name) for the subsystem (
subsystem
in Unified Logging andSYSLOG_IDENTIFIER
in systemd journal) to log messages on each platform. That value can be overridden atinit
time by passing the subsystem parameter. For example:Since TraceLog’s and the underlying logging systems’ LogLevels may differ, the AdaptiveWriter uses a conversion table to convert from a TraceLog defined level such as
TraceLog.LogLevel.info
to a platform level such asOSLogType.default
in Darwin’s Unified Logging System.AdaptiveWriter contains a default conversion table for each platform.
Apple Unified Logging System - Conversion Table
.error
.error
.warning
.default
.info
.default
.trace1
.debug
.trace2
.debug
.trace3
.debug
.trace4
.debug
Linux Systemd Journal - Conversion Table
.error
LOG_ERR
.warning
LOG_WARNING
.info
LOG_INFO
.trace1
LOG_DEBUG
.trace2
LOG_DEBUG
.trace3
LOG_DEBUG
.trace4
LOG_DEBUG
If the default table does not work for your particular use-case, AdaptiveWriter allows you to override the default conversion table at creation time. Here are some examples:
Setting an empty table will convert all TraceLog levels to the default level of the platform in use. On Darwin that is
OSLogType.default
and on Linux the value isLOG_INFO
.Setting one or more levels will set the levels specified and all non-specified levels will be converted to the platform default. To set a value you must wrap the system defined value in AdaptiveWriter’s
Platform.LogLevel
type. This will translate to the proper type on each platform.You may also specify a full conversion table to change all values.
Minimum Requirements
Build Environment
Minimum Runtime Version
Installation (Swift Package Manager)
TraceLogAdaptiveWriter supports dependency management via Swift Package Manager on All Apple OS variants as well as Linux.
Please see Swift Package Manager for further information.
Installation (CocoaPods)
TraceLog is available through CocoaPods. Simply add the following lines to your Podfile:
Credits
License
TraceLogAdaptiveWriter is released under the Apache License, Version 2.0