Android Components > Support > Base
Base or core component containing building blocks and interfaces for other components.
Usually this component never needs to be added to application projects manually. Other components may have a transitive dependency on some of the classes and interfaces in this component.
Use gradle to download the library from JCenter:
implementation "org.mozilla.components:base:{latest-version}
The base component offers helpers for logging for component (and app) code that allows the app to be in control what gets logged and how.
A log messages are routed through the Log
object which doesn't process any logs itself. Instead it forwards the calls to LogSink
implementations. The base component includes the AndroidLogSink
class which implements LogSink
and forwards log messages to Android's system log.
// Forward logs to Android's system log.
// Most apps want to do that at least for debug builds:
Log.addSink(AndroidLogSink())
// A default tag can be set. This tag will be used whenever no tag is provided when logging a message.
Log.addSink(AndroidLogSink("MyAwesomeApp"))
// Log a message (See "Logger" section for more convenient ways to log)
Log.log(tag = "Test", priority = Log.Priority.DEBUG, message = "Hello World!")
// Set the minimum log level. All log messages with a lower level will be ignored.
Log.logLevel = Log.Priority.WARN
An application can add multiple LogSink
implementations to save logs to disk, send them to a crash reporting service or display them inside the app.
The Log
class only offers a low-level logging call. The logger
sub package contains classes that wrap Log
and provide a more convenient API for logging.
class MyClass {
// All log calls on this instance will use the tag MyClassLogger
val logger = Logger("MyClassLogger")
fun doSomething() {
// Will log a DEBUG message with tag MyClassLogger
logger.debug("Hello World")
}
fun couldThrow() {
try {
// ..
} catch (e: IllegalStateException) {
// Will log a ERROR message with stack trace and tag MyClassLogger
logger.error("Oops!", e)
)
}
fun generic() {
// You can also use the Logger class directly if no custom tag is needed:
Logger.info("Hello World!")
}
}
This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
file, You can obtain one at http://mozilla.org/MPL/2.0/