blob: c5d2df4dfcb273bfcfb4b53d3781dc50df0ca18b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
## Parameters ##################################################################
TO_PRED_TEMPLATE_DIR ?=
INFERRED_LEVEL_FILE ?=
PROPERTIES_DIR ?=
#### Where to find the properties to verify
ALL_PROPERTY_FILES ?= $(wildcard $(PROPERTIES_DIR)/*.pro)
################################################################################
PRED_TO_INFER = \
$(addsuffix .pp,$(addprefix $(TO_PRED_TEMPLATE_DIR)/,$(notdir $(basename $(ALL_PROPERTY_FILES)))))
ADDITIONAL_MAKEFILES = \
$(addsuffix .deps,$(addprefix $(DEPENDENCIES_DIR)/,$(basename $(notdir $(ALL_PROPERTY_FILES)))))
export
## Makefile Rules ##############################################################
compile: $(PRED_TO_INFER) $(ADDITIONAL_MAKEFILES)
model:
solutions:
clean:
rm -f $(TO_PRED_TEMPLATE_DIR)/*
rm -f $(INFERRED_LEVEL_FILE)
clean_model:
clean_solutions:
rm -f $(TO_PRED_TEMPLATE_DIR)/*
rm -f $(INFERRED_LEVEL_FILE)
########
$(TO_PRED_TEMPLATE_DIR)/%.pp: $(PROPERTIES_DIR)/%.pro
touch $@
$(MAKE) $(DEPENDENCIES_DIR)/$(patsubst %.pp,%,$(notdir $(basename $@))).deps
$(DEPENDENCIES_DIR)/%.deps: $(PROPERTIES_DIR)/%.pro
printf "$(SOL_DIR)/$(notdir $(basename $@)).sol.ready: " > $@
for dep in `sed -n 's/^#require \"\(.*\)\"$$/\1/p' $<` ; do \
printf "$(SOL_DIR)/$$dep.sol " >> $@ ; \
done
printf "\n\t touch $(SOL_DIR)/$(notdir $(basename $@)).sol.ready\n\n" >> $@
|