blob: 0fe37cc05674e86a86f75afe97ebf98fb06758e2 (
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
## Parameters ##################################################################
TO_PRED_TEMPLATE_DIR ?=
INFERRED_LEVEL_FILE ?=
PARSING_SCRIPT ?= ${CURDIR}/parser.py
PROPERTIES_DIR ?=
#### Where to find the properties to verify
ALL_PROPERTY_FILES ?= $(wildcard $(PROPERTIES_DIR)/*.pro)
## Parameters Sanity Check #####################################################
ifeq ($(strip $(PARSING_SCRIPT)),)
$(error No PARSING_SCRIPT defined as parameter.)
endif
################################################################################
## Makefile Magic ##############################################################
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
cat $< | sed 's/.*;;.*//g' | tr -d "\n\r" \
| sed -n 's/.*(tag_existing[ \t]\+([ \t]*\(\([ \t]*([^)]\+)\)\+\)[ \t]*.*)/\1/p' \
| sed 's/)/)\n/g' | sed 's/[ \t]\+/ /g' | tr -d "()" \
| $(PARSING_SCRIPT) \
$(patsubst %.pp,%,$(notdir $(basename $@))) \
$@ \
$(INFERRED_LEVEL_FILE)
$(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" >> $@
|