Makefile revision 7a3fe82695aa32657693e05712f84d7f81672f2e
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# Author: (c) Klaus Luettich, Christian Maeder, Uni Bremen 2002-2009
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# This Makefile will compile the hets system and provides also
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# targets for test programs during implementation phases.
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# !!! Note: This makefile is written for GNU make !!!
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# (gmake on solaris)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# the 'replacing spaces' example was taken from the (GNU) Make info manual
355b4669e025ff377602b6fc7caaf30dbc218371jacobsDRIFT_ENV = DERIVEPATH=$(subst $(space),:,$(PFE_PATHS))
355b4669e025ff377602b6fc7caaf30dbc218371jacobsGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsGENITCORRECTIONS_deps = utils/itcor/GenItCorrections.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Modal/Parse_AS.hs Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsGENRULECALL = $(GENRULES) -r Typeable -r ShATermConvertible \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsSETUPPREFIX = --prefix=$(HOME)/.ghc/$(ARCH)-$(OSBYUNAME)-hets-packages
355b4669e025ff377602b6fc7caaf30dbc218371jacobs ../$(SETUP) build; ../$(SETUP) haddock; ../$(SETUP) install --user
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# list glade files
355b4669e025ff377602b6fc7caaf30dbc218371jacobsGTK_GLADE_HSFILES = $(subst .glade,.hs,$(GTK_GLADE_FILES))
b0e753dd6a955fb2f10a0ce17d32bd33172e0400Gordon Ross# the list of logics that need ShATermConvertible instances
b0e753dd6a955fb2f10a0ce17d32bd33172e0400Gordon Rosslogics = CASL HasCASL Isabelle Modal Temporal CoCASL COL CspCASL CASL_DL \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs SoftFOL ConstraintCASL Propositional OWL RelationalScheme VSE OMDoc DFOL \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsTESTTARGETFILES += CASL/fromKif.hs CASL/capa.hs HasCASL/hacapa.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs ATC/ATCTest.hs ATC/ATCTest2.hs Common/ATerm/ATermLibTest.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs SoftFOL/tests/PrintTPTPTests.hs Comorphisms/test/showKP.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Comorphisms/test/sublogicGraph.hs PGIP/ParseProofScript.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs### list of directories to run checks in
355b4669e025ff377602b6fc7caaf30dbc218371jacobshs_clean_files = Haskell/TiATC.hs Haskell/TiDecorateATC.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs base/parse2/LexerGen base/parse2/LexerSpec base/tests/HbcLibraries \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs property/TI property/defs property/parse2 property/parse2/Parser
355b4669e025ff377602b6fc7caaf30dbc218371jacobspfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
355b4669e025ff377602b6fc7caaf30dbc218371jacobshappy_files += $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsprogramatica_pkg: $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs echo "of programatica package found"; else \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs cp -f utils/programatica.cabal ../programatica/tools; \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs echo "{-# OPTIONS -w #-}" > $@
355b4669e025ff377602b6fc7caaf30dbc218371jacobs$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs## rule for appendHaskellPreludeString
355b4669e025ff377602b6fc7caaf30dbc218371jacobsHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsAst_Haskell_files = HsDeclStruct HsExpStruct HsFieldsStruct \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs#Ti_Haskell_files = TiTypes TiKinds TiDecorate TiInstanceDB
355b4669e025ff377602b6fc7caaf30dbc218371jacobs#Ti_Prop_files = property/TI/TiPropDecorate property/syntax/PropSyntaxRec
355b4669e025ff377602b6fc7caaf30dbc218371jacobsOther_PFE_files = property/AST/HsPropStruct base/defs/PNT \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs base/defs/UniqueNames base/Modules/TypedIds base/Modules/Ents \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs## rule for ATC generation
355b4669e025ff377602b6fc7caaf30dbc218371jacobsHaskell/ATC_Haskell.der.hs: $(Haskell_files) $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i Haskell.BaseATC -o $@ $(Haskell_files)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsTESTTARGETFILES += Haskell/hana.hs Haskell/h2h.hs Haskell/h2hf.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# unset this variable from var.mk because the programatica sources
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# are needed to created our sources!
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# end of programatica stuff
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# uncomment HC_PROF for profiling (and comment out packages in var.mk)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# call resulting binary with a final +RTS -p to get a file <binary>.prof
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# HC_PROF = -prof -auto-all -osuf p_o +RTS -K100m -RTS
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# -ddump-minimal-imports
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# uncomment the above line to generate .imports files for displayDependencyGraph
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# files generated by DriFT
b0e753dd6a955fb2f10a0ce17d32bd33172e0400Gordon Ross Syntax/AS_Structured.hs Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs CspCASL/AS_CspCASL_Process.hs CspCASL/AS_CspCASL.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# files to extract data types from to generate ShATermConvertible instances
355b4669e025ff377602b6fc7caaf30dbc218371jacobsatc_files = Common/AS_Annotation.der.hs Common/DefaultMorphism.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Logic/Prover.hs Common/LibName.hs Common/ExtSign.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Common/Consistency.hs Common/ProofTree.hs Static/DevGraph.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# files generated by genRules as input for DriFT
355b4669e025ff377602b6fc7caaf30dbc218371jacobs ATC/$(basename $(basename $(notdir $(file)))).der.hs)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# the rules to create ATC .der.hs file for DriFT
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/OrderedMap.der.hs: Common/OrderedMap.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/AS_Annotation.der.hs: Common/AS_Annotation.der.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.Id -i Common.ATerm.ConvInstances -o $@ $<
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/Consistency.der.hs: Common/Consistency.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -x Common.Consistency.ConservativityChecker -o $@ $<
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.Id -i Common.ATerm.ConvInstances -o $@ $<
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i Common.ATerm.ConvInstances -o $@ $<
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/DefaultMorphism.der.hs: Common/DefaultMorphism.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/AS_Structured.der.hs: Syntax/AS_Structured.der.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/AS_Architecture.der.hs: Syntax/AS_Architecture.der.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/AS_Library.der.hs: Syntax/AS_Library.der.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL2) -i ATC.AS_Architecture -i ATC.LibName -o $@ $<
355b4669e025ff377602b6fc7caaf30dbc218371jacobsATC/GlobalAnnotations.der.hs: Common/GlobalAnnotations.hs $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.AS_Annotation -i ATC.Result -o $@ $<
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# ATC files for every logic
355b4669e025ff377602b6fc7caaf30dbc218371jacobsCASL_files = CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsHasCASL_files = Common/Prec.hs HasCASL/As.hs HasCASL/Le.hs HasCASL/Sublogic.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsPropositional_files = Propositional/Sign.hs Propositional/Morphism.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobs Propositional/AS_BASIC_Propositional.hs Propositional/Symbol.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsRS_files = RelationalScheme/AS.hs RelationalScheme/Sign.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsTemporal_files = Temporal/AS_BASIC_Temporal.hs Temporal/Sign.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsConstraintCASL_files = ConstraintCASL/AS_ConstraintCASL.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsCoCASL_files = CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsCspCASL_files = CspCASL/AS_CspCASL.hs CspCASL/AS_CspCASL_Process.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsCASL_DL_files = CASL_DL/AS_CASL_DL.hs CASL_DL/Sign.hs CASL_DL/Sublogics.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsOWL_files = OWL/Sign.hs OWL/Sublogic.hs OWL/Morphism.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsDFOL_files = DFOL/AS_DFOL.hs DFOL/Sign.hs DFOL/Morphism.hs DFOL/Symbol.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsMaude_files = Maude/Sign.hs Maude/Morphism.hs Maude/Sentence.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsExtModal_files = ExtModal/AS_ExtModal.hs ExtModal/ExtModalSign.hs \
355b4669e025ff377602b6fc7caaf30dbc218371jacobsReduce_files = Reduce/Sign.hs Reduce/Morphism.hs Reduce/AS_BASIC_Reduce.hs Reduce/Symbol.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobsCommonLogic_files = CommonLogic/AS_CommonLogic.hs CommonLogic/Sign.hs CommonLogic/Symbol.hs
355b4669e025ff377602b6fc7caaf30dbc218371jacobs# ATC DrIFT-rule generation for logics
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.GlobalAnnotations -o $@ $(CASL_files)
b0e753dd6a955fb2f10a0ce17d32bd33172e0400Gordon RossRelationalScheme/ATC_RelationalScheme.der.hs: $(RS_files) $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.GlobalAnnotations -o $@ $(RS_files)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsPropositional/ATC_Propositional.der.hs: $(Propositional_files) $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.AS_Annotation -o $@ $(Propositional_files)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.AS_Annotation -o $@ $(QBF_files)
355b4669e025ff377602b6fc7caaf30dbc218371jacobsHasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) $(GENRULES)
355b4669e025ff377602b6fc7caaf30dbc218371jacobs $(GENRULECALL) -i ATC.GlobalAnnotations -o $@ $(HasCASL_files)
# 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)
-i../.. -o $(INLINEAXIOMS)
if [ -d ../programatica ] ; then \
./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