automated the build process some more, users must add the android ndk, sdk and fpc dir to their $PATH and cmake will do the rest, I still need a solution for the sdl dir. Subrepo's perhaps? hedgeroid
authorXeli
Sat, 12 Nov 2011 14:48:35 +0100
branchhedgeroid
changeset 6230 de1e43054017
parent 6228 1b7d4d7d162b
child 6232 cf4b0f43d64d
automated the build process some more, users must add the android ndk, sdk and fpc dir to their $PATH and cmake will do the rest, I still need a solution for the sdl dir. Subrepo's perhaps?
project_files/Android-build/CMakeLists.txt
project_files/Android-build/Templates/Makefile.android
--- a/project_files/Android-build/CMakeLists.txt	Sat Nov 12 14:45:36 2011 +0100
+++ b/project_files/Android-build/CMakeLists.txt	Sat Nov 12 14:48:35 2011 +0100
@@ -16,82 +16,87 @@
 # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
 ###################################################################################
 
+find_program(ANT ant)
 
+if(NOT ANDROID_NDK)
+    find_path(ANDROID_NDK ndk-build)
+endif()
 
+if(IS_DIRECTORY ${ANDROID_NDK})
+    MESSAGE(STATUS "Detected the android NDK directory at: " ${ANDROID_NDK}) 
+else ()
+    MESSAGE(FATAL_ERROR "Couldn't detect the Android NDK directory")
+endif()
+
+if(NOT ANDROID_SDK)#Check if its defined at the cmdline
+    find_path(ANDROID_SDK adb ) #assume they've added platform-tools to their path
+    get_filename_component(ANDROID_SDK ${ANDROID_SDK} PATH)
+    set(ANDROID_SDK ${ANDROID_SDK} CACHE PATH "Path to the android sdk" FORCE)
+endif()
 
-###################################################################################
-# Uncomment (remove the leading '#') and change the paths accordingly to your own 
-# build environment, please do specify an absolute path (/home/richard/SoftDev    
-# rather than ~/SoftDev).
-# You only need to change the three lines below, after that you can run 'cmake .'
-# from the hedgewars root directory
-# 
-# optionally you can specify SDL_DIR this will move the required SDL libraries to
-# the correct place
-##################################################################################
+if( IS_DIRECTORY ${ANDROID_SDK})
+    MESSAGE(STATUS "Detected the android SDK directory at: " ${ANDROID_SDK}) 
+else ()
+    MESSAGE(FATAL_ERROR "Couldn't detect the Android SDK directory")
+endif()
 
-set(ANDROID_NDK /home/richard/SoftDev/android/android-ndk-r5b)
-set(ANDROID_SDK /home/richard/SoftDev/android/android-sdk-linux_86)
-set(FPC_DIR /home/richard/SoftDev/fpc-2.4.4)
+if( NOT FPC_DIR)
+    find_path(FPC_DIR ppcrossarm)
+    get_filename_component(FPC_DIR ${FPC_DIR} PATH)
+    set(FPC_DIR ${FPC_DIR} CACHE PATH "Path to fpc dir used in the android port" FORCE)
+endif()
+
+if( IS_DIRECTORY ${FPC_DIR})
+    MESSAGE(STATUS "Detected the FreePascal directory at: " ${FPC_DIR}) 
+else ()
+    MESSAGE(FATAL_ERROR "Couldn't detect the FreePascal directory")
+endif()
+
 set(SDL_DIR /home/richard/Downloads/android-project)
 
-if(ANDROID_NDK AND ANDROID_SDK AND FPC_DIR)
 
-    set(ANDROID_SDK_API_LVL 8)
-    set(ANDROID_NDK_API_LVL 5)
+set(ANDROID_SDK_API_LVL 8)
+set(ANDROID_NDK_API_LVL 5)
 
-    MESSAGE("Creating android scripts and configuration files")
+MESSAGE(STATUS "Creating android scripts and configuration files")
 
-    configure_file(Templates/complete_build.sh .)
-    configure_file(Templates/default.properties SDL-android-project/)
-    configure_file(Templates/local.properties SDL-android-project/)
-    configure_file(Templates/Makefile.android .)
-    configure_file(Templates/pushToDevice.sh .)
-
-    if(SDL_DIR)
-
-        MESSAGE("Moving Android port of SDL to the proper directories")
+configure_file(Templates/complete_build.sh .)
+configure_file(Templates/default.properties SDL-android-project/)
+configure_file(Templates/local.properties SDL-android-project/)
+configure_file(Templates/Makefile.android .)
+configure_file(Templates/pushToDevice.sh .)
 
-        set(DirsToCopy
-            SDL
-	    SDL_image
-            SDL_mixer
-            SDL_ttf
-	    jpeg
-	    png
-            mikmod
-           ) 
-         foreach(DIR ${DirsToCopy})
-             exec_program( 
-	        ${CMAKE_COMMAND} 
-                ARGS -E copy_directory 
-	        ${SDL_DIR}/jni/${DIR}
-	        ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/${DIR}
-        	)
-             MESSAGE("Moved ${DIR}")
-         endforeach(DIR)
-        exec_program(${HGCOMMAND}
-	            ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/core/android/SDL_android.cpp
-		    )
-        exec_program(${HGCOMMAND}
-		    ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/main/android/SDL_android_main.cpp
-		    )
-        exec_program(${HGCOMMAND}
-		    ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/video/android/SDL_androidtouch.c
-		    )
+if(SDL_DIR_TEMP_DISABLE)
+    MESSAGE("Moving Android port of SDL to the proper directories")
+    set(DirsToCopy
+        SDL
+        SDL_image
+        SDL_mixer
+        SDL_ttf
+	jpeg
+	png
+         mikmod
+        ) 
+    foreach(DIR ${DirsToCopy})
+        exec_program( 
+            ${CMAKE_COMMAND} 
+            ARGS -E copy_directory 
+            ${SDL_DIR}/jni/${DIR}
+            ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/${DIR}
+        )
+        MESSAGE(STATUS "Moved ${DIR}")
+    endforeach(DIR)
+    exec_program(${HGCOMMAND}
+        ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/core/android/SDL_android.cpp
+	)
+    exec_program(${HGCOMMAND}
+        ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/main/android/SDL_android_main.cpp
+	)
+    exec_program(${HGCOMMAND}
+        ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/video/android/SDL_androidtouch.c
+        )
 
-        exec_program(${HGCOMMAND}
-		    ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/video/android/SDL_androidtouch.h
-		    )
-
-
-    else(SDL_DIR)
-        MESSAGE("Android port of SDL not moved..")
-    endif(SDL_DIR)
-
- 
-else(ANDROID_AND AND ANDROID_SDK AND FPC_DIR)
-    MESSAGE("Android port files not created, edit top of ${CMAKE_CURRENT_SOURCE_DIR}/CMakeList.txt to create android specific files")
-endif(ANDROID_NDK AND ANDROID_SDK AND FPC_DIR)
-
-
+    exec_program(${HGCOMMAND}
+        ARGS revert ${CMAKE_CURRENT_SOURCE_DIR}/SDL-android-project/jni/SDL/src/video/android/SDL_androidtouch.h
+	)
+endif(SDL_DIR_TEMP_DISABLE)
--- a/project_files/Android-build/Templates/Makefile.android	Sat Nov 12 14:45:36 2011 +0100
+++ b/project_files/Android-build/Templates/Makefile.android	Sat Nov 12 14:48:35 2011 +0100
@@ -14,7 +14,14 @@
 
 all:
 	-${CMAKE_COMMAND} -E make_directory out
+
+	${ANDROID_NDK}/ndk-build -C $(SDL_ANDROID_DIR) -j 8
+
 	$(PPCROSSARM) $(LINKERFLAGS) $(PPCROSSARM_FLAGS) $(PPCROSSARM_INCLUDES) $(FPC_DEFINES) -oout/libhwengine.so ../../hedgewars/hwLibrary.pas
 	${CMAKE_COMMAND} -E copy out/libhwengine.so SDL-android-project/libs/armeabi/
+
+	${ANT} install -f $(SDL_ANDROID_DIR)/build.xml
 clean:  
-	${CMAKE_COMMAND} -E remove_directory out	
+	${CMAKE_COMMAND} -E remove_directory out
+	${ANDROID_NDK}/ndk-build -C $(SDL_ANDROID_DIR) -j 8 clean
+	${ANT} clean -f $(SDL_ANDROID_DIR)/build.xml