mirror of
				https://github.com/InsanusMokrassar/KSLog.git
				synced 2025-10-26 17:10:07 +00:00 
			
		
		
		
	
			
				
					
						
					
					35e3d028372f9073531252dee523964fb39cb43e
				
			
			
		
	How to use
It is simple logging tool which is using built-in tools for logging:
- java.util.logging.Loggerfor- JVM
- android.util.Logfor- Android
- Consolefor- JS
How to use
Fast-travel
Just use some boring extensions like:
KSLog.i("Some message")
// OR
KSLog.i("Some tag", "Some message")
// OR
KSLog.i("Some tag", "Some message", IllegalArgumentException("So, that is exception :)"))
// OR
KSLog.i("Some optional tag", Exception("Optional")) { "Lazy inited message" }
// OR
KSLog.iS("Some optional tag", Exception("Optional")) { "Lazy inited message for suspendable calculation of text" }
// OR EVEN
KSLog.l(LogLevel.INFO, "Some tag", "Some message", IllegalArgumentException("So, that is exception :)"))
// OR
KSLog.l(LogLevel.INFO, "Some optional tag", IllegalArgumentException("So, that is exception :)")) { "And lazily inited message" }
A little bit deeper
There are several important "terms" in context of this library:
- Default logger (available via KSLog.default)
- Local logger (can be created via KSLogfunctions and passed anywhere asKSLog)
- Logging shortcuts like KSLog.i/KSLog.info
Every logging extension (like KSLog.i) have its analog with lazy inited message text and the same one with suffix S (like KSLog.iS) for the suspendable message calculation.
Default logger can be created by passing defaultTag and one of variants log level filters: set or minimal loggable level. In JVM you also may setup any logger as base logger for default realizations of KSLog. Besides, you may use your own callback (on any target platform) as output of logging:
val logger = KSLog { logLevel, optionalTag, message, optionalThrowable ->
    println("[$logLevel] $optionalTag - $message: $optionalThrowable.stackTraceToString()")
}
In the example above we will take the logger which will just print incoming data as common output.
Installation
Gradle
implementation "dev.inmo:kslog:$kslog_version"
Maven
<dependency>
  <groupId>dev.inmo</groupId>
  <artifactId>kslog</artifactId>
  <version>${kslog_version}</version>
</dependency>
					Languages
				
				
								
								
									Kotlin
								
								99%
							
						
							
								
								
									Shell
								
								1%