project_files/Android-build/SDL-android-project/jni/src/hedgewars_main.c
branchhedgeroid
changeset 5304 e29aa9e29f00
child 5350 4c100fbfad5f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/project_files/Android-build/SDL-android-project/jni/src/hedgewars_main.c	Wed Jun 22 23:59:01 2011 +0200
@@ -0,0 +1,40 @@
+
+#include "android/log.h"
+#include "SDL.h"
+#include "dlfcn.h"
+#include "GLES/gl.h"
+
+#define TAG "HWEngine Loader"
+
+typedef  (*HWEngine_Game)(int);
+
+main(int argc, char *argv[]){
+	void *handle;
+	char *error;
+	HWEngine_Game Game;
+	
+
+        __android_log_print(ANDROID_LOG_INFO, TAG, "HWEngine being loaded");
+	handle = dlopen("/data/data/org.hedgewars/lib/libhwengine.so", RTLD_NOW|RTLD_GLOBAL);
+	if(!handle){
+		__android_log_print(ANDROID_LOG_INFO, "foo", dlerror());
+		__android_log_print(ANDROID_LOG_INFO, "foo", "error dlopen");
+		exit(EXIT_FAILURE);
+	}
+	dlerror();
+
+        __android_log_print(ANDROID_LOG_INFO, TAG, "HWEngine successfully loaded..");
+
+
+	Game = (HWEngine_Game) dlsym(handle,"Game");
+	if((error = dlerror()) != NULL){
+		__android_log_print(ANDROID_LOG_INFO, "foo", error);
+		__android_log_print(ANDROID_LOG_INFO, "foo", "error dlsym");
+		exit(EXIT_FAILURE);
+	}
+	__android_log_print(ANDROID_LOG_INFO, "foo", "dlsym succeeded");
+	Game(1);
+	__android_log_print(ANDROID_LOG_INFO, "foo", "Game() succeeded");
+
+	dlclose(handle);
+}