summaryrefslogtreecommitdiff
path: root/platform/android/src/logger.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'platform/android/src/logger.cpp')
-rw-r--r--platform/android/src/logger.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/platform/android/src/logger.cpp b/platform/android/src/logger.cpp
new file mode 100644
index 0000000000..1cc7660716
--- /dev/null
+++ b/platform/android/src/logger.cpp
@@ -0,0 +1,34 @@
+#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);
+ }
+}
+
+} // namespace android
+} // namespace mbgl \ No newline at end of file