summaryrefslogtreecommitdiffstats
path: root/android.cpp
diff options
context:
space:
mode:
authorGravatar Anton Lundin <glance@acc.umu.se>2014-03-26 23:08:57 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-03-27 10:40:43 -0700
commitdf12944c939d618fe2d2629e990c6355d402545c (patch)
treec7d2d0c0c2df62e4957d06fe7859215a2ef15a4b /android.cpp
parent770bf9afba18a2d50ead56c0068dc07ed8cb63a1 (diff)
downloadsubsurface-df12944c939d618fe2d2629e990c6355d402545c.tar.gz
Introduce android specific file
This contains a first stab at Subsurface platform interfacing code for Android, and surrounding parts. Signed-off-by: Anton Lundin <glance@acc.umu.se> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'android.cpp')
-rw-r--r--android.cpp81
1 files changed, 81 insertions, 0 deletions
diff --git a/android.cpp b/android.cpp
new file mode 100644
index 000000000..15de9e65d
--- /dev/null
+++ b/android.cpp
@@ -0,0 +1,81 @@
+/* implements Android specific functions */
+#include "dive.h"
+#include "display.h"
+#include <string.h>
+#include <sys/types.h>
+#include <dirent.h>
+#include <fcntl.h>
+
+#include <QtAndroidExtras/QtAndroidExtras>
+#include <QtAndroidExtras/QAndroidJniObject>
+
+extern "C" {
+
+const char system_divelist_default_font[] = "Roboto";
+const int system_divelist_default_font_size = 8;
+
+const char *system_default_filename(void)
+{
+ /* Replace this when QtCore/QStandardPaths getExternalStorageDirectory landed */
+ QAndroidJniObject externalStorage = QAndroidJniObject::callStaticObjectMethod("android/os/Environment", "getExternalStorageDirectory", "()Ljava/io/File;");
+ QAndroidJniObject externalStorageAbsolute = externalStorage.callObjectMethod( "getAbsolutePath", "()Ljava/lang/String;" );
+ QString system_default_filename = externalStorageAbsolute.toString()+"/subsurface.xml";
+ QAndroidJniEnvironment env;
+ if (env->ExceptionCheck()) {
+ // FIXME: Handle exception here.
+ env->ExceptionClear();
+ return strdup("/sdcard/subsurface.xml");
+ }
+ return strdup(system_default_filename.toUtf8().data());
+}
+
+int enumerate_devices (device_callback_t callback, void *userdata)
+{
+ /* FIXME: we need to enumerate in some other way on android */
+ /* qtserialport maybee? */
+ return -1;
+}
+
+/* NOP wrappers to comform with windows.c */
+int subsurface_rename(const char *path, const char *newpath)
+{
+ return rename(path, newpath);
+}
+
+int subsurface_open(const char *path, int oflags, mode_t mode)
+{
+ return open(path, oflags, mode);
+}
+
+FILE *subsurface_fopen(const char *path, const char *mode)
+{
+ return fopen(path, mode);
+}
+
+void *subsurface_opendir(const char *path)
+{
+ return (void *)opendir(path);
+}
+
+struct zip *subsurface_zip_open_readonly(const char *path, int flags, int *errorp)
+{
+ return zip_open(path, flags, errorp);
+}
+
+int subsurface_zip_close(struct zip *zip)
+{
+ return zip_close(zip);
+}
+
+/* win32 console */
+void subsurface_console_init(bool dedicated)
+{
+ /* NOP */
+}
+
+void subsurface_console_exit(void)
+{
+ /* NOP */
+}
+
+}