summaryrefslogtreecommitdiff
path: root/platform/android/src/logger.cpp
diff options
context:
space:
mode:
authortobrun <tobrun.van.nuland@gmail.com>2018-07-17 15:05:53 +0200
committerTobrun <tobrun@mapbox.com>2018-08-24 18:40:11 +0200
commitd297bf10ef89e97da30e1a00dd49560e18bcb3f0 (patch)
tree7f7eea2ffd8125777d258a62683d3ffbeb66820f /platform/android/src/logger.cpp
parent0f58d956d7b525f3722f24494784c8b97801105a (diff)
downloadqtlocation-mapboxgl-d297bf10ef89e97da30e1a00dd49560e18bcb3f0.tar.gz
[android] - modularise the sdk
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