mirror of
https://github.com/etesync/android
synced 2025-01-23 14:10:54 +00:00
7ab740d443
* build.xml for Ant * necessary library re-organization * compatiblity changes to code * now buildable via Ant and Eclipse ADT * eclipse-libs has to be included for ADT building only * ready for Fdroid
143 lines
6.4 KiB
XML
143 lines
6.4 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<project name="davdroid" 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: custom -->
|
|
<target name="-compile" depends="-pre-build, -build-setup, -code-gen, -pre-compile">
|
|
<do-only-if-manifest-hasCode elseText="hasCode = false. Skipping...">
|
|
<!-- merge the project's own classpath and the tested project's classpath -->
|
|
<path id="project.javac.classpath">
|
|
<fileset dir="compile-libs" includes="*.jar" />
|
|
<path refid="project.all.jars.path" />
|
|
<path refid="tested.project.classpath" />
|
|
<path path="${java.compiler.classpath}" />
|
|
</path>
|
|
<javac encoding="${java.encoding}"
|
|
source="${java.source}" target="${java.target}"
|
|
debug="true" extdirs="" includeantruntime="false"
|
|
destdir="${out.classes.absolute.dir}"
|
|
bootclasspathref="project.target.class.path"
|
|
verbose="${verbose}"
|
|
classpathref="project.javac.classpath"
|
|
fork="${need.javac.fork}">
|
|
<src path="${source.absolute.dir}" />
|
|
<src path="${gen.absolute.dir}" />
|
|
<compilerarg line="${java.compilerargs}" />
|
|
</javac>
|
|
|
|
<!-- if the project is a library then we generate a jar file -->
|
|
<if condition="${project.is.library}">
|
|
<then>
|
|
<echo level="info">Creating library output jar file...</echo>
|
|
<property name="out.library.jar.file" location="${out.absolute.dir}/classes.jar" />
|
|
<if>
|
|
<condition>
|
|
<length string="${android.package.excludes}" trim="true" when="greater" length="0" />
|
|
</condition>
|
|
<then>
|
|
<echo level="info">Custom jar packaging exclusion: ${android.package.excludes}</echo>
|
|
</then>
|
|
</if>
|
|
|
|
<propertybyreplace name="project.app.package.path" input="${project.app.package}" replace="." with="/" />
|
|
|
|
<jar destfile="${out.library.jar.file}">
|
|
<fileset dir="${out.classes.absolute.dir}"
|
|
includes="**/*.class"
|
|
excludes="${project.app.package.path}/R.class ${project.app.package.path}/R$*.class ${project.app.package.path}/BuildConfig.class"/>
|
|
<fileset dir="${source.absolute.dir}" excludes="**/*.java ${android.package.excludes}" />
|
|
</jar>
|
|
</then>
|
|
</if>
|
|
|
|
</do-only-if-manifest-hasCode>
|
|
</target>
|
|
|
|
<import file="${sdk.dir}/tools/ant/build.xml" />
|
|
|
|
</project>
|