rules revision 43bb71dfe7ec405f563864d57c1cacdaa8ce9a80
91934be261c16d036521379306a74b0991720e67joncruz# Makefile
91934be261c16d036521379306a74b0991720e67joncruz# $Header$
91934be261c16d036521379306a74b0991720e67joncruz# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2005
91934be261c16d036521379306a74b0991720e67joncruz# Year: 2004
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruz# This Makefile will compile the new hets system and provides also
91934be261c16d036521379306a74b0991720e67joncruz# targets for test programs during implementation phases.
f727367dddbf050f0a7d33757e9290f571cbd492kiirala
9dc68827cbd515262ecb8d5ae8547d9e82c72e00Jon A. Cruz# !!! Note: This makefile is written for GNU make !!!
91934be261c16d036521379306a74b0991720e67joncruz# (gmake on solaris)
f727367dddbf050f0a7d33757e9290f571cbd492kiirala
91934be261c16d036521379306a74b0991720e67joncruzall: hets
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruz####################################################################
91934be261c16d036521379306a74b0991720e67joncruz## Some varibles, which control the compilation
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzINCLUDE_PATH = ghc fgl hxt
91934be261c16d036521379306a74b0991720e67joncruzCOMMONLIB_PATH = Common/Lib Common/ATerm fgl/Data/Graph \
91934be261c16d036521379306a74b0991720e67joncruz fgl/Data/Graph/Inductive fgl/Data/Graph/Inductive/Internal \
38fb914eb3aced01da1c1ca278e5da766d340c21keescook fgl/Data/Graph/Inductive/Monad fgl/Data/Graph/Inductive/Query
38fb914eb3aced01da1c1ca278e5da766d340c21keescookCLEAN_PATH = . utils/DrIFT-src utils/GenerateRules utils/InlineAxioms Common \
91934be261c16d036521379306a74b0991720e67joncruz Logic CASL CASL/CCC Syntax Static GUI HasCASL Haskell Modal CoCASL COL \
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free CspCASL ATC ToHaskell Proofs Comorphisms Isabelle Driver $(INCLUDE_PATH) \
91934be261c16d036521379306a74b0991720e67joncruz Haskell/Hatchet Hatchet Taxonomy $(PFE_PATHS)
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruz# the 'replacing spaces' example was taken from the (GNU) Make info manual
f727367dddbf050f0a7d33757e9290f571cbd492kiiralaempty =
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaspace = $(empty) $(empty)
91934be261c16d036521379306a74b0991720e67joncruz
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel## set ghc imports properly for your system
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus EngelGHC_IMPORTS = `$(HC) --print-libdir`/imports
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus EngelDRIFT_ENV = \
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel DERIVEPATH=.:ghc:$(GHC_IMPORTS):$(subst $(space),:,$(PFE_PATHS))
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel# override on commandline for other architectures
35087bff7509c736a32e0b74fd9ff0834bde7b6bMarkus EngelINSTALLDIR = \
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeDRIFT_deps = utils/DrIFT-src/*hs
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps) Common/Utils.hs
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs Common/ListUtils.hs \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free Common/Lib/Pretty.hs Common/Keywords.hs Common/Lib/Set.hs \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free Common/Lib/Map.hs Common/Lib/Rel.hs Common/Lib/State.hs Common/Id.hs \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs CASL/ShowMixfix.hs \
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel CASL/Utils.hs Common/Lexer.hs Common/Token.hs Common/Anno_Parser.hs \
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel Common/GlobalAnnotations.hs Common/PrettyPrint.hs \
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel Common/Print_AS_Annotation.hs Common/PPUtils.hs CASL/LiteralFuns.hs \
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel CASL/Print_AS_Basic.hs Common/AnnoState.hs CASL/Formula.hs \
91934be261c16d036521379306a74b0991720e67joncruz CASL/OpItem.hs CASL/SortItem.hs CASL/Inject.hs Common/Result.hs \
91934be261c16d036521379306a74b0991720e67joncruz Common/ConvertLiteral.hs Common/Earley.hs CASL/MixfixParser.hs \
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel CASL/Parse_AS_Basic.hs CASL/Sign.hs CASL/Overload.hs \
a2e796b608034e2c62290378d713058b8b58ef8fMarkus Engel CASL/StaticAna.hs Modal/AS_Modal.hs Modal/Parse_AS.hs \
a2e796b608034e2c62290378d713058b8b58ef8fMarkus Engel Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzHC = ghc
91934be261c16d036521379306a74b0991720e67joncruzPERL = perl
91934be261c16d036521379306a74b0991720e67joncruzHAPPY = happy -sgca
91934be261c16d036521379306a74b0991720e67joncruzDRIFT = utils/DrIFT
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus EngelINLINEAXIOMS = utils/outlineAxioms
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus EngelHADDOCK = haddock
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus EngelCPPP = cpp
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus EngelHC_WARN = -Wall
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus EngelHC_FLAGS = $(HC_WARN) -fglasgow-exts -fno-monomorphism-restriction \
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel -fallow-overlapping-instances -fallow-undecidable-instances
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel# -ddump-minimal-imports
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel# flags also come in via ../uni/uni-package.conf
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel# but added it here in case of compilation without uni
7ab987fc3c5f568cfe40eccfe8a4f4ecc8c0006cMarkus Engel
35087bff7509c736a32e0b74fd9ff0834bde7b6bMarkus EngelHC_INCLUDE = $(addprefix -i, $(INCLUDE_PATH))
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzlogics = CASL HasCASL Modal CoCASL COL CspCASL Hatchet
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzUNI_PACKAGE_CONF = $(wildcard ../uni/uni-package.conf)
91934be261c16d036521379306a74b0991720e67joncruzifneq ($(strip $(UNI_PACKAGE_CONF)),)
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus EngelHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
35087bff7509c736a32e0b74fd9ff0834bde7b6bMarkus Engel -package uni-server -DUNI_PACKAGE
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruz# some modules from uni for haddock
91934be261c16d036521379306a74b0991720e67joncruz# if uni/server is included also HaXml sources are needed
91934be261c16d036521379306a74b0991720e67joncruzuni_dirs = ../uni/davinci ../uni/graphs ../uni/events \
91934be261c16d036521379306a74b0991720e67joncruz ../uni/reactor ../uni/util ../uni/posixutil
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engeluni_sources = $(wildcard $(addsuffix /haddock/*.hs, $(uni_dirs))) \
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel $(wildcard ../uni/htk/haddock/*/*.hs)
91934be261c16d036521379306a74b0991720e67joncruzendif
91934be261c16d036521379306a74b0991720e67joncruz
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala### list of directories to run checks in
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaTESTDIRS += Common CASL HasCASL Haskell/Hatchet/examples
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaPFE_TOOLDIR = $(wildcard ../programatica/tools)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaifneq ($(strip $(PFE_TOOLDIR)),)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelen base/parse2/LexerGen base/parse2/LexerSpec base/tests/HbcLibraries \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala base/transforms base/transforms/Deriving property \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala property/syntax property/AST property/transforms \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala property/TI property/defs property/parse2 property/parse2/Parser
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralapfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaPFE_PATH = $(addprefix -i, $(PFE_PATHS))
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralahappy_files += $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelen
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaLEX_DIR = $(PFE_TOOLDIR)/base/parse2/Lexer
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala$(LEX_DIR)/HsLex.hs: $(LEX_DIR)Gen/HsLexerGen
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala $< > $@
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free $(LEX_DIR)/HsTokens.hs
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free $(HC) --make -O -package data \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free -i$(PFE_TOOLDIR)/base/tests/HbcLibraries \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free -i$(PFE_TOOLDIR)/base/lib \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free $@.hs -o $@
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freelogics += Haskell
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freederived_sources += Haskell/PreludeString.hs $(LEX_DIR)/HsLex.hs \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free $(LEX_DIR)Gen/HsLexerGen
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free Haskell/ProgramaticaPrelude.hs
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free## rule for appendHaskellPreludeString
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free $(APPENDPRELUDESTRING)
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free $(APPENDPRELUDESTRING) < $< > $@
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaAst_Haskell_files = HsDeclStruct HsExpStruct HsFieldsStruct \
91934be261c16d036521379306a74b0991720e67joncruz HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
35087bff7509c736a32e0b74fd9ff0834bde7b6bMarkus Engel HsModule HsName HsLiteral HsIdent
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzOther_PFE_files = property/AST/HsPropStruct base/defs/PNT \
91934be261c16d036521379306a74b0991720e67joncruz base/defs/UniqueNames base/Modules/TypedIds base/TI/TiKinds \
91934be261c16d036521379306a74b0991720e67joncruz base/parse2/SourceNames base/syntax/SyntaxRec \
91934be261c16d036521379306a74b0991720e67joncruz property/syntax/PropSyntaxStruct
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus EngelHaskell_files = $(addsuffix .hs, \
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus Engel $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
91934be261c16d036521379306a74b0991720e67joncruz $(addprefix $(PFE_TOOLDIR)/, $(Other_PFE_files)))
91934be261c16d036521379306a74b0991720e67joncruz
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free## rule for ATC generation
368622010cf5cb2dda801c6a3ad939e28757a635kiiralaHaskell/ATC_Haskell.der.hs: $(Haskell_files) utils/genRules
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
9dc68827cbd515262ecb8d5ae8547d9e82c72e00Jon A. Cruz $(Haskell_files)
9dc68827cbd515262ecb8d5ae8547d9e82c72e00Jon A. Cruz
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeTESTDIRS += ToHaskell
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freeendif
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-freehappy_files += Haskell/Hatchet/HsParser.hs
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruz### Profiling (only for debugging)
35087bff7509c736a32e0b74fd9ff0834bde7b6bMarkus Engel### Attention every module must be compiled with profiling or the linker
91934be261c16d036521379306a74b0991720e67joncruz### cannot link the various .o files properly. So after switching on
91934be261c16d036521379306a74b0991720e67joncruz### Profiling, do an 'gmake real_clean; gmake'
91934be261c16d036521379306a74b0991720e67joncruz### and comment out HC_PACKAGE variable definition above.
91934be261c16d036521379306a74b0991720e67joncruz### Comment in the following line for switching on profiling.
91934be261c16d036521379306a74b0991720e67joncruz#HC_PROF = -prof -auto-all
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus Engel
c9ebeb3ded5075c514a3cfa23bc2619d70136493Markus EngelHCI_OPTS = $(HC_FLAGS) $(HC_INCLUDE) $(HC_PACKAGE) $(PFE_FLAGS)
6ab675b12355da3e6c9a4a67d03e3a2c02d8c189Markus EngelHC_OPTS = $(HCI_OPTS) $(HC_PROF)
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiralaDRIFT_OPTS = +RTS -K10m -RTS
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
91934be261c16d036521379306a74b0991720e67joncruz####################################################################
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala## sources for hets (semi - manually produced with a perl script)
60282e8335d7b6ae7020613bb22c7c69a6909fbbJon A. Cruz
91934be261c16d036521379306a74b0991720e67joncruz#GHCMAKE_OUTPUT = $(wildcard hetcats-make)
91934be261c16d036521379306a74b0991720e67joncruz
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala#ifneq ($(strip $(GHCMAKE_OUTPUT)),)
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala#include sources_hetcats.mk
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala#else
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiralanon_sources = Common/LaTeX_maps.svmono.hs CspCASL/Main.hs Logic/Morphism.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Static/LogicStructured.hs Common/CaslLanguage.hs ./Test.hs
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free
35087bff7509c736a32e0b74fd9ff0834bde7b6bMarkus EngelSOURCE_PATHS = $(COMMONLIB_PATH) $(CLEAN_PATH)
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzsources = hets.hs $(filter-out $(non_sources), \
91934be261c16d036521379306a74b0991720e67joncruz $(wildcard $(addsuffix /[A-Z]*hs, $(SOURCE_PATHS))))
91934be261c16d036521379306a74b0991720e67joncruz
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala#endif
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelenobjects = $(sources:%.hs=%.o)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiraladrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelen $(gendrifted_files)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelengenrule_header_files = $(wildcard ATC/*.header.hs)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelenatc_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Common/AS_Annotation.der.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelen Static/DevGraph.hs Proofs/Proofs.hs Isabelle/IsaSign.hs
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelenatc_der_files = $(foreach file, $(atc_files), \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala ATC/$(basename $(basename $(notdir $(file)))).der.hs)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaCASL_files = CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelen CASL/AS_Basic_CASL.der.hs
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaHasCASL_files = HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala HasCASL/Sublogic.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaModal_files = Modal/AS_Modal.hs Modal/ModalSign.hs
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaCoCASL_files = CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaCOL_files = COL/AS_COL.hs COL/COLSign.hs
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelenCspCASL_files = CspCASL/AS_CSP_CASL.hs CspCASL/SignCSP.hs
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaHatchet_files = Haskell/Hatchet/AnnotatedHsSyn.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Haskell/Hatchet/MultiModuleBasics.hs Haskell/Hatchet/HsSyn.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Haskell/Hatchet/Representation.hs Haskell/Hatchet/Class.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Haskell/Hatchet/KindInference.hs Haskell/Hatchet/Env.hs \
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala Hatchet/HatParser.hs
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralaatc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralagenerated_rule_files = $(atc_der_files) $(atc_logic_files)
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelengendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiiralainline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Comorphisms/Modal2CASL.hs Comorphisms/CASL2TopSort.hs
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiralagen_inline_axiom_files = $(patsubst %.hs,%.inline.hs, $(inline_axiom_files))
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiraladerived_sources += $(drifted_files) Driver/Version.hs $(happy_files) \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala $(inline_axiom_files) Modal/ModalSystems.hs
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala# sources that have {-# OPTIONS -cpp #-}
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiralacpp_sources = Common/DFiniteMap.hs Common/DynamicUtils.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Isabelle/Logic_Isabelle.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Proofs/Proofs.hs hets.hs CASL/CCC/FreeTypes.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Comorphisms/LogicList.hs Comorphisms/LogicGraph.hs $(happy_files)
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiralanondoc_sources = $(wildcard utils/DrIFT-src/*.hs) \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala $(wildcard utils/DrIFT-src/*.lhs) \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala $(wildcard utils/GenerateRules/*.hs) \
9dc68827cbd515262ecb8d5ae8547d9e82c72e00Jon A. Cruz $(wildcard utils/InlineAxioms/*.hs) \
39e454bdef986f01ef929a38513fc09b4ae80e32Abhishek Sharma Public $(cpp_sources) $(pfe_sources) $(gen_inline_axiom_files) \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala $(genrule_header_files) $(generated_rule_files) \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Modal/GeneratePatterns.inline.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala Haskell/PreludeString.append.hs Haskell/ProgramaticaPrelude.hs \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala hxt/HXT.hs hxt/Net.hs $(patsubst %.hs, %.der.hs, $(drifted_files))
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala# this variable holds the modules that should be documented
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiiraladoc_sources = $(filter-out $(nondoc_sources), $(sources)) \
ce31c2a2937dddb2eb4fd13b2cf8679882038d29kiirala $(patsubst %.hs, %.hspp, $(cpp_sources)) $(uni_sources)
f727367dddbf050f0a7d33757e9290f571cbd492kiirala
d9a7c806ee7f408ddb61ff4f233c9d96111ee2b5johanengelentax_sources = Taxonomy/AbstractGraphView.hs Taxonomy/MMiSSOntology.hs \
f727367dddbf050f0a7d33757e9290f571cbd492kiirala Taxonomy/MMiSSOntologyGraph.hs Taxonomy/OntoParser.hs
f727367dddbf050f0a7d33757e9290f571cbd492kiirala
f727367dddbf050f0a7d33757e9290f571cbd492kiiralatax_objects = $(patsubst %.hs, %.o, $(tax_sources))
f727367dddbf050f0a7d33757e9290f571cbd492kiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala####################################################################
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala### targets
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala
1eb1d82bb52720d1379a4ed8f78c0e700251956dkiirala.PHONY : all hets-opt hets-optimized clean d_clean real_clean bin_clean \
f727367dddbf050f0a7d33757e9290f571cbd492kiirala lib_clean distclean check capa hacapa h2h clean_genRules genRules \
7c89b734639fa72a5d2ffdc9cf1f7ab22eff67f1tavmjong-free taxonomy count doc apache_doc post_doc4apache \
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free derivedSources install_hets install release
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free
9f6f7e74a1ded383518676e0ecb2ccc5caa73d25tavmjong-free.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
f727367dddbf050f0a7d33757e9290f571cbd492kiirala#.PRECIOUS: sources_hetcats.mk
f727367dddbf050f0a7d33757e9290f571cbd492kiirala
f727367dddbf050f0a7d33757e9290f571cbd492kiirala### call run_hc with
91934be261c16d036521379306a74b0991720e67joncruz# $(call run_hc,<command-that-compiles-hetc-with-ghc>)
91934be261c16d036521379306a74b0991720e67joncruz# and it generates hetcats-make
91934be261c16d036521379306a74b0991720e67joncruz# iff there was no error during compilation
91934be261c16d036521379306a74b0991720e67joncruzrun_hc = ($(1) 2>&1 || $(RM) hetcats-make) | tee hetcats-make
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzhets: $(sources) $(derived_sources)
91934be261c16d036521379306a74b0991720e67joncruz $(call run_hc, $(HC) --make -o $@ hets.hs $(HC_OPTS))
91934be261c16d036521379306a74b0991720e67joncruz
91934be261c16d036521379306a74b0991720e67joncruzhets-opt:
91934be261c16d036521379306a74b0991720e67joncruz $(MAKE) distclean
a4030d5ca449e7e384bc699cd249ee704faaeab0Chris Morgan $(MAKE) derivedSources
$(MAKE) real_clean
$(MAKE) hets-optimized
hets-optimized: $(derived_sources)
$(call run_hc, $(HC) --make -O -o hets hets.hs $(HC_OPTS))
strip hets
hets-old: $(objects)
$(RM) $@
$(HC) -o hets $(HC_OPTS) $(objects)
hets.cgi: $(sources) GUI/hets_cgi.hs
ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
-package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_INCLUDE) \
$(HC_FLAGS) -O
strip hets.cgi
taxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
$(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
###############################
### TAGS files for (x)emacs
# load them with "M-x" "visit-tags-table" from
# "HetCATS/hetcats.TAGS"
# use "M-." to search for a tag
# !!Beware this is somewhat instable, because it uses an absolute path!!
hetcats.TAGS: $(sources)
/home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
$(sources); mv TAGS $@; mv tags hetcats.tags
###############################
### count lines of code
count: $(sources)
wc -l $(sources)
###############################
### Documentation via haddock
doc: docs/index.html
# generate haddock documentation with links to sources
docs/index.html: $(doc_sources)
$(HADDOCK) $(doc_sources) -o docs -h -v \
-i docs/base.haddock -i docs/parsec.haddock -s ../ \
-t 'Hets - the Heterogeneous Tool Set' \
-p Hets-Haddock-Prologue.txt
# sources are not copied here
apache_doc:
$(RM) docs/*.*
cvs up -d ; echo "CVS exited with: " $$?
$(MAKE) hets-opt
$(MAKE) doc
$(MAKE) post_doc4apache
$(MAKE) o_clean
$(MAKE) hets.cgi
post_doc4apache:
$(PERL) utils/post_process_docs.pl docs \
'Common.Lib.Map.html:Common.Lib._Map.html'
cp docs/*.* a-docs/
###############################
### release management
derivedSources: $(derived_sources)
utils/DrIFT: $(DRIFT_deps)
(cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
strip ../DrIFT)
utils/genRules: $(GENERATERULES_deps)
(cd utils/GenerateRules; \
$(HC) --make -i../DrIFT-src -i../.. $(HC_WARN) \
GenerateRules.hs -o ../genRules && strip ../genRules)
$(INLINEAXIOMS): $(INLINEAXIOMS_deps)
$(HC) --make utils/InlineAxioms/InlineAxioms.hs $(HC_WARN) $(HC_PROF) \
-i../.. -o $(INLINEAXIOMS)
strip $(INLINEAXIOMS)
release:
$(RM) -r HetCATS
cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository\
co -P HetCATS
$(RM) -r uni
if [ -d ../uni ] ; then ln -s ../uni uni ; fi
$(RM) -r programatica
if [ -d ../programatica ] ; then \
mkdir programatica; \
ln -s ../../programatica/tools programatica/tools ; fi
(cd HetCATS; $(MAKE) derivedSources; \
$(MAKE) clean; ./clean.sh; \
find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
$(RM) clean.*; mv Makefile Makefile.orig; \
mv ReleaseMakefile Makefile)
tar cvf HetCATS.tar HetCATS
install-hets:
chmod g+w hets
cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
cp -p version_nr $(INSTALLDIR)
(cd $(INSTALLDIR); $(RM) hets; \
ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
install: hets-opt install-hets
#############################
### ATC DrIFT-rule generation
genRules: $(generated_rule_files)
$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
$(foreach file, $(atc_files), $(gen_atc_files))
CASL/ATC_CASL.der.hs: $(CASL_files) utils/genRules
utils/genRules -r $(rule) -o CASL $(CASL_files)
HasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) utils/genRules
utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
Modal/ATC_Modal.der.hs: $(Modal_files) utils/genRules
utils/genRules -r $(rule) -o Modal $(Modal_files)
CoCASL/ATC_CoCASL.der.hs: $(CoCASL_files) utils/genRules
utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
COL/ATC_COL.der.hs: $(COL_files) utils/genRules
utils/genRules -r $(rule) -o COL $(COL_files)
CspCASL/ATC_CspCASL.der.hs: $(CspCASL_files) utils/genRules
utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
Hatchet/ATC_Hatchet.der.hs: $(Hatchet_files) utils/genRules
utils/genRules -r $(rule) -o Hatchet -h ATC/Hatchet.header.hs \
$(Hatchet_files)
rule = ShATermConvertible
gen_atc_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 ;
clean_genRules:
$(RM) $(generated_rule_files) $(gendrifted_files)
###############
### clean up
clean: bin_clean o_clean
### removes *.hi and *.o in all include directories
o_clean:
for p in $(CLEAN_PATH) ; do \
(cd $$p ; $(RM) *.hi *.o *.hspp) ; done
### remove binaries
bin_clean:
$(RM) hets
$(RM) test_parser
$(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) hetpa
$(RM) hetana
$(RM) hetdg
$(RM) atctest2
$(RM) atctest
$(RM) Common/annos
$(RM) Haskell/Hatchet/hatch
$(RM) ToHaskell/translateAna
$(RM) Taxonomy/taxonomyTool
### additonally removes *.d (dependency files) in every include directory
### also delete *.d.bak (dependency file backups)
d_clean: clean
for p in $(CLEAN_PATH) ; do \
(cd $$p ; $(RM) *.d *.d.bak) ; done
### remove files also in own libraries
lib_clean:
for p in $(COMMONLIB_PATH) ; do \
(cd $$p ; $(RM) *.hi *.d *.o) ; done
### additionally removes the files that define the sources-variable
real_clean: bin_clean lib_clean clean
$(RM) hetcats-make sources_hetcats.mk
### additionally removes files not in CVS tree
distclean: real_clean clean_genRules d_clean
$(RM) $(derived_sources)
$(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
####################################################################
### test targets
####################################################################
### a parser to test annotation parser and Id parsers
test_parser: Common/test_parser
Common/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### interactive
ghci:
$(HC)i $(HCI_OPTS)
### christian's target
### CASL parser
capa: CASL/capa
CASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### HasCASL parser
hacapa: HasCASL/hacapa
HasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### Haskell analysis
hana: Haskell/hana
Haskell/hana: Haskell/hana.hs Haskell/HatAna.hs Haskell/PreludeString.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### HasCASL to Haskell translation
h2h: ToHaskell/h2h
ToHaskell/h2h: ToHaskell/h2h.hs ToHaskell/*.hs Haskell/*.hs HasCASL/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### HetCASL parser
hetpa: Syntax/hetpa.hs Syntax/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### HetCASL parser
hetana: Static/hetana.hs Static/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### ATC test system
atctest: ATC/ATCTest.hs ATC/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
atctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs \
Common/Lib/*.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### ATerm.Lib test system
atermlibtest: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs \
Common/ATerm/*.hs Common/Lib/*.hs
$(HC) --make -o $@ $< $(HC_OPTS) $(EXTRA_HC_OPTS)
hatermdiff: Common/ATerm/ATermDiffMain.hs Common/SimpPretty.hs \
Common/ATerm/*.hs Common/Lib/*.hs
$(HC) --make -o $@ $< $(HC_OPTS) $(EXTRA_HC_OPTS)
### HetCASL with dev graph
hetdg: GUI/hetdg.hs $(drifted_files) *.hs
$(HC) --make -o $@ $< $(HC_OPTS)
### run tests in other directories
check:
for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
####################################################################
## Preparing the version of HetCATS
Driver/Version.hs: Driver/Version.in version_nr
$(PERL) utils/build_version.pl version_nr < Driver/Version.in > $@
## two hardcoded dependencies for a correct generation of Version.hs
Driver/Options.hs Driver/WriteFn.hs Driver/ReadFn.hs: Driver/Version.hs
hets.hs: Driver/Version.hs
####################################################################
## rules for DrIFT
.SUFFIXES:
%: %.hs
$(HC) --make -o $@ $<
%.hs: %.ly
$(HAPPY) $<
%.hs: %.y
$(HAPPY) -o $@ $<
%.hs: %.der.hs utils/DrIFT
($(DRIFT_ENV); export DERIVEPATH; $(DRIFT) $(DRIFT_OPTS) $< > $@)
## rules for inlineAxioms
%.hs: %.inline.hs $(INLINEAXIOMS)
$(INLINEAXIOMS) $< > $@
## rule for cpp and haddock
%.hspp: %.hs
$(HC) -E -cpp -DUNI_PACKAGE -optP -P $<
## compiling rules for object and interface files
%.o %.hi: %.hs
$(HC) -c $< $(HC_OPTS)
%.o %.hi: %.lhs
$(HC) -c $< $(HC_OPTS)
## compiling rules for dependencies
%.d : %.hs
$(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
%.d : %.lhs
$(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
Modal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in \
utils/genTransMFormFunc.pl $(INLINEAXIOMS)
$(PERL) utils/genTransMFormFunc.pl $< $@
# hetcats-make is created as side-effect of hets or hets-optimized
sources_hetcats.mk: hetcats-make utils/create_sources.pl
$(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk