考虑以下makefile:
SHELL = /bin/sh
MY_DIR := $(realpath ./)
BASE_DIR := $(realpath ../..)
BASE_SRC_DIR = $(BASE_DIR)/src
BASE_INC_DIR = $(BASE_DIR)/include
HUL_DIR = $(MY_DIR)/hul
JNI_DIR = $(HUL_DIR)/jni
JNI_SRC_DIR = $(JNI_DIR)/src
JNI_INC_DIR = $(JNI_DIR)/include
dirs: $(JNI_SRC_DIR) $(JNI_INC_DIR)
$(JNI_SRC_DIR): $(JNI_DIR)
ln -s $(BASE_SRC_DIR) $@
$(JNI_INC_DIR): $(JNI_DIR)
ln -s $(BASE_INC_DIR) $@
$(JNI_DIR):
mkdir -p $(JNI_DIR)
此makefile创建两个符号链接(JNI_SRC_DIR
和JNI_INC_DIR
)并将JNI_DIR
设置为这些链接的依赖关系。一切都很好,除了一件事:调用make dirs
两次创建链接然后链接这些文件夹。我知道这是符号链接已经存在的文件夹的标准ln
行为,我只是不知道任何ln
选项标志,以防止它没有错误(-n
做到但是一个错误)。无论如何,我想改变的是make
第二次运行规则。显然它也遵循符号链接,但我只想检查它们是否在那里:
这是一个示例输出,有三个调用:
$ make dirs
mkdir -p /Users/fratelli/Documents/hul/platform/android/hul/jni
ln -s /Users/fratelli/Documents/hul/src /Users/fratelli/Documents/hul/platform/android/hul/jni/src
ln -s /Users/fratelli/Documents/hul/include /Users/fratelli/Documents/hul/platform/android/hul/jni/include
$ make dirs
ln -s /Users/fratelli/Documents/hul/src /Users/fratelli/Documents/hul/platform/android/hul/jni/src
ln -s /Users/fratelli/Documents/hul/include /Users/fratelli/Documents/hul/platform/android/hul/jni/include
$ make dirs
make: Nothing to be done for `dirs'.
我希望第二次表现为第三次,因为符号链接已经存在。
答案 0 :(得分:2)
正在发生的是,当第一个make dirs
调用创建符号链接时,目录的修改时间会更新。由于您对目录有依赖性,这意味着下次运行make dirs
时,make
会判定目标已过期。
您可以将$(JNI_DIR)
的依赖关系更改为order-only prerequisite,如下所示:
$(JNI_SRC_DIR): | $(JNI_DIR)
ln -s $(BASE_SRC_DIR) $@
$(JNI_INC_DIR): | $(JNI_DIR)
ln -s $(BASE_INC_DIR) $@
如果make
不存在,则告诉$(JNI_DIR)
创建table.ix[:,0]
,但如果目录已更新,则不会重新创建链接。