rules revision c9e197862d9d8ef2585270dd08f5194b3aed4a9d
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# This Makefile will compile the new hets system and provides also
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# targets for test programs during implementation phases.
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# !!! Note: This makefile is written for GNU make !!!
e7b7e6e7468bd5a96d2172699776f4349835f2ceBob Halley# (gmake on solaris)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley####################################################################
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley## Some varibles, which control the compilation
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyINCLUDE_PATH = ghc fgl hxt
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyCOMMONLIB_PATH = Common/Lib Common/ATerm fgl/Data/Graph \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley fgl/Data/Graph/Inductive fgl/Data/Graph/Inductive/Internal \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley fgl/Data/Graph/Inductive/Monad fgl/Data/Graph/Inductive/Query
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyCLEAN_PATH = . utils/DrIFT-src utils/GenerateRules utils/InlineAxioms Common \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Logic CASL CASL/CCC Syntax Static GUI HasCASL Haskell Modal CoCASL COL \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley CspCASL ATC ToHaskell Proofs Comorphisms Isabelle Driver $(INCLUDE_PATH) \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Haskell/Hatchet Hatchet Taxonomy $(PFE_PATHS)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley## set ghc imports properly for your system
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyGHC_IMPORTS =`$(HC) --print-libdir`/imports
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyDRIFT_ENV = \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley DERIVEPATH=.:ghc:$(GHC_IMPORTS):$(subst $(space),:,$(PFE_PATHS))
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# the 'replacing spaces' example was taken from the (GNU) Make info manual
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyspace:= $(empty) $(empty)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# override on commandline for other architectures
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyINSTALLDIR = \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyDRIFT_deps = utils/DrIFT-src/*hs
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps) Common/Utils.hs
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs Common/ListUtils.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Common/Lib/Pretty.hs Common/Keywords.hs Common/Lib/Set.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Common/Lib/Map.hs Common/Lib/Rel.hs Common/Lib/State.hs Common/Id.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs CASL/ShowMixfix.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley CASL/Utils.hs Common/Lexer.hs Common/Token.hs Common/Anno_Parser.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Common/GlobalAnnotations.hs Common/PrettyPrint.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Common/Print_AS_Annotation.hs Common/PPUtils.hs CASL/LiteralFuns.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley CASL/Print_AS_Basic.hs Common/AnnoState.hs CASL/Formula.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley CASL/OpItem.hs CASL/SortItem.hs Common/Result.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Common/ConvertLiteral.hs Common/Earley.hs CASL/MixfixParser.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley CASL/Parse_AS_Basic.hs CASL/Sign.hs CASL/Overload.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley CASL/StaticAna.hs Modal/AS_Modal.hs Modal/Parse_AS.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyHAPPY = happy -sgca
d6da3b9e10b2ac6de4426f944659a362157effdaBob HalleyHADDOCK = haddock
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyHC_WARN = -Wall
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyHC_FLAGS = $(HC_WARN) -fglasgow-exts -fno-monomorphism-restriction \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley -fallow-overlapping-instances -fallow-undecidable-instances
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# -ddump-minimal-imports
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# flags also come in via ../uni/uni-package.conf
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# but added it here in case of compilation without uni
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyHC_INCLUDE = $(addprefix -i, $(INCLUDE_PATH))
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleylogics = CASL HasCASL Modal CoCASL COL CspCASL Hatchet
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyUNI_PACKAGE_CONF := $(wildcard ../uni/uni-package.conf)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyifneq ($(strip $(UNI_PACKAGE_CONF)),)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley -package uni-server -DUNI_PACKAGE
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# some modules from uni for haddock
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley# if uni/server is included also HaXml sources are needed
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyuni_dirs = ../uni/davinci ../uni/graphs ../uni/events \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyuni_sources = $(wildcard $(addsuffix /haddock/*.hs, $(uni_dirs))) \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley $(wildcard ../uni/htk/haddock/*/*.hs)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyPFE_TOOLDIR := $(wildcard ../programatica/tools)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyifneq ($(strip $(PFE_TOOLDIR)),)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley base/transforms base/transforms/Deriving property \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley property/syntax property/AST property/transforms \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley property/TI property/defs property/parse2 property/parse2/Parser
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleypfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyPFE_PATH = $(addprefix -i, $(PFE_PATHS))
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyhappy_files = $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyLEX_DIR := $(PFE_TOOLDIR)/base/parse2/Lexer
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley $(HC) --make -O -package data \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley -i$(PFE_TOOLDIR)/base/tests/HbcLibraries \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley -i$(PFE_TOOLDIR)/base/lib \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleylogics += Haskell
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halleyderived_sources += Haskell/PreludeString.hs
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley## rule for appendHaskellPreludeString
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley $(APPENDPRELUDESTRING)
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley $(APPENDPRELUDESTRING) < $< > $@
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyAst_Haskell_files := HsDeclStruct HsExpStruct HsFieldsStruct \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob Halley HsModule HsName HsLiteral HsIdent
138d22b316c7cd10eaa9df2ee0e3ec712a077153Bob HalleyOther_PFE_files := property/AST/HsPropStruct base/defs/PNT \
$(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
happy_files += Haskell/Hatchet/HsParser.hs
TESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell
#include sources_hetcats.mk
sources = hets.hs $(filter-out $(non_sources), \
genrule_header_files = $(wildcard ATC/*.header.hs)
ATC/$(basename $(basename $(notdir $(file)))).der.hs)
Hatchet_files := Haskell/Hatchet/AnnotatedHsSyn.hs \
atc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
gendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
gen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
derived_sources += $(drifted_files) Driver/Version.hs $(happy_files) \
$(inline_axiom_files) Modal/ModalSystems.hs
nondoc_sources = $(wildcard utils/DrIFT-src/*.hs) \
$(wildcard utils/DrIFT-src/*.lhs) \
$(wildcard utils/GenerateRules/*.hs) \
$(wildcard utils/InlineAxioms/*.hs) \
$(patsubst %.hs,%.der.hs,$(drifted_files))
#.PRECIOUS: sources_hetcats.mk
$(call run_hc, $(HC) --make -o $@ hets.hs $(HC_OPTS))
$(call run_hc, $(HC) --make -O -o hets hets.hs $(HC_OPTS))
ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
strip hets.cgi
taxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
$(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
hetcats.TAGS: $(sources)
$(sources); mv TAGS $@; mv tags hetcats.tags
doc: docs/index.html
docs/index.html: $(doc_sources)
$(MAKE) hets.cgi
$(PERL) utils/post_process_docs.pl docs \
utils/DrIFT: $(DRIFT_deps)
utils/genRules: $(GENERATERULES_deps)
(cd utils/GenerateRules; \
GenerateRules.hs -o ../genRules && strip ../genRules)
$(HC) --make utils/InlineAxioms/InlineAxioms.hs $(HC_WARN) \
$(MAKE) clean; ./clean.sh; \
$(RM) clean.*; mv Makefile Makefile.orig; \
tar cvf HetCATS.tar HetCATS
cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
utils/genRules -r $(rule) -o CASL $(CASL_files)
utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
utils/genRules -r $(rule) -o Modal $(Modal_files)
utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
utils/genRules -r $(rule) -o COL $(COL_files)
utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; \
then utils/genRules -r $(rule) -o ATC -h \
ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
else utils/genRules -r $(rule) -o ATC $(file); fi ;
$(RM) CASL/capa
$(RM) HasCASL/hacapa
$(RM) Haskell/hapa
$(RM) Haskell/hana
$(RM) Haskell/wrap
$(RM) ToHaskell/h2h
$(RM) Syntax/hetpa
$(RM) Static/hetana
$(RM) GUI/hetdg
$(RM) Common/annos
$(RM) Haskell/Hatchet/hatch
$(RM) ToHaskell/translateAna
$(RM) Taxonomy/taxonomyTool
### also delete *.d.bak (dependency file backups)
(cd $$p ; $(RM) *.d *.d.bak) ; done
$(RM) hetcats-make sources_hetcats.mk
test_parser: Common/test_parser
capa: CASL/capa
hacapa: HasCASL/hacapa
hana: Haskell/hana
h2h: ToHaskell/h2h
hetpa: Syntax/hetpa.hs Syntax/*.hs
hetana: Static/hetana.hs Static/*.hs
atctest: ATC/ATCTest.hs ATC/*.hs
### ATerm.Lib test system
hetdg: GUI/hetdg.hs $(drifted_files) *.hs
## two hardcoded dependencies for a correct generation of Version.hs
%.hs: %.inline.hs $(INLINEAXIOMS)
## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
utils/genTransMFormFunc.pl $(INLINEAXIOMS)
$(PERL) utils/genTransMFormFunc.pl $< $@