Senna
a logging engine backend of Apple’s swift-log
Status
data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="license"
data:image/s3,"s3://crabby-images/45b5a/45b5ac82f6856c1951a71e1b4915a8802954ec1e" alt="platforms"
Features
- Pure Swift
- Backend of
apple/swift-log
- Both Darwin(iOS macOS watchOS tvOS) and Linux compatibility
- Builtin output target :
[stdout/stderr,file,oslog,syslog]
- ANSI escape code
- Complete customizable for text out
- Support string interpolation the same as Apple’s Unified Logging System
- 100% Code Coverage
Examples
Use Builtin Sinks
Simple stdout
//create sink
let sink = StandardSink.out()
//create formation
let formation = Formation.standard
//create log
var logger = Logger(label: "LogName") {
Handler(name: $0, sink: sink, formation: formation, logLevel: .trace)
}
// do some logs
logger.trace("This is a trace message")
logger.debug("This is a debug message")
logger.info("This is a info message")
logger.notice("This is a notice message")
logger.warning("This is a warning message")
logger.error("This is a error message")
logger.critical("This is a critical message")
Terminal out :
data:image/s3,"s3://crabby-images/de19c/de19c3775938da699ba7efee02a85b4780b6c3ea" alt=""
Change LogLevel
logger.logLevel = .info
logger.debug("will not log")
logger.info("will log")
logger[metadataKey: "UserID"] = .stringConvertible(9527)
logger.info("message with logger meta data")
logger.info("message with both logger and message meta data", metadata: ["UserName": .string("L1MeN9Yu")])
Terminal out :
data:image/s3,"s3://crabby-images/1fd0d/1fd0d4590ba7a03938891724d63a32cee3a4cf5a" alt=""
Builtin Sinks
FileSink
let fileSink = FileSink("path/of/log")
Log message will write to file.
See Tests for more.
let osLogSink = OSLogSink(subsystem: "subsystem", category: "category")
Log message will write to OS log (Apple’s syslog). Use Connsole.app
in your macOS to watch oslog messages.
See Tests for more.
SystemLogSink (Linux)
let systemLogSink = SystemLogSink()
Log message will write to syslog.
See Tests for more.
Formation
generate the log message.
There are some builtin Formation
:
Formation.standard
. This is default for stdout/stderr
.
Formation.standardXcode
. This is default for stdout/stderr
display in Xcode due Xcode’s console is not support ANSI escape code.
data:image/s3,"s3://crabby-images/51972/519728e5e5b05a3ab1460d42bc0525dc40339bb1" alt=""
Formation.file
. This is default for File
.
Formation.os
. This is default for OSLog
.
Formation.system
. This is default for syslog
.
Create Formation
is simple : Formation(components: <#T##[Component]##[Senna.Component]#>, printer: <#T##Printable?##Senna.Printable?#>, separator: <#T##String?##Swift.String?#>)
The Formation contains components: [Component]
, printer: Printable?
and separator: String?
.
Component
Component is your log message’s element. See Component file.
Printable
The Printable
enhanced your log messages, It can add color or style to the component.
The builtin Printer
has two default instance.
Printer.standard
for stdout/stderr
.
Printer.xcode
for stdout/stderr
in Xcode.
You can create new Printer
instance or Use YourPrinter
which implements Printable
protocol.
See Printer and Printable for more.
Separator
The Separator
string is used for split log message’s component.
The Formation.standard
‘s separator is " ▶ "
.
Apple’s Unified Logging System
Senna reimplement the string interpolation behavior of Apple’s Unified Logging System
let sink = StandardSink.out()
let formation = Formation.standard
var logger = Logger(label: "LogName") {
Handler(name: $0, sink: sink, formation: formation, logLevel: .trace)
}
logger[metadataKey: "UserID"] = .stringConvertible(9527)
#if DEBUG
let privacy = Privacy.public
#else
let privacy = Privacy.private
#endif
// default is private
logger.senna.notice("the user name is \("L1MeN9Yu")")
logger.senna.notice("the user name is \("L1MeN9Yu", privacy: privacy)")
Terminal out :
data:image/s3,"s3://crabby-images/e673e/e673e7d61d686ed45515f77dcc8a9917888e3c8e" alt=""
see LoggerSennaTests.swift for more usages.
Installation
Swift Package Manager
Add the following to your Package.swift
file:
dependencies: [
.package(url: "https://github.com/L1MeN9Yu/Senna.git", from: "3.0.0")
]
Credit
License
Senna is available under the MIT license. See the LICENSE file for details.
Thanks | 鸣谢
Thanks to JetBrains for “Licenses for Open Source Development”. JetBrains supports non-commercial open source projects by providing core project contributors with a set of best-in-class
developer tools free of charge.
感谢 JetBrains 提供的开源开发许可证。JetBrains 通过为项目核心开发者免费提供开发工具来支持非商业开源项目。
Senna
a logging engine backend of Apple’s swift-log
Status
Features
apple/swift-log
[stdout/stderr,file,oslog,syslog]
Examples
Use Builtin Sinks
Simple stdout
Terminal out :
Change LogLevel
Add MetaData
Terminal out :
Builtin Sinks
FileSink
Log message will write to file.
See Tests for more.
OSLogSink (Apple platform only)
Log message will write to OS log (Apple’s syslog). Use
Connsole.app
in your macOS to watch oslog messages.See Tests for more.
SystemLogSink (Linux)
Log message will write to syslog.
See Tests for more.
Formation
Formation
generate the log message.There are some builtin
Formation
:Formation.standard
. This is default forstdout/stderr
.Formation.standardXcode
. This is default forstdout/stderr
display in Xcode due Xcode’s console is not support ANSI escape code.Formation.file
. This is default forFile
.Formation.os
. This is default forOSLog
.Formation.system
. This is default forsyslog
.Advanced Customize Formation
Create
Formation
is simple :Formation(components: <#T##[Component]##[Senna.Component]#>, printer: <#T##Printable?##Senna.Printable?#>, separator: <#T##String?##Swift.String?#>)
The Formation contains
components: [Component]
,printer: Printable?
andseparator: String?
.Component
Component is your log message’s element. See Component file.
Printable
The
Printable
enhanced your log messages, It can add color or style to the component.The builtin
Printer
has two default instance.Printer.standard
forstdout/stderr
.Printer.xcode
forstdout/stderr
in Xcode.You can create new
Printer
instance or UseYourPrinter
which implementsPrintable
protocol.See Printer and Printable for more.
Separator
The
Separator
string is used for split log message’s component. TheFormation.standard
‘s separator is" ▶ "
.Apple’s Unified Logging System
Senna reimplement the string interpolation behavior of Apple’s Unified Logging System
Terminal out :
see LoggerSennaTests.swift for more usages.
Installation
Swift Package Manager
Add the following to your
Package.swift
file:Credit
License
Senna is available under the MIT license. See the LICENSE file for details.
Thanks | 鸣谢
Thanks to JetBrains for “Licenses for Open Source Development”. JetBrains supports non-commercial open source projects by providing core project contributors with a set of best-in-class developer tools free of charge.
感谢 JetBrains 提供的开源开发许可证。JetBrains 通过为项目核心开发者免费提供开发工具来支持非商业开源项目。