summaryrefslogtreecommitdiff
path: root/platform/android/src/logger.cpp
blob: 0ade914604edf8f51cfcb6b9c68ba31ff1b9e842 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#include "logger.hpp"
#include "java_types.hpp"

namespace mbgl {
namespace android {

void Logger::registerNative(jni::JNIEnv& env) {
    _class = *jni::Class<Logger>::Find(env).NewGlobalRef(env).release();
}

jni::Class<Logger> Logger::_class;

void Logger::log(jni::JNIEnv& env, EventSeverity severity, const std::string &msg) {
    auto tag = jni::Make<jni::String>(env, "Mbgl");
    auto message = jni::Make<jni::String>(env, msg);
    using Signature = void(jni::String, jni::String);

    if (severity == EventSeverity::Debug) {
        auto static debug = _class.GetStaticMethod<Signature>(env, "d");
        _class.Call(env, debug, tag, message);
    } else if (severity == EventSeverity::Info) {
        auto static info = _class.GetStaticMethod<Signature>(env, "i");
        _class.Call(env, info, tag, message);
    } else if(severity == EventSeverity::Warning) {
        auto static warning = _class.GetStaticMethod<Signature>(env, "w");
        _class.Call(env, warning, tag, message);
    } else {
        auto static error = _class.GetStaticMethod<Signature>(env, "e");
        _class.Call(env, error, tag, message);
    }

    DeleteLocalRef(env, tag);
    DeleteLocalRef(env, message);
}

} // namespace android
} // namespace mbgl