summaryrefslogtreecommitdiff
path: root/platform/android/src/logger.cpp
blob: f5d78cc83ce4d3a7c52615877cc54ad111418a14 (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
#include "logger.hpp"
#include "java_types.hpp"

namespace mbgl {
namespace android {

void Logger::registerNative(jni::JNIEnv& env) {
    jni::Class<Logger>::Singleton(env);
}

void Logger::log(jni::JNIEnv& env, EventSeverity severity, const std::string &msg) {
    static auto& _class = jni::Class<Logger>::Singleton(env);

    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);
    }
}

} // namespace android
} // namespace mbgl