Easy and useful log methods for Android apps in debug or release mode, with minimal impact.
In my country (México), software developers are poorly paid, so I have had to look for another job to earn a living and I cannot dedicate more time to maintaining this and other repositories that over the years have never generated any money for me. If anyone is interested in maintaining this repository, I'd be happy to transfer it to them, along with the associated npm package. |
---|
En mi país (México), los desarrolladores de software somos pésimamente pagados, por lo que he tenido que buscar otro trabajo para ganarme la vida y no puedo dedicar más tiempo a mantener éste y otros repositorios que a través de los años nunca me generaron dinero. Si a alguien le interesa dar mantenimiento a este repositorio, con gusto se lo transferiré, así como el paquete de npm asociado. |
Works with RN 0.50+, Gradle plugin 3.1.x and Gradle 4.4 or later.
Default build is for minSdkVersion
21 and targetSdkVersion
27, but you can configure this.
NOTE:
In iOS, the default level is SUPPRESS
, which disables the output. If you change it, console.log
will be used.
-
Install the module from npm and link it:
$ yarn add react-native-android-log $ react-native link react-native-android-log
-
Replace 'compile' with 'implementation' in your android/app/build.gradle. It must looks like:
implementation project(':react-native-android-log')
Optional: You can add the tag used by Log to the logCatArguments
properties in .vscode/launch.json
This example will include React Native warnings and errors, and all the messages from App in the "OUTPUT" panel:
...
{
"name": "Debug Android",
"program": "${workspaceRoot}/.vscode/launchReactNative.js",
"type": "reactnative",
"request": "launch",
"platform": "android",
"sourceMaps": true,
"outDir": "${workspaceRoot}/.vscode/.react",
"logCatArguments": [
"*:S",
"ReactNative:W",
"ReactNativeJS:W",
"App:V"
]
},
Optional: In your android/build.gradle file, set the SDK versions that your app is using.
Example with the predefined values:
ext {
def buildToolsVersion = '27.0.3'
def minSdkVersion = 16
def compileSdkVersion = 27
def targetSdkVersion = 27
}
Log messages in your JavaScript files:
import Log from 'react-native-android-log'
// Set the default priority level (optional)
Log.setLevel(__DEV__ ? Log.VERBOSE : Log.WARN)
...
Log.v('Verbose message') // no output in release builds
Log.w('Debugging')
// debugging message with amother tag:
Log.d('Proc2', 'warning')
...and see the output in the console through adb
:
$ adb logcat -s App:V Proc2:V
or in the OUPUT panel of VS Code, if you are using the React Native Tools extension.
Numeric levels, from most to least verbosity:
Constant | Description |
---|---|
VERBOSE |
Used by Log.v , outputs nothing unless you use Log.setLevel(Log.VERBOSE) |
DEBUG |
Priority constant for Log.d |
INFO |
Priority constant for Log.i |
WARN |
Priority constant for Log.w |
ERROR |
Priority constant for Log.e |
SUPPRESS |
This is a special constant used to disable logging |
-
setTag(tag: string)
Sets the tag to use by the logging methods without a tag parameter.
The predefined tag is "App".
-
setLevel(tag: string | null, level: number)
Allows you to change the logging level for a specific tag or, if you pass a null tag, the default level for all the tags.
The predefined level is
DEBUG
for debug builds andERROR
for release builds. -
getLevel(tag?: string | null)
Return the level for a specific tag.
If tag is
null
, not specified, or does not have a specific level, this method return the default level for all the tags. -
print(level: string, tag: string, msg: string)
-
print(level: string, msg: string)
Base method for all the one-letter logging methods.
-
v (VERBOSE)
-
d (DEBUG)
-
i (INFO)
-
w (WARN)
-
e (ERROR)
The above methods are one-letter shortcuts to the
print
method with the corresponding priority level and can be invoked with or without thetag
parameter:method(tag: string, msg: string)
method(msg: string)
If you omit the
tag
, the one specified withsetTag
will be used, or the predefined tag "App".
MIT © 2018 Alberto Martínez