Fixed out of source build.
authorArmin Novak <anovak@thinstuff.com>
Tue, 17 Sep 2013 14:07:52 +0000 (16:07 +0200)
committerArmin Novak <anovak@thinstuff.com>
Tue, 17 Sep 2013 14:07:52 +0000 (16:07 +0200)
client/Android/FreeRDPCore/AndroidManifest.xml.cmake
client/Android/FreeRDPCore/CMakeLists.txt
client/Android/FreeRDPCore/ant.properties [deleted file]
client/Android/FreeRDPCore/build.xml [deleted file]
client/Android/FreeRDPCore/jni/CMakeLists.txt
client/Android/FreeRDPCore/project.properties.cmake [moved from client/Android/FreeRDPCore/project.properties with 93% similarity]

index 161f5c0..f21e53c 100644 (file)
@@ -3,10 +3,10 @@
 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
        android:installLocation="auto"
        package="com.freerdp.freerdpcore"
-       android:versionCode="1"
+       android:versionCode="2"
        android:versionName="@GIT_REVISION@" >
 
-       <uses-sdk android:targetSdkVersion="8" android:minSdkVersion="8"/>
+       <uses-sdk android:targetSdkVersion="@ANDROID_APP_TARGET_SDK@" android:minSdkVersion="@ANDROID_APP_MIN_SDK@"/>
        <uses-permission android:name="android.permission.INTERNET"/>
        <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
        <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
index 005e90d..6f256af 100644 (file)
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
-set(ANDROID_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
+set(ANDROID_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR})
 set(ANDROID_PACKAGE_NAME "aFreeRDPCore")
 
-CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/AndroidManifest.xml.cmake ${CMAKE_CURRENT_SOURCE_DIR}/AndroidManifest.xml @ONLY)
+CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/AndroidManifest.xml.cmake
+       ${CMAKE_CURRENT_BINARY_DIR}/AndroidManifest.xml @ONLY)
+CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/build.xml.cmake
+       ${CMAKE_CURRENT_BINARY_DIR}/build.xml @ONLY)
+CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/project.properties.cmake
+       ${CMAKE_CURRENT_BINARY_DIR}/project.properties @ONLY)
+CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/ant.properties.cmake
+       ${CMAKE_CURRENT_BINARY_DIR}/ant.properties @ONLY)
+
+file(COPY res DESTINATION ${CMAKE_CURRENT_BINARY_DIR})
 
 if (ANDROID_SDK)
-       CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/local.properties.cmake ${CMAKE_CURRENT_SOURCE_DIR}/local.properties @ONLY)
+       CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/local.properties.cmake
+               ${CMAKE_CURRENT_BINARY_DIR}/local.properties @ONLY)
 endif()
 
 add_subdirectory(jni)
 
 
 if(ANDROID_BUILD_JAVA)
-       set(ANDROIDLIB "${ANDROID_SOURCE_DIR}/bin/classes.jar")
+       set(ANDROIDLIB "${ANDROID_BINARY_DIR}/bin/classes.jar")
 
   # command to create the android package
        add_custom_command(
                OUTPUT "${ANDROIDLIB}"
                COMMAND ${ANT_COMMAND} ${ANDROID_BUILD_TYPE}
-               WORKING_DIRECTORY "${ANDROID_SOURCE_DIR}"
+               WORKING_DIRECTORY "${ANDROID_BINARY_DIR}"
                MAIN_DEPENDENCY AndroidManifest.xml
-               DEPENDS freerdp-android local.properties
+               DEPENDS freerdp-android
+                       ${CMAKE_CURRENT_BINARY_DIR}/local.properties
        )
        add_custom_target(android-lib ALL SOURCES "${ANDROIDLIB}")
        SET_DIRECTORY_PROPERTIES(PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES "gen;bin")
diff --git a/client/Android/FreeRDPCore/ant.properties b/client/Android/FreeRDPCore/ant.properties
deleted file mode 100644 (file)
index 73031c7..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-# This file is used to override default values used by the Ant build system.
-#
-# This file must be checked into Version Control Systems, as it is
-# integral to the build system of your project.
-
-# This file is only used by the Ant script.
-
-# You can use this to override default values such as
-#  'source.dir' for the location of your java source folder and
-#  'out.dir' for the location of your output folder.
-
-# You can also use it define how the release builds are signed by declaring
-# the following properties:
-#  'key.store' for the location of your keystore and
-#  'key.alias' for the name of the key to use.
-# The password will be asked during the build when you use the 'release' target.
diff --git a/client/Android/FreeRDPCore/build.xml b/client/Android/FreeRDPCore/build.xml
deleted file mode 100644 (file)
index f07d7de..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project name="." default="help">
-
-    <!-- The local.properties file is created and updated by the 'android' tool.
-         It contains the path to the SDK. It should *NOT* be checked into
-         Version Control Systems. -->
-    <property file="local.properties" />
-
-    <!-- The ant.properties file can be created by you. It is only edited by the
-         'android' tool to add properties to it.
-         This is the place to change some Ant specific build properties.
-         Here are some properties you may want to change/update:
-
-         source.dir
-             The name of the source directory. Default is 'src'.
-         out.dir
-             The name of the output directory. Default is 'bin'.
-
-         For other overridable properties, look at the beginning of the rules
-         files in the SDK, at tools/ant/build.xml
-
-         Properties related to the SDK location or the project target should
-         be updated using the 'android' tool with the 'update' action.
-
-         This file is an integral part of the build system for your
-         application and should be checked into Version Control Systems.
-
-         -->
-    <property file="ant.properties" />
-
-    <!-- if sdk.dir was not set from one of the property file, then
-         get it from the ANDROID_HOME env var.
-         This must be done before we load project.properties since
-         the proguard config can use sdk.dir -->
-    <property environment="env" />
-    <condition property="sdk.dir" value="${env.ANDROID_HOME}">
-        <isset property="env.ANDROID_HOME" />
-    </condition>
-
-    <!-- The project.properties file is created and updated by the 'android'
-         tool, as well as ADT.
-
-         This contains project specific properties such as project target, and library
-         dependencies. Lower level build properties are stored in ant.properties
-         (or in .classpath for Eclipse projects).
-
-         This file is an integral part of the build system for your
-         application and should be checked into Version Control Systems. -->
-    <loadproperties srcFile="project.properties" />
-
-    <!-- quick check on sdk.dir -->
-    <fail
-            message="sdk.dir is missing. Make sure to generate local.properties using 'android update project' or to inject it through the ANDROID_HOME environment variable."
-            unless="sdk.dir"
-    />
-
-    <!--
-        Import per project custom build rules if present at the root of the project.
-        This is the place to put custom intermediary targets such as:
-            -pre-build
-            -pre-compile
-            -post-compile (This is typically used for code obfuscation.
-                           Compiled code location: ${out.classes.absolute.dir}
-                           If this is not done in place, override ${out.dex.input.absolute.dir})
-            -post-package
-            -post-build
-            -pre-clean
-    -->
-    <import file="custom_rules.xml" optional="true" />
-
-    <!-- Import the actual build file.
-
-         To customize existing targets, there are two options:
-         - Customize only one target:
-             - copy/paste the target into this file, *before* the
-               <import> task.
-             - customize it to your needs.
-         - Customize the whole content of build.xml
-             - copy/paste the content of the rules files (minus the top node)
-               into this file, replacing the <import> task.
-             - customize to your needs.
-
-         ***********************
-         ****** IMPORTANT ******
-         ***********************
-         In all cases you must update the value of version-tag below to read 'custom' instead of an integer,
-         in order to avoid having your file be overridden by tools such as "android update project"
-    -->
-    <!-- version-tag: 1 -->
-    <import file="${sdk.dir}/tools/ant/build.xml" />
-
-</project>
index 5aec24e..05e6e1f 100644 (file)
@@ -68,6 +68,7 @@ set(${MODULE_PREFIX}_LIBS ${${MODULE_PREFIX}_LIBS} jnigraphics)
 
 target_link_libraries(${MODULE_NAME} ${${MODULE_PREFIX}_LIBS})
 
-set_target_properties(${MODULE_NAME} PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${ANDROID_SOURCE_DIR}/libs/${ANDROID_ABI}")
+set_target_properties(${MODULE_NAME}
+       PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${ANDROID_BINARY_DIR}/libs/${ANDROID_ABI}")
 
 set_property(TARGET ${MODULE_NAME} PROPERTY FOLDER "Client/Android")
@@ -11,5 +11,5 @@
 #proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
 
 # Project target.
-target=android-11
+target=android-@ANDROID_APP_TARGET_SDK@
 android.library=true