J'utilise libusb dans mon application Android. Lorsque j'essaie de construire la bibliothèque native libusb
, le message d'erreur ci-dessous s'affiche et les fichiers * .so sont générés.
Erreur: L'exécution a échoué pour la tâche ': app: transformNativeLibsWithMergeJniLibsForDebug' . Plusieurs fichiers ont été trouvés avec le chemin indépendant du système d'exploitation 'lib/x86/libusb.so'
build.gradle
import org.Apache.tools.ant.taskdefs.condition.Os
apply plugin: 'com.Android.application'
apply plugin: 'kotlin-Android'
apply plugin: 'kotlin-Android-extensions'
Android {
compileSdkVersion 26
buildToolsVersion "26.0.0"
defaultConfig {
applicationId "com.williams.libusbpoc"
minSdkVersion 21
targetSdkVersion 26
versionCode 1
versionName "1.0"
testInstrumentationRunner "Android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-Android.txt'), 'proguard-rules.pro'
}
}
externalNativeBuild {
ndkBuild {
path 'src/main/jni/Android.mk'
}
}
sourceSets.main {
jniLibs.srcDir 'src/main/libs'
jni.srcDirs = [] //disable automatic ndk-build call
}
// call regular ndk-build(.cmd) script from app directory
task ndkBuild(type: Exec) {
if (Os.isFamily(Os.FAMILY_WINDOWS)) {
commandLine 'ndk-build.cmd', '-C', file('src/main').absolutePath
} else {
commandLine 'ndk-build', '-C', file('src/main').absolutePath
}
}
tasks.withType(JavaCompile) {
compileTask -> compileTask.dependsOn ndkBuild
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
androidTestImplementation ('com.Android.support.test.espresso:espresso-core:2.2.2', {
exclude group: 'com.Android.support', module: 'support-annotations'
})
implementation"org.jetbrains.kotlin:kotlin-stdlib-jre7:$kotlin_version"
implementation 'com.Android.support:appcompat-v7:26.0.0-beta2'
testImplementation 'junit:junit:4.12'
implementation 'com.Android.support.constraint:constraint-layout:1.0.2'
compile "org.jetbrains.anko:anko-appcompat-v7-commons:$anko_version"
}
Je suis sur la machine Windows. Est-ce que quelqu'un sait ce qui pourrait être le problème?
J'ai supprimé le code jniLibs.srcDir 'src/main/libs'
dans le bloc sourceSets.main. Il créait deux fois des fichiers * .so.
sourceSets.main {
jniLibs.srcDir 'src/main/libs'
jni.srcDirs = [] //disable automatic ndk-build call
}
J'ai constaté une erreur similaire lors de l'exécution de mon application après la migration vers Android Studio 3.0. Un build propre a résolu le problème.
Je souhaite simplement ajouter à la réponse Nonos que je pense avoir reçu ce problème après avoir exécuté ndk-build
dans mon répertoire app/jni
, puis ./gradlew installDebug
à partir du répertoire de niveau supérieur de mon projet Android NDK. Donc, faire un ndk-build clean
dans app/jni
avant de faire une autre construction de Gradle a effectivement résolu le problème.