今天阳历生日,明天光棍节。继续光着吧。
前几天,编译Android程序时,出现了类似下面的一个错误。
build/core/base_rules.mk:74: *** Module name: xxxtest
build/core/base_rules.mk:75: *** Makefile location: packages/xxx/xxxtest
build/core/base_rules.mk:76: *
build/core/base_rules.mk:77: * Each module must use a LOCAL_MODULE_TAGS in its
build/core/base_rules.mk:78: * Android.mk. Possible tags declared by a module:
build/core/base_rules.mk:79: *
build/core/base_rules.mk:80: * optional, debug, eng, tests, samples
build/core/base_rules.mk:81: *
build/core/base_rules.mk:82: * If the module is expected to be in all builds
build/core/base_rules.mk:83: * of a product, then it should use the
build/core/base_rules.mk:84: * "optional" tag:
build/core/base_rules.mk:85: *
build/core/base_rules.mk:86: * Add "LOCAL_MODULE_TAGS := optional" in the
build/core/base_rules.mk:87: * Android.mk for the affected module, and add
build/core/base_rules.mk:88: * the LOCAL_MODULE value for that component
build/core/base_rules.mk:89: * into the PRODUCT_PACKAGES section of product
build/core/base_rules.mk:90: * makefile(s) where it's necessary, if
build/core/base_rules.mk:91: * appropriate.
build/core/base_rules.mk:92: *
build/core/base_rules.mk:93: * If the component should be in EVERY build of ALL
build/core/base_rules.mk:94: * products, then add its LOCAL_MODULE value to the
build/core/base_rules.mk:95: * PRODUCT_PACKAGES section of
build/core/base_rules.mk:96: * build/target/product/core.mk
build/core/base_rules.mk:97: *
build/core/base_rules.mk:98: *** user tag detected on new module - user tags are only supported on legacy modules. Stop.
看这段解释,也上网搜答案,都说要把写上LOCAL_MODULE_TAGS := optional这么一行。但是明明我写了啊?看来不是这个问题。
后来才发现,原来是我Android.mk里,变量赋值的顺序的问题。
本来在LOCAL_MODULE := xxxtest和include $(BUILD_EXECUTABLE)之间,我还给了好几个变量赋了值,有一个还是前面赋了一段,在这两者之间又赋了一段。我试着将LOCAL_MODULE := test_exe和include $(BUILD_EXECUTABLE)放到最后。问题突然就解决了。
因为太忙,也没去看看到底是什么问题。就去忙别的了。
如果谁遇到这问题,看是不是这个问题,咱们再探讨。