Makefile revision c8012b9719c73f08418af7a0b4ba28fa1d200631
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# Author: (c) Klaus Luettich, Christian Maeder, Uni Bremen 2002-2009
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# This Makefile will compile the hets system and provides also
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# targets for test programs during implementation phases.
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# !!! Note: This makefile is written for GNU make !!!
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# (gmake on solaris)
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# the 'replacing spaces' example was taken from the (GNU) Make info manual
9c3531d72aeaad6c5f01efe6a1c82023e1379e4dDavid LawrenceDRIFT_ENV = DERIVEPATH=$(subst $(space),:,$(PFE_PATHS))
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsGENITCORRECTIONS_deps = utils/itcor/GenItCorrections.hs
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Common/Doc.hs CASL/ToDoc.hs Modal/AS_Modal.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Modal/Parse_AS.hs Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsGENRULECALL = $(GENRULES) -r Typeable -r ShATermConvertible \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsGENRULECALL2 = $(GENRULES) -r Typeable -r ShATermLG \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews -i Data.Typeable -i ATerm.Lib -i ATC.Grothendieck
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsSETUPPREFIX = --prefix=$(HOME)/.ghc/$(ARCH)-$(OSBYUNAME)-hets-packages
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence ../$(SETUP) configure -O -p $(SETUPPREFIX) --user; \
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence ../$(SETUP) build; ../$(SETUP) haddock; ../$(SETUP) install
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# list glade files
b60271016957475ef5d675f8a5a116a661b46b82David LawrenceGTK_GLADE_FILES = $(wildcard GUI/Glade/*.glade)
b60271016957475ef5d675f8a5a116a661b46b82David LawrenceGTK_GLADE_HSFILES = $(subst .glade,.hs,$(GTK_GLADE_FILES))
37d266d288410d1ead241c02a8a1dbcb0160be46Michael Graff# the list of logics that need ShATermConvertible instances
37d266d288410d1ead241c02a8a1dbcb0160be46Michael Grafflogics = CASL HasCASL Isabelle Modal Temporal CoCASL COL CspCASL CASL_DL \
37d266d288410d1ead241c02a8a1dbcb0160be46Michael Graff SoftFOL ConstraintCASL Propositional OWL RelationalScheme VSE OMDoc DFOL \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews LF Framework Maude ExtModal CommonLogic CSL QBF Adl HolLight Fpl THF
35c842e05dc6382ce1d9161a658d3ff4b2c3d4c9Bob HalleyTESTTARGETFILES += Scratch.hs CASL/fromKif.hs CASL/capa.hs HasCASL/hacapa.hs \
37d266d288410d1ead241c02a8a1dbcb0160be46Michael Graff Haskell/wrap.hs Isabelle/isa.hs Syntax/hetpa.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews ATC/ATCTest.hs ATC/ATCTest2.hs Common/ATerm/ATermLibTest.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Common/ATerm/ATermDiffMain.hs Common/annos.hs \
35c842e05dc6382ce1d9161a658d3ff4b2c3d4c9Bob Halley SoftFOL/tests/PrintTPTPTests.hs Comorphisms/test/showKP.hs \
200bf9036488042a01b42aeb79a75870af42e5bdMark Andrews Comorphisms/test/sublogicGraph.hs PGIP/ParseProofScript.hs \
37d266d288410d1ead241c02a8a1dbcb0160be46Michael Graff SoftFOL/dfg.hs Adl/adl.hs GUI/displayDependencyGraph.hs
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews### list of directories to run checks in
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsTESTDIRS += Common CASL Fpl/test HasCASL test HolLight
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrewshs_clean_files = Haskell/TiATC.hs Haskell/TiDecorateATC.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Haskell/TiPropATC.hs Haskell/ATC_Haskell.der.hs
b60271016957475ef5d675f8a5a116a661b46b82David LawrencePFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence base/parse2/LexerGen base/parse2/LexerSpec base/tests/HbcLibraries \
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence base/transforms base/transforms/Deriving property \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews property/syntax property/AST property/transforms \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews property/TI property/defs property/parse2 property/parse2/Parser
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrewspfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrewshappy_files += $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrewsprogramatica_pkg: $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs \
f2fdfe7c42f3b10f3653f851ce5a0a90ee5ac1f9David Lawrence @if $(HCPKG) field programatica version; then \
f2fdfe7c42f3b10f3653f851ce5a0a90ee5ac1f9David Lawrence echo "of programatica package found"; else \
f2fdfe7c42f3b10f3653f851ce5a0a90ee5ac1f9David Lawrence -i `pwd`/Haskell/Programatica.patch || exit 0); \
f2fdfe7c42f3b10f3653f851ce5a0a90ee5ac1f9David Lawrence cp -f utils/programatica.cabal $(PFE_TOOLDIR); \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews echo "{-# OPTIONS -w #-}" > $@
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(HC) --make -fno-monomorphism-restriction -O \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael GraffAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
37d266d288410d1ead241c02a8a1dbcb0160be46Michael Graff## rule for appendHaskellPreludeString
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsAst_Haskell_files = HsDeclStruct HsExpStruct HsFieldsStruct \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews#Ti_Haskell_files = TiTypes TiKinds TiDecorate TiInstanceDB
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews#Ti_Prop_files = property/TI/TiPropDecorate property/syntax/PropSyntaxRec
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsOther_PFE_files = property/AST/HsPropStruct base/defs/PNT \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews base/defs/UniqueNames base/Modules/TypedIds base/Modules/Ents \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews base/parse2/SourceNames base/syntax/SyntaxRec \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(addprefix $(PFE_TOOLDIR)/, $(Other_PFE_files)))
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews## rule for ATC generation
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsHaskell/ATC_Haskell.der.hs: $(Haskell_files) $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL) -i Haskell.BaseATC -o $@ $(Haskell_files)
6f2a61172f328246b27fa8811a7c7b6ddf693afcMark AndrewsTESTTARGETFILES += Haskell/hana.hs Haskell/h2h.hs Haskell/h2hf.hs
ca81c3971cd0c9cfd830c0a18289d4d1b0f9de01David Lawrence# unset this variable from var.mk because the programatica sources
ca81c3971cd0c9cfd830c0a18289d4d1b0f9de01David Lawrence# are needed to created our sources!
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# end of programatica stuff
ca81c3971cd0c9cfd830c0a18289d4d1b0f9de01David LawrenceNO_BIND_WARNING = -fno-warn-unused-do-bind -fno-warn-warnings-deprecations
35c842e05dc6382ce1d9161a658d3ff4b2c3d4c9Bob HalleyHC_WARN = -Wall -fno-warn-orphans $(NO_BIND_WARNING)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# uncomment HC_PROF for profiling (and comment out packages in var.mk)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# call resulting binary with a final +RTS -p to get a file <binary>.prof
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# HC_PROF = -prof -auto-all -osuf p_o +RTS -K100m -RTS
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsHC_OPTS += $(HC_WARN) $(HC_INCLUDE) $(HC_PROF) $(HC_DEBIAN_OPT)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# -ddump-minimal-imports
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# uncomment the above line to generate .imports files for displayDependencyGraph
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# files generated by DriFT
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Syntax/AS_Structured.hs Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews CspCASL/AS_CspCASL_Process.hs CspCASL/AS_CspCASL.hs \
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence# files to extract data types from to generate ShATermConvertible instances
b60271016957475ef5d675f8a5a116a661b46b82David Lawrenceatc_files = Common/AS_Annotation.der.hs Common/DefaultMorphism.hs \
b60271016957475ef5d675f8a5a116a661b46b82David Lawrence Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Common/Consistency.hs Common/ProofTree.hs Static/DevGraph.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Common/Id.hs Common/Result.hs Common/OrderedMap.hs \
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael Graff# files generated by genRules as input for DriFT
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael Graffatc_der_files = $(foreach file, $(atc_files), \
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael Graff ATC/$(basename $(basename $(notdir $(file)))).der.hs)
2193d51910ed8f37185f29d1ebbc7cdc85184f06Michael Graff# the rules to create ATC .der.hs file for DriFT
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael GraffATC/Result.der.hs: Common/Result.hs $(GENRULES)
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael GraffATC/OrderedMap.der.hs: Common/OrderedMap.hs $(GENRULES)
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael GraffATC/Graph.der.hs: Common/Lib/Graph.hs $(GENRULES)
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael GraffATC/ProofTree.der.hs: Common/ProofTree.hs $(GENRULES)
99dd8505ed03c6a6a6527cf6d2acebca270cce47Michael GraffATC/AS_Annotation.der.hs: Common/AS_Annotation.der.hs $(GENRULES)
aad37e39b3ac0388b1b9ea729bc9de263095c8afMichael Graff $(GENRULECALL) -i ATC.Id -i Common.ATerm.ConvInstances -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/Consistency.der.hs: Common/Consistency.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL) -x Common.Consistency.ConservativityChecker -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/LibName.der.hs: Common/LibName.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL) -i ATC.Id -i Common.ATerm.ConvInstances -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/ExtSign.der.hs: Common/ExtSign.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL) -i Common.ATerm.ConvInstances -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/DefaultMorphism.der.hs: Common/DefaultMorphism.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/AS_Structured.der.hs: Syntax/AS_Structured.der.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/AS_Architecture.der.hs: Syntax/AS_Architecture.der.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/AS_Library.der.hs: Syntax/AS_Library.der.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL2) -i ATC.AS_Architecture -i ATC.LibName -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/GlobalAnnotations.der.hs: Common/GlobalAnnotations.hs $(GENRULES)
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL) -i ATC.AS_Annotation -i ATC.Result -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews $(GENRULECALL) -x Logic.Prover.ProverTemplate \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews -i ATC.AS_Annotation -i ATC.OrderedMap -o $@ $<
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsATC/DevGraph.der.hs: Static/DevGraph.hs $(GENRULES)
35c842e05dc6382ce1d9161a658d3ff4b2c3d4c9Bob Halley $(GENRULECALL2) -i ATC.LibName -i ATC.Consistency \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews# ATC files for every logic
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsCASL_files = CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsHasCASL_files = Common/Prec.hs HasCASL/As.hs HasCASL/Le.hs HasCASL/Sublogic.hs
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsPropositional_files = Propositional/Sign.hs Propositional/Morphism.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark Andrews Propositional/AS_BASIC_Propositional.hs Propositional/Symbol.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsHolLight_files = HolLight/Sentence.hs HolLight/Sign.hs \
7d2b275f7e9238e2c709737601f6260b5a9a4ee1Mark AndrewsQBF_files = Propositional/Sign.hs QBF/Morphism.hs \
# all ATC .der.hs files for all logics
# a rule to create all .der.hs files
# files to be processed by utils/InlineAxioms
cgi:
(cd utils/GenerateRules; \
GenerateRules.hs -o ../genRules)
./clean.sh; \
# Common/LaTeX_maps.hs generation
@echo -n "Generating pretty/LaTeX_maps.hs ... "
@(cd pretty >/dev/null; ../utils/genItCorrections \
$(RM) $@
## two hardcoded dependencies for a correct generation of Version.hs
.SUFFIXES:
%.hs: %.y
$(RM) $@
$(RM) $@
$(INLINEAXIOMS) $< > $@
%.d : %.hs
%.d : %.lhs
$(RM) $@
$(RM) $@
$(PERL) $+ > $@
## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
# uses intransparently utils/outlineAxioms
$(RM) $@
@echo Please do