Plank
Plank is an Android library for easy logging using context receivers.
Flavours
There are 3 flavours to choose from:
- Seal:
"Logging using the «seal» flavour" log debug
- Func:
log("Logging using the «func» flavour")
- Classic:
Plank.d("Logging using the «classic» flavour")
All of the above yield the same results and the tag is inferred based on the class from which the message is logged. In this case, the only difference is syntax.
Installation
-
Choose one flavour:
- Seal
implementation("com.github.sunkengxd.plank:seal:1.0.0")
- Func
implementation("com.github.sunkengxd.plank:func:1.0.0")
- Classic
implementation("com.github.sunkengxd.plank:classic:1.0.0")
-
Add kotlin compiler options:
// module-level build.gradle.kts
kotlinOptions {
// ...
freeCompilerArgs = listOf("-Xcontext-receivers")
}
Usage
Apart from logging, the library supports muting the messages. All of the below can only be called from the Application class.
- Seal:
Plank.muteAll() // prevents any logging
verbose.mute() // mutes all verbose type messages
- Func:
PlankConfig.mute() // the same as muteAll() from seal
- Classic:
Plank.mute() // the same as mute() from func or muteAll() from seal
Additional parameters
- tag – functions from the func and seal flavours can receive a parameter tag, in case you want messages from different classes to have the same name or just want a custom tag.
- type – log() from the func flavour also accepts this optional parameter denoting whether it is a debug, info, warn or some other type of message. Defaults to debug.
Limitations
Due to the Any context receiver of these functions, they cannot be used inside top-level functions.
Feedback
Any feedback is welcome!