diff options
author | Son Ho | 2023-12-22 18:47:50 +0100 |
---|---|---|
committer | Son Ho | 2023-12-22 18:47:50 +0100 |
commit | 455ba366f9c8d07a1f1848ec0960b1f2d161e7cf (patch) | |
tree | 03493e0e2eddef8187296befceeda40eba102c4c /backends/fstar/merge/Makefile | |
parent | e799ef503dda30b6dcbecb042ecb0fae1a71fa81 (diff) |
Update the library for F*
Diffstat (limited to 'backends/fstar/merge/Makefile')
-rw-r--r-- | backends/fstar/merge/Makefile | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/backends/fstar/merge/Makefile b/backends/fstar/merge/Makefile new file mode 100644 index 00000000..a16b0edb --- /dev/null +++ b/backends/fstar/merge/Makefile @@ -0,0 +1,47 @@ +INCLUDE_DIRS = . + +FSTAR_INCLUDES = $(addprefix --include ,$(INCLUDE_DIRS)) + +FSTAR_HINTS ?= --use_hints --use_hint_hashes --record_hints + +FSTAR_OPTIONS = $(FSTAR_HINTS) \ + --cache_checked_modules $(FSTAR_INCLUDES) --cmi \ + --warn_error '+241@247+285-274' \ + +FSTAR_NO_FLAGS = fstar.exe --already_cached 'Prims FStar LowStar Steel' --odir obj --cache_dir obj + +FSTAR = $(FSTAR_NO_FLAGS) $(FSTAR_OPTIONS) + +# The F* roots are used to compute the dependency graph, and generate the .depend file +FSTAR_ROOTS ?= $(wildcard *.fst *.fsti) + +# Build all the files +all: $(addprefix obj/,$(addsuffix .checked,$(FSTAR_ROOTS))) + +# This is the right way to ensure the .depend file always gets re-built. +ifeq (,$(filter %-in,$(MAKECMDGOALS))) +ifndef NODEPEND +ifndef MAKE_RESTARTS +.depend: .FORCE + $(FSTAR_NO_FLAGS) --dep full $(notdir $(FSTAR_ROOTS)) > $@ + +.PHONY: .FORCE +.FORCE: +endif +endif + +include .depend +endif + +# For the interactive mode +%.fst-in %.fsti-in: + @echo $(FSTAR_OPTIONS) + +# Generete the .checked files in batch mode +%.checked: + $(FSTAR) $(FSTAR_OPTIONS) $< && \ + touch -c $@ + +.PHONY: clean +clean: + rm -f obj/* |