Android с муравьиным лицензированием библиотек - PullRequest
6 голосов
/ 19 апреля 2011

Мне нужно использовать ANT с процессом сборки Android, потому что в конце мне нужно создать две версии приложения (FULL & LITE).Когда я создал новый проект с помощью инструментов командной строки, он генерирует для меня все необходимые файлы сборки (build.xml, local.properties, build.properties и default.properties, oh, а также proguard.cfg).Моя полная версия приложения нуждается в библиотеке лицензирования рынка (которая находится в моей библиотеке $ {sdk.dir} / extras / google / market_licensing /. Поэтому в Eclipse я определяю, где находится эта библиотека, и она работает, если я запускаю свое приложение из EclipseТеперь, если я запускаю ant-скрипт в моем приложении

${my.project-home}$ ant
Buildfile: ${my.project-home}/build.xml
    [setup] Android SDK Tools Revision 10
    [setup] Project Target: Android 2.1-update1
    [setup] API level: 7
    [setup] 
    [setup] ------------------
    [setup] Resolving library dependencies:

BUILD FAILED
${my.project-home}/build.xml:77: ../../../android-sdk-mac_86/extras/google/market_licensing/library resolve to a path with no default.properties file for project ${my.project-home}

Мои default.properties выглядят как

target=android-7
android.library=false
android.library.reference.1=../../../android-sdk-mac_86/extras/google/market_licensing/library

И мой build.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project name="MyMeasures">

<!-- 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 build.properties file can be created by you and is never touched
         by the 'android' tool. This is the place to change some of the
         default property values used by the Ant rules.
         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'.

         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="build.properties" />

    <!-- The default.properties file is created and updated by the 'android'
         tool, as well as ADT.
         This file is an integral part of the build system for your
         application and should be checked into Version Control Systems. -->
    <property file="default.properties" />


    <!-- Required pre-setup import -->
    <import file="${sdk.dir}/tools/ant/pre_setup.xml" />


<!-- extension targets. Uncomment the ones where you want to do custom work
     in between standard targets -->

    <target name="-pre-build">
    </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">
    </target>
-->

    <!-- Execute the Android Setup task that will setup some properties
         specific to the target, and import the build rules files.

         The rules file is imported from
            <SDK>/tools/ant/
         Depending on the project type it can be either:
         - main_rules.xml
         - lib_rules.xml
         - test_rules.xml

         To customize existing targets, there are two options:
         - Customize only one target:
             - copy/paste the target into this file, *before* the
               <setup> task.
             - customize it to your needs.
         - Customize the whole script.
             - copy/paste the content of the rules files (minus the top node)
               into this file, *after* the <setup> task
             - disable the import of the rules by changing the setup task
               below to <setup import="false" />.
             - customize to your needs.
    -->
    <setup />

</project>

единственное, что я сейчас делаю в build.xml, это то, что я раскомментировал -pre-build и -pre-compile, но они ничего не делают ... Я также попытался прокомментировать их, и это тот же результат.

Есть кто-нибудьиспользуется библиотека лицензирования рынка с муравьем?

Ответы [ 4 ]

2 голосов
/ 16 сентября 2011

немного более старая тема, но, возможно, это кому-то поможет. У меня была такая же проблема, и, наконец, я обнаружил источник проблем

система: win7, последнее Eclipse и старые инструменты для Android

создал build.xml с

android update project --path .

добавлены библиотеки (библиотеки) в default.properties, такие как

android.library.reference.1=..\dir\MyLibrary

но это не работает ... наконец-то я нашел решение. Это работает !

android.library.reference.1=..\\dir\\MyLibrary

надеюсь, это кому-нибудь поможет ...

0 голосов
/ 29 мая 2011

zmeda проверьте дополнительную папку LVM. Я думаю, что в ней отсутствует файл default.properties .. по крайней мере, именно об этом говорится в вашем сообщении об ошибке ..

0 голосов
/ 09 сентября 2011

Привет, вам нужно поместить ссылку на проект библиотеки в файл build.properties вашего основного приложения. Это должно выглядеть так:

android.library.reference.1=../path-to/library-project

Тогда, пока у этого проекта есть рабочий муравей build.xml, он будет собираться и включаться в ваше приложение.

Подробнее здесь

0 голосов
/ 19 апреля 2011

Я не использовал эту библиотеку, однако обнаружил, что для сборок Ant, для которых требуются сторонние jar-файлы, необходимо создать каталог 'libs' ниже вашего 'my_project_home' (т.е. на том же уровне, что и 'src').Брось туда банку.Цели в main_rules.xml должны быть в состоянии найти его.

...