Использование плагина Android Gradle 0.7.0 со следующим build.gradle
:
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'com.android.tools.build:gradle:0.7.0'
}
}
apply plugin: 'android'
repositories {
maven { url "https://android-rome-feed-reader.googlecode.com/svn/maven2/releases" }
maven { url "http://dl.bintray.com/populov/maven" }
mavenCentral()
}
android {
compileSdkVersion 19
buildToolsVersion '18.1.1'
defaultConfig {
minSdkVersion 9
targetSdkVersion 19
}
buildTypes {
release {
runProguard true
proguardFile getDefaultProguardFile('proguard-android-optimize.txt')
}
}
productFlavors {
defaultFlavor {
proguardFile 'proguard-rules.txt'
}
}
sourceSets {
instrumentTest.setRoot('src/instrumentTest')
}
}
configurations {
apt
}
ext.androidAnnotationsVersion = '2.7.1';
dependencies {
compile 'com.android.support:support-v4:18.0.0'
compile 'com.viewpagerindicator:library:2.4.1@aar'
compile 'com.google.code.android-rome-feed-reader:android-rome-feed-reader:1.0.0-r2'
compile 'org.jdom:jdom:1.1.1-android-fork'
apt "com.googlecode.androidannotations:androidannotations:${androidAnnotationsVersion}"
compile "com.googlecode.androidannotations:androidannotations-api:${androidAnnotationsVersion}"
compile 'com.google.code.gson:gson:2.2.4'
compile 'com.j256.ormlite:ormlite-android:4.47'
compile 'com.j256.ormlite:ormlite-core:4.47'
compile 'org.springframework.android:spring-android-core:1.0.1.RELEASE'
compile 'org.springframework.android:spring-android-rest-template:1.0.1.RELEASE'
compile 'com.prolificinteractive:actionbarsherlock:4.3.1@aar'
compile 'com.google.code.geocoder-java:geocoder-java:0.15'
compile files('libs/CWAC-Pager.jar')
}
android.applicationVariants.all { variant ->
aptOutput = file("${project.buildDir}/source/apt_generated/${variant.dirName}")
println "****************************"
println "variant: ${variant.name}"
println "manifest: ${variant.processResources.manifestFile}"
println "aptOutput: ${aptOutput}"
println "****************************"
variant.javaCompile.doFirst {
println "*** compile doFirst ${variant.name}"
aptOutput.mkdirs()
variant.javaCompile.options.compilerArgs += [
'-processorpath', configurations.apt.getAsPath(),
'-AandroidManifestFile=' + variant.processResources.manifestFile,
'-s', aptOutput
]
}
}
выдает ошибку Duplicate files copied in APK META-INF/LICENSE.txt
:
WARNING: Dependency commons-logging:commons-logging:1.0.4 is ignored for defaultFlavorDebug as it may be conflicting with the internal version provided by Android.
In case of problem, please repackage it with jarjar to change the class packages
WARNING: Dependency commons-logging:commons-logging:1.0.4 is ignored for defaultFlavorRelease as it may be conflicting with the internal version provided by Android.
In case of problem, please repackage it with jarjar to change the class packages
Creating properties on demand (a.k.a. dynamic properties) has been deprecated and is scheduled to be removed in Gradle 2.0. Please read http://gradle.org/docs/current/dsl/org.gradle.api.plugins.ExtraPropertiesExtension.html for information on the replacement for dynamic properties.
Deprecated dynamic property: "aptOutput" on "com.android.build.gradle.internal.api.ApplicationVariantImpl_Decorated@5705013c", value: "/Users/david/Developer...".
****************************
variant: defaultFlavorDebug
manifest: /Users/david/Developer/.../build/manifests/defaultFlavor/debug/AndroidManifest.xml
aptOutput: /Users/david/Developer/.../build/source/apt_generated/defaultFlavor/debug
****************************
Deprecated dynamic property "aptOutput" created in multiple locations.
****************************
variant: defaultFlavorRelease
manifest: /Users/david/Developer/.../build/manifests/defaultFlavor/release/AndroidManifest.xml
aptOutput: /Users/david/Developer/.../build/source/apt_generated/defaultFlavor/release
****************************
:TravelGuard:compileDefaultFlavorDebugNdk UP-TO-DATE
:TravelGuard:preBuild UP-TO-DATE
:TravelGuard:preDefaultFlavorDebugBuild UP-TO-DATE
:TravelGuard:preDefaultFlavorReleaseBuild UP-TO-DATE
:TravelGuard:prepareComProlificinteractiveActionbarsherlock431Library UP-TO-DATE
:TravelGuard:prepareComViewpagerindicatorLibrary241Library UP-TO-DATE
:TravelGuard:prepareDefaultFlavorDebugDependencies
:TravelGuard:compileDefaultFlavorDebugAidl UP-TO-DATE
:TravelGuard:compileDefaultFlavorDebugRenderscript UP-TO-DATE
:TravelGuard:generateDefaultFlavorDebugBuildConfig UP-TO-DATE
:TravelGuard:mergeDefaultFlavorDebugAssets UP-TO-DATE
:TravelGuard:mergeDefaultFlavorDebugResources UP-TO-DATE
:TravelGuard:processDefaultFlavorDebugManifest UP-TO-DATE
:TravelGuard:processDefaultFlavorDebugResources UP-TO-DATE
:TravelGuard:generateDefaultFlavorDebugSources UP-TO-DATE
:TravelGuard:compileDefaultFlavorDebugJava
*** compile doFirst defaultFlavorDebug
/Users/david/Developer/.../src/main/java/com/travelguard/service/TravelGuardService.java:53: cannot find symbol
symbol : class TravelGuardPrefs_
location: class com.travelguard.service.TravelGuardService
TravelGuardPrefs_ travelGuardPrefs;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/CategoriesActivity.java:14: cannot find symbol
symbol : class AssistanceFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.AssistanceFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/CategoriesActivity.java:16: cannot find symbol
symbol : class CategoryFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.CategoryFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/CategoriesActivity.java:17: cannot find symbol
symbol : class ContactFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.ContactFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/CountriesActivity.java:25: cannot find symbol
symbol : class TravelGuardPrefs_
location: package com.travelguard.service
import com.travelguard.service.TravelGuardPrefs_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/CountriesActivity.java:44: cannot find symbol
symbol : class TravelGuardPrefs_
location: class com.travelguard.ui.CountriesActivity
TravelGuardPrefs_ travelGuardPrefs;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/InstructionsActivity.java:18: cannot find symbol
symbol : class AssistanceFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.AssistanceFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/InstructionsActivity.java:19: cannot find symbol
symbol : class ContactFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.ContactFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/InstructionsActivity.java:21: cannot find symbol
symbol : class InstructionsFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.InstructionsFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/MainActivity.java:36: cannot find symbol
symbol : class TravelGuardPrefs_
location: package com.travelguard.service
import com.travelguard.service.TravelGuardPrefs_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/MainActivity.java:40: cannot find symbol
symbol : class AssistanceFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.AssistanceFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/MainActivity.java:41: cannot find symbol
symbol : class ContactFragment_
location: package com.travelguard.ui.fragments
import com.travelguard.ui.fragments.ContactFragment_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/MainActivity.java:55: cannot find symbol
symbol : class TravelGuardPrefs_
location: class com.travelguard.ui.MainActivity
TravelGuardPrefs_ travelGuardPrefs;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/TermsActivity.java:17: cannot find symbol
symbol : class TravelGuardPrefs_
location: package com.travelguard.service
import com.travelguard.service.TravelGuardPrefs_;
^
/Users/david/Developer/.../src/main/java/com/travelguard/ui/TermsActivity.java:23: cannot find symbol
symbol : class TravelGuardPrefs_
location: class com.travelguard.ui.TermsActivity
TravelGuardPrefs_ travelGuardPrefs;
^
Note: Starting AndroidAnnotations annotation processing
Note: AndroidManifest.xml file found: /Users/david/Developer/.../build/manifests/defaultFlavor/debug/AndroidManifest.xml
Note: Number of files generated by AndroidAnnotations: 22
Note: Generating source file: com.travelguard.service.SmartTravellerService_
Note: Generating source file: com.travelguard.service.SmartTravellerWebservice_
Note: Generating source file: com.travelguard.service.TravelGuardPrefs_
Note: Generating source file: com.travelguard.service.TravelGuardService_
Note: Generating source file: com.travelguard.service.TravelGuardWebservice_
Note: Generating source file: com.travelguard.ui.AdviceActivity_
Note: Generating source file: com.travelguard.ui.CategoriesActivity_
Note: Generating source file: com.travelguard.ui.ContactDetailActivity_
Note: Generating source file: com.travelguard.ui.ContactListActivity_
Note: Generating source file: com.travelguard.ui.ContactTravelGuardActivity_
Note: Generating source file: com.travelguard.ui.CountriesActivity_
Note: Generating source file: com.travelguard.ui.InformationActivity_
Note: Generating source file: com.travelguard.ui.InstructionsActivity_
Note: Generating source file: com.travelguard.ui.MainActivity_
Note: Generating source file: com.travelguard.ui.TermsActivity_
Note: Generating source file: com.travelguard.ui.TravelGuardActivity_
Note: Generating source file: com.travelguard.ui.fragments.AdviceDetailFragment_
Note: Generating source file: com.travelguard.ui.fragments.AdviceFragment_
Note: Generating source file: com.travelguard.ui.fragments.AssistanceFragment_
Note: Generating source file: com.travelguard.ui.fragments.CategoryFragment_
Note: Generating source file: com.travelguard.ui.fragments.ContactFragment_
Note: Generating source file: com.travelguard.ui.fragments.InstructionsFragment_
Note: Time measurements: [Whole Processing = 913 ms], [Generate Sources = 358 ms], [Extract Manifest = 163 ms], [Process Annotations = 158 ms], [Extract Annotations = 120 ms], [Validate Annotations = 82 ms], [Find R Classes = 28 ms],
Note: Time measurements: [Whole Processing = 0 ms],
Note: Time measurements: [Whole Processing = 0 ms],
warning: The following options were not recognized by any processor: '[androidManifestFile]'
Note: /Users/david/Developer/.../src/main/java/com/travelguard/ui/ContactDetailActivity.java uses or overrides a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: /Users/david/Developer/.../src/main/java/com/travelguard/service/SmartTravellerService.java uses unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
:TravelGuard:preDexDefaultFlavorDebug UP-TO-DATE
:TravelGuard:dexDefaultFlavorDebug
:TravelGuard:processDefaultFlavorDebugJavaRes UP-TO-DATE
:TravelGuard:validateDebugSigning
:TravelGuard:packageDefaultFlavorDebug
Error: duplicate files during packaging of APK /Users/david/Developer/.../build/apk/TravelGuard-defaultFlavor-debug-unaligned.apk
Path in archive: META-INF/LICENSE.txt
Origin 1: /Users/david/.gradle/caches/modules-2/files-2.1/commons-httpclient/commons-httpclient/3.1/964cd74171f427720480efdec40a7c7f6e58426a/commons-httpclient-3.1.jar
Origin 2: /Users/david/.gradle/caches/modules-2/files-2.1/commons-codec/commons-codec/1.2/397f4731a9f9b6eb1907e224911c77ea3aa27a8b/commons-codec-1.2.jar
:TravelGuard:packageDefaultFlavorDebug FAILED
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':TravelGuard:packageDefaultFlavorDebug'.
> Duplicate files copied in APK META-INF/LICENSE.txt
File 1: /Users/david/.gradle/caches/modules-2/files-2.1/commons-httpclient/commons-httpclient/3.1/964cd74171f427720480efdec40a7c7f6e58426a/commons-httpclient-3.1.jar
File 2: /Users/david/.gradle/caches/modules-2/files-2.1/commons-httpclient/commons-httpclient/3.1/964cd74171f427720480efdec40a7c7f6e58426a/commons-httpclient-3.1.jar
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
Total time: 21.957 secs
Сегодня утром все работало нормально, пока я не обновил Android Studio. Любые идеи?
РЕДАКТИРОВАТЬ: я смог временно исправить это, выполнив такие команды, как
zip -d spring-android-core-1.0.1.RELEASE.jar META-INF/notice.txt
пока все повторяющиеся ошибки не исчезли.
android
gradle
android-studio
android-gradle-plugin
Дэвид Лоусон
источник
источник
pickFirst
опция доступна с Gradle 0.9.1 .Ответы:
Начиная с версии Android Studio 0.8.14
Вы должны добавить:
в ваш
build.gradle
файл.История:
Согласно комментарию 14 в этой ошибке: https://issuetracker.google.com/issues/36982149#comment14 это ошибка в v0.7.0 плагина Android Gradle, которая должна быть исправлена в версии 0.7.1 в ближайшее время.
Вот заметки из этой ошибки о дополнении для 0.7.1:
0.7.1 вышла с исправлением для этого.
DSL для исключения файлов:
Вы можете добавить столько исключений, сколько хотите. Значение - это путь к архиву. Пока нет подстановочных знаков или поддержки глобуса.
Имена файлов "LICENSE.txt" и "NOTICE.txt" чувствительны к регистру. Пожалуйста, попробуйте также использовать "license.txt" и "note.txt".
источник
В моем случае мне пришлось включить несколько дополнительных исключений. Похоже, ему не нравятся регулярные выражения, которые бы сделали это хорошим однострочником.
источник
LICENSE
иNOTICE
после того, как я добавилcommons-lang3
.источник
.txt
суффикс..txt
суффикс. Так что я думаю, YMMV (или MMMV в зависимости от времени года).Посмотрите на комментарий Сакибоя !
Устаревший ответ
Начиная с Gradle 0.9.1 поддерживается следующее:
Больше информации в примечаниях к выпуску Gradle .
источник
Та же проблема, когда я экспортирую библиотеку httclient-4.3.5 в Android Studio 0.8.6, мне нужно включить это:
Библиотека заархивировала содержимое следующей банки:
источник
Эта ошибка все еще существует в 0.8 + / 1.10
С джексоном
Я должен был включить, а также вышеупомянутое предложение, прежде чем оно скомпилирует
источник
Это более одной ошибки
Под
apply plugin: 'android-library'
Добавь это ::
В случае дубликатов файлов легко, заглянуть внутрь
JAR
подMETA-INF
каталог и посмотреть , что вызывает ошибку. Это может быть несколько. В моем случае плагин Couchbase Lite. Когда вы добавите больше плагинов, вам понадобится больше исключенийисточник
--info
флагом позволяет мне видеть журнал классов, добавляемых в apk, и затем я могу искать вверх, чтобы найти запись журнала для того же класса, добавляемого из другого JAR. Это также показало мне путь файла к обоим файлам JAR. Я не смог найти хороший способ выбрать один файл .class над другим, поэтому я изменил один из файлов JAR и удалил дубликат .classТа же проблема, когда я использовал 'org.springframework.android:spring-android-rest-template:2.0.0.M1' в Android Studio 1.0.1. Мне нужно включить это в
build.gradle
источник
Это работает для меня:
источник
Я думаю, что вам нужно включить только эти опции в build.gradle :
ps тот же ответ из моего поста в: Ошибка :: дубликаты файлов при упаковке APK
источник
Проблема в том, что папка META-INF не будет отфильтрована, поэтому множественные записи
NOTICE
илиLICENSE
дубликаты при сборке будут пытаться скопировать их вместе.Грязное Быстрое Исправление:
Откройте
.jar
файл в вашей.gradle/caches/...
папке (с помощью zip-совместимого инструмента) и удалите или переименуйте файлы вMETA-INF
папке, которые вызывают ошибку (обычноNOTICE
илиLICENSE
). (Я знаю, что это тоже в ОП, но для меня это было не совсем понятно, пока я не прочитал форум Google)РЕДАКТИРОВАТЬ:
Это было исправлено в 0.7.1. Просто добавьте искажающие файлы, чтобы исключить.
источник
То же самое здесь с
Я потерял около 2 дней из-за этой странной ошибки ... Почему это все еще происходит в Gradle 1.0.0? Это очень тревожно для новичков ... Во всяком случае, спасибо за эту информацию, я думал, что это было в моем коде :)
источник
Важно знать, в каком файле происходит эта ошибка (в вашем примере это META-INF / LICENSE.txt), в моем случае это было в META-INF / LICENSE [без «.txt»], а затем в файле META-INF / ASL2.0, поэтому я добавил в свой build.gradle следующие строки:
Очень важно (!) -> добавить имя файла в том же стиле, который вы видите в сообщении об ошибке: текст чувствителен к регистру, и есть разница между * .txt и * (без «txt») ,
источник
Если вы хотите внести свой вклад как разработчик, используя библиотеки с открытым исходным кодом, попробуйте включить все эти лицензии с открытым исходным кодом в свои
apk
. Для этого вы можете использовать метод слияния в вашемpackagingOptions
.Пример:
Этот ответ лучше, чем использовать,
pickFirst
потому что этот метод выбирает только первую найденную лицензию и игнорирует все остальные, что делает его бесполезным в этом случае.Короче говоря, используйте
merge
метод, чтобы включить все эти лицензии из тех потрясающих библиотек с открытым исходным кодом, которые вы использовали.Больше информации на
Gradle
PackagingOptions .источник
Я заметил этот комментарий коммита в AOSP, решение будет состоять в том, чтобы исключить некоторые файлы, используя DSL. Вероятно, когда выйдет 0.7.1.
источник
В моем случае мне нужно всего лишь добавить в файл build.gradle проекта:
источник
В Android Studio 1.1.0 мне нужны были строчные имена:
источник
Файлы "LICENSE.txt" и "NOTICE.txt" чувствительны к регистру. Так что для библиотеки SPring Android я должен был добавить
источник
Удаление .txt после ЛИЦЕНЗИИ удалило мою ошибку:
источник
источник