kopia lustrzana https://github.com/ge0rg/aprsdroid
160 wiersze
6.4 KiB
XML
160 wiersze
6.4 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<project name="APRSdroid" 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. -->
|
|
<loadproperties srcFile="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" />
|
|
|
|
<!-- 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'"
|
|
unless="sdk.dir"
|
|
/>
|
|
|
|
|
|
<!-- extension targets. Uncomment the ones where you want to do custom work
|
|
in between standard targets -->
|
|
<property name="mapviewxml" value="res/layout/mapview.xml" />
|
|
<target name="-pre-build">
|
|
<fail unless="mapsApiKey">You need to add mapsApiKey=... to local.properties</fail>
|
|
<copy file="mapview.xml.tpl" tofile="${mapviewxml}" overwrite="true">
|
|
<filterchain>
|
|
<replacetokens>
|
|
<token key="apiKey" value="${mapsApiKey}"/>
|
|
</replacetokens>
|
|
</filterchain>
|
|
|
|
</copy>
|
|
<tstamp>
|
|
<format property="build.date" pattern="yyyy-MM-dd" />
|
|
</tstamp>
|
|
<exec executable="git" outputproperty="git.revision">
|
|
<arg line="describe --tags --dirty=+"/>
|
|
</exec>
|
|
<copy file="version.xml.tpl" tofile="${resource.absolute.dir}/values/version.xml" overwrite="true">
|
|
<filterchain>
|
|
<replacetokens>
|
|
<token key="build_version" value="${ant.project.name} ${git.revision} ${build.date}"/>
|
|
</replacetokens>
|
|
</filterchain>
|
|
|
|
</copy>
|
|
</target>
|
|
<!--
|
|
<target name="-pre-compile">
|
|
</target>
|
|
|
|
/* 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} */
|
|
-->
|
|
<target name="-post-compile" depends="scalac, proguard">
|
|
</target>
|
|
|
|
<!-- 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 -->
|
|
<import file="${sdk.dir}/tools/ant/build.xml" />
|
|
|
|
<target name="check-scalalib">
|
|
<available file="tools/scala-library.jar" property="have.scalalib"/>
|
|
<fail unless="have.scalalib">You have to place scala-compiler.jar and scala-library.jar to tools/</fail>
|
|
</target>
|
|
<target name="check-scalac">
|
|
<available file="tools/scala-compiler.jar" property="have.scalac"/>
|
|
<fail unless="have.scalac">You have to place scala-compiler.jar and scala-library.jar to tools/</fail>
|
|
</target>
|
|
|
|
<target name="scalac" depends="-compile, check-scalalib, check-scalac">
|
|
<taskdef resource="scala/tools/ant/antlib.xml"
|
|
classpath="tools/scala-compiler.jar:tools/scala-library.jar" />
|
|
<scalac force="changed" deprecation="on"
|
|
srcdir="${source.absolute.dir}" includes="**/*.scala"
|
|
bootclasspathref="android.target.classpath"
|
|
destdir="${out.classes.absolute.dir}">
|
|
<classpath>
|
|
<pathelement location="${out.classes.absolute.dir}"/>
|
|
<fileset dir="tools" includes="*.jar"/>
|
|
<fileset dir="${jar.libs.dir}" includes="*.jar"/>
|
|
</classpath>
|
|
</scalac>
|
|
</target>
|
|
|
|
<target name="check-proguard">
|
|
<available file="tools/proguard.jar" property="have.proguard"/>
|
|
<fail unless="have.proguard">ProGuard is required to build! Copy proguard.jar to tools/</fail>
|
|
</target>
|
|
|
|
<property name="optimized.dir" value="${out.absolute.dir}/optimized" />
|
|
<target name="proguard" depends="scalac, check-proguard">
|
|
<taskdef resource="proguard/ant/task.properties"
|
|
classpath="tools/proguard.jar" />
|
|
<mkdir dir="${optimized.dir}" />
|
|
<proguard configuration="proguard.cfg">
|
|
-injars ${out.classes.absolute.dir}:${jar.libs.dir}:tools/scala-library.jar(!META-INF/MANIFEST.MF,!library.properties)
|
|
-outjars ${out.absolute.dir}/classes.min.jar
|
|
-libraryjars ${toString:android.target.classpath}
|
|
-printusage ${optimized.dir}/proguard.usage
|
|
</proguard>
|
|
</target>
|
|
|
|
<target name="-dex" depends="-post-compile">
|
|
<echo>Converting compiled files and external libraries into ${intermediate.dex.file}...</echo>
|
|
<apply executable="${dx}" failonerror="true" parallel="true">
|
|
<arg value="--dex" />
|
|
<arg value="--output=${intermediate.dex.file}" />
|
|
<fileset dir="${out.absolute.dir}" includes="*.min.jar"/>
|
|
</apply>
|
|
</target>
|
|
</project>
|