做cmcc分支,我们需要将heathd的唤醒间隔设置短一点,但是又在一个主分支上着就需要做宏。
具体我们可以编译的时候带参数:
make BUILD_MASS_PRODUCTION=false
后面参数的意思就是不是量产分支,这样我们就认为是cmcc分支。
一、局部修改
我们的第一反应可以在heathd的Android.mk中修改如下:
ifeq ($(strip $(BUILD_MASS_PRODUCTION)),false)
LOCAL_CFLAGS += -DCONFIG_IS_CMCC
endif
这样在heathd中,就定义了CONFIG_IS_CMCC这个宏了。
在healthd.cpp的修改如下:
#ifdef CONFIG_IS_CMCC
#define DEFAULT_PERIODIC_CHORES_INTERVAL_SLOW (60 * 10 * 6)
#else
#define DEFAULT_PERIODIC_CHORES_INTERVAL_SLOW (60 * 10)
#endif
二、全局修改
这样修改就可以了,但是cmcc分支的宏应该是全局的,而不是每修改一次就在修改的Android.mk中增加LOCAL_CFLAGS。
于是我们可以在common下的device.mk中修改如下:
ifeq ($(BUILD_MASS_PRODUCTION),true)
MASS_PRODUCTION := true
else
MASS_PRODUCTION := false
GLOBAL_FEATURE_CFLAGS += -DCONFIG_IS_CMCC
endif
加入GLOBAL_FEATURE_CFLAGS的话就是全局的CFLAGS了,也就是在所有的c代码中都可以使用CONFIG_IS_CMCC这个宏了。
而java中要做宏的话怎么办,
PRODUCT_PROPERTY_OVERRIDES += \
ro.build.mass.production=$(MASS_PRODUCTION)
java的话我们通过属性了。
三、注意
但是有一点需要注意上面在common下的device.mk中为GLOBAL_FEATURE_CFLAGS加flag,要注意后面的mk文件会不会把GLOBAL_FEATURE_CFLAGS 这个变量清除,如果清除我们要在清除那个mk文件后面加这个操作。
还有一点,java的属性是否生效可以用getprop命令查看,一般需要make clean后,在make才生效。GLOBAL_FEATURE_CFLAGS 的话是一个编译项,只要编译就生效。