解决android libcore局部编译时`out/target/common/obj/JAVA_LIBRARIES/sqlite-jdbc_intermediates/javalib.jar'

本文介绍了一种解决Android项目中特定编译错误的方法,通过修改libcore下的Android.mk文件,避免了不必要的测试编译,实现了精准定位并修复问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在最近的工作中,对libcore/下的文件进行了修改,编译时遇到了如下错误:


make: *** No rule to make target `out/target/common/obj/JAVA_LIBRARIES/sqlite-jdbc_intermediates/javalib.jar', 
needed by `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/classes-full-debug.jar'.  Stop.


以往的解决方案很暴力,都是直接将整个源码进行一次重新编译,也可以通过,不过这种做法很没有工程师精神,

于是将libcore下的Android.mk文件进行了梳理,发现与JAVA_LIBRARIES以及sqlite同时相关的编译语句是用于测试的,

现在并不需要测试,其中一部分语句如下:

ifeq ($(LIBCORE_SKIP_TESTS),)
# Make the core-tests library.
include $(CLEAR_VARS)
LOCAL_SRC_FILES := $(test_src_files)
LOCAL_JAVA_RESOURCE_DIRS := $(test_resource_dirs)
LOCAL_NO_STANDARD_LIBRARIES := true
LOCAL_JAVA_LIBRARIES := core-libart okhttp core-junit bouncycastle
LOCAL_STATIC_JAVA_LIBRARIES := core-tests-support sqlite-jdbc mockwebserver nist-pkix-tests
LOCAL_JAVACFLAGS := $(local_javac_flags)
LOCAL_MODULE := core-tests
LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/JavaLibrary.mk
include $(BUILD_STATIC_JAVA_LIBRARY)
endif


于是在libcore\JavaLibraby.mk文件的开头加入了一句export LIBCORE_SKIP_TESTS := false


加入位置摘抄:

 The Java files and their associated resources.
common_core_src_files := $(call all-main-java-files-under,dalvik dex dom json luni xml)
core_resource_dirs := $(call all-core-resource-dirs,main)
test_resource_dirs := $(call all-core-resource-dirs,test)
test_src_files := $(call all-test-java-files-under,dalvik dom harmony-tests json luni xml)


# ///*** 修改在这里
export LIBCORE_SKIP_TESTS := false
# ///*** 修改完毕


ifeq ($(EMMA_INSTRUMENT),true)
ifneq ($(EMMA_INSTRUMENT_STATIC),true)


再次mmm libcore,编译成功!




### 构建路径解析 对于`classes-header.jar`的构建路径,在Android源码编译体系中,该文件通常位于特定目录下以供后续链接和其他模块使用。具体来说: - `classes-header.jar`作为Java库的一部分,其生成位置遵循预定义结构:`out/target/common/obj/JAVA_LIBRARIES/<module_name>_intermediates/classes-header.jar`[^1]。 在`Android.mk`文件配置方面,为了确保正确生成此类中间件并将其纳入整体构建流程之中,需适当设置变量来指明模块属性及其标签等信息。例如通过指定`LOCAL_MODULE_TAGS := optional`以及包含多预构建指令`include $(BUILD_MULTI_PREBUILT)`可以影响到最终产物如何被打包处理[^2]。 当涉及到具体的框架级组件时,假设目标是Framework,则对应的Makefile片段可能如下所示: ```makefile # 定义本地模块名称为framework LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := framework LOCAL_SRC_FILES := $(call all-java-files-under, src) LOCAL_JAR_EXCLUDE_FILES := none LOCAL_MODULE_CLASS := JAVA_LIBRARIES LOCAL_MODULE_SUFFIX := .jar LOCAL_MODULE_TAGS := optional include $(BUILD_STATIC_JAVA_LIBRARY) # 配置输出至预期路径下的classes-header.jar $(eval $(call create-intermediates-dir,$(TARGET_OUT_COMMON_INTERMEDIATES)/JAVA_LIBRARIES/framework_intermediates)) ``` 上述脚本会促使编译系统按照既定规则创建必要的中间文件夹,并将编译后的类打包成`classes-header.jar`存放在相应位置以便于其他依赖项能够顺利找到它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值