Makefile revision 7c99e334446bb97120e30e967baeeddfdd1278de
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# hetcats/Makefile
25cc5fbba63f84b47e389af749f55abbbde71c8cChristian Maeder# $Header$
25cc5fbba63f84b47e389af749f55abbbde71c8cChristian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
25cc5fbba63f84b47e389af749f55abbbde71c8cChristian Maeder# Year: 2004
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# This Makefile will compile the new hetcats system and provides also
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# targets for test programs during implementation phases.
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# !!! Note: This makefile is written for GNU make !!!
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# (gmake on solaris ; make on linux)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maederall: hets
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## Some varibles, which control the compilation
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederINCLUDE_PATH = ghc hetcats fgl hxt
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederCOMMONLIB_PATH = Common/Lib Common/ATerm fgl/Data/Graph \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder fgl/Data/Graph/Inductive fgl/Data/Graph/Inductive/Internal \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder fgl/Data/Graph/Inductive/Monad fgl/Data/Graph/Inductive/Query
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederCLEAN_PATH = . utils/DrIFT-src utils/GenerateRules utils/InlineAxioms Common \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Logic CASL CASL/CCC Syntax Static GUI HasCASL Haskell Modal CoCASL COL \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder CspCASL ATC ToHaskell Proofs Comorphisms Isabelle $(INCLUDE_PATH) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Haskell/Hatchet Hatchet Taxonomy $(PFE_PATHS)
ce8b15da31cd181b7e90593cbbca98f47eda29d6Till Mossakowski
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder## set ghc imports properly for your system
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederGHC_IMPORTS =`$(HC) --print-libdir`/imports
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederDRIFT_ENV = \
8f51f7ee933762df1a1e52caee78f5564fcf0730Christian Maeder DERIVEPATH=.:ghc:hetcats:$(GHC_IMPORTS):$(subst $(space),:,$(PFE_PATHS))
88c800932dd7053322501ea2039d9f234be6866cKlaus Luettich
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder# the 'replacing spaces' example was taken from the (GNU) Make info manual
c0c2380bced8159ff0297ece14eba948bd236471Christian Maederempty:=
c0c2380bced8159ff0297ece14eba948bd236471Christian Maederspace:= $(empty) $(empty)
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder# override on commandline for other architectures
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederINSTALLDIR = \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus LuettichDRIFT_deps = utils/DrIFT-src/*hs
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus LuettichGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
3474624438293363cada4e49225aae1e292fa597Christian MaederINLINEAXIOMS_deps = utils/InlineAxioms/*hs $(drifted_files)
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederHC = ghc
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederPERL = perl
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederHAPPY = happy -sgca
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederDRIFT = utils/DrIFT
e593b89bfd4952698dc37feced21cefe869d87a2Christian MaederINLINEAXIOMS = utils/outlineAxioms
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian MaederHADDOCK = haddock
6e049108aa87dc46bcff96fae50a4625df1d9648Klaus LuettichCPPP = cpp
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5d44c8cecd07b47ce537c7e14bf7b41a39f08507Christian MaederHC_FLAGS = -Wall -fglasgow-exts -fno-monomorphism-restriction \
a2d6702f18737cc5fff8e8631c08f221f8375c4bChristian Maeder -fallow-overlapping-instances -fallow-undecidable-instances
a2d6702f18737cc5fff8e8631c08f221f8375c4bChristian Maeder# -ddump-minimal-imports
c6fcd42c6d6d9dae8c7835c24fcb7ce8531a9050Christian Maeder# flags also come in via ../uni/uni-package.conf
31c49f2fa23d4ac089f35145d80a224deb6ea7e4Till Mossakowski# but added it here in case of compilation without uni
c55a0f77be7e88d3620b419ec8961f4379a586e3Klaus Luettich
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederHC_INCLUDE = $(addprefix -i, $(INCLUDE_PATH))
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder
8cacad2a09782249243b80985f28e9387019fe40Christian Maederlogics = CASL HasCASL Modal CoCASL COL CspCASL Hatchet
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian MaederUNI_PACKAGE_CONF := $(wildcard ../uni/uni-package.conf)
d3ae0072823e2ef0d41d4431fcc768e66489c20eChristian Maederifneq ($(strip $(UNI_PACKAGE_CONF)),)
9e748851c150e1022fb952bab3315e869aaf0214Christian MaederHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich -package uni-server -DUNI_PACKAGE
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder# some modules from uni for haddock
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder# if uni/server is included also HaXml sources are needed
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederuni_dirs = ../uni/davinci ../uni/graphs ../uni/events \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder ../uni/reactor ../uni/util ../uni/posixutil
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederuni_sources = $(wildcard $(addsuffix /haddock/*.hs, $(uni_dirs))) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(wildcard ../uni/htk/haddock/*/*.hs)
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederendif
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian MaederPFE_TOOLDIR := $(wildcard ../programatica/tools)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederifneq ($(strip $(PFE_TOOLDIR)),)
c0c2380bced8159ff0297ece14eba948bd236471Christian MaederPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
fd09d0eee026d0db12542af37fd0fbd0790f0eeaChristian Maeder base/transforms base/transforms/Deriving property \
fd09d0eee026d0db12542af37fd0fbd0790f0eeaChristian Maeder property/syntax property/AST property/transforms \
fd09d0eee026d0db12542af37fd0fbd0790f0eeaChristian Maeder property/TI property/defs property/parse2 property/parse2/Parser
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederpfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederPFE_PATH = $(addprefix -i, $(PFE_PATHS))
c0c2380bced8159ff0297ece14eba948bd236471Christian MaederPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
549b97cfbe3a6687db74440a550b68b2fc19a272Christian Maederhappy_files = $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs \
549b97cfbe3a6687db74440a550b68b2fc19a272Christian Maeder $(PFE_TOOLDIR)/base/parse2/Lexer/HsLex.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederLEX_DIR := $(PFE_TOOLDIR)/base/parse2/Lexer
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder$(LEX_DIR)/HsLex.hs: $(LEX_DIR)Gen/HsLexerGen
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $< > $@
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(LEX_DIR)/HsTokens.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(HC) --make -O -package data \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder -i$(PFE_TOOLDIR)/base/tests/HbcLibraries \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder -i$(PFE_TOOLDIR)/base/lib \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $@.hs -o $@
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
a3c6d8e0670bf2aa71bc8e2a3b1f45d56dd65e4cChristian Maederlogics += Haskell
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maederderived_sources += Haskell/PreludeString.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder Haskell/ProgramaticaPrelude.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder## rule for appendHaskellPreludeString
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(APPENDPRELUDESTRING)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(APPENDPRELUDESTRING) < $< > $@
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederAst_Haskell_files := HsDeclStruct HsExpStruct HsFieldsStruct \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder HsModule HsName HsLiteral HsIdent
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederOther_PFE_files := property/AST/HsPropStruct base/defs/PNT \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder base/defs/UniqueNames base/Modules/TypedIds \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder base/TI/TiKinds \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder base/parse2/SourceNames base/syntax/SyntaxRec \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder property/syntax/PropSyntaxStruct
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederHaskell_files = $(addsuffix .hs, \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(addprefix $(PFE_TOOLDIR)/, $(Other_PFE_files)))
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder## rule for ATC generation
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian MaederHaskell/ATC_Haskell.der.hs: $(Haskell_files) utils/genRules
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder $(Haskell_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederendif
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maederhappy_files += Haskell/Hatchet/HsParser.hs
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich### Profiling (only for debugging)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### Attention every module must be compiled with profiling or the linker
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### cannot link the various .o files properly. So after switching on
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich### Profiling, do an 'gmake real_clean; gmake'
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich### and comment out HC_PACKAGE variable definition above.
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich### Comment in the following line for switching on profiling.
5d4038657f6a63e131f5804af2f7957b69e15a43Klaus Luettich#HC_PROF = -prof -auto-all
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
c0c2380bced8159ff0297ece14eba948bd236471Christian MaederHCI_OPTS = $(HC_FLAGS) $(HC_INCLUDE) $(HC_PACKAGE) $(PFE_FLAGS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederHC_OPTS = $(HCI_OPTS) $(HC_PROF)
77a65251ee036c6aaf09c2775315a4ee24259fbdJorina Freya GerkenDRIFT_OPTS = +RTS -K10m -RTS
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### list of directories to run checks in
afa6ceaf4359ae437aaa6830949583143ace2752Christian MaederTESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
97812b7ce9860bf514a8822a63503451795dbc65Klaus Luettich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## sources for hetcats (semi - manually produced with a perl script)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder#GHCMAKE_OUTPUT = $(wildcard hetcats-make)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder#ifneq ($(strip $(GHCMAKE_OUTPUT)),)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder#include sources_hetcats.mk
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder#else
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedernon_sources = Common/LaTeX_maps.svmono.hs CspCASL/Main.hs Logic/Morphism.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederSOURCE_PATHS = $(COMMONLIB_PATH) $(CLEAN_PATH)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedersources = hets.hs $(filter-out $(non_sources), \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(wildcard $(addsuffix /[A-Z]*hs, $(SOURCE_PATHS))))
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder#endif
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederobjects = $(sources:%.hs=%.o)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
9df11f85fd7f8c4745d64464876e84ec4e263692Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
9df11f85fd7f8c4745d64464876e84ec4e263692Christian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder $(gendrifted_files)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
5d4038657f6a63e131f5804af2f7957b69e15a43Klaus Luettichgenrule_header_files = $(wildcard ATC/*.header.hs)
5d4038657f6a63e131f5804af2f7957b69e15a43Klaus Luettich
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederatc_files := Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
c432483b64662e8db604a58758cd18ea7fa65659Christian Maeder Common/AS_Annotation.der.hs \
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
8659594bb40eb5f3da5439692f0908300947191eSonja Gröning Static/DevGraph.hs \
8c692d0cc44e7df93f58a3eed0d9774ba5908339Jorina Freya Gerken Proofs/Proofs.hs \
eeb419aa20c97b4af973e97ee6ae77a8eed29e15Till Mossakowski Isabelle/IsaSign.hs
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederatc_der_files = $(foreach file, $(atc_files), \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder ATC/$(basename $(basename $(notdir $(file)))).der.hs)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCASL_files := CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder CASL/AS_Basic_CASL.der.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederHasCASL_files := HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder HasCASL/Sublogic.hs \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederModal_files := Modal/AS_Modal.hs Modal/ModalSign.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCoCASL_files := CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCOL_files := COL/AS_COL.hs COL/COLSign.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCspCASL_files := CspCASL/AS_CSP_CASL.hs CspCASL/SignCSP.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
afa6ceaf4359ae437aaa6830949583143ace2752Christian MaederHatchet_files := Haskell/Hatchet/AnnotatedHsSyn.hs \
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder Haskell/Hatchet/MultiModuleBasics.hs \
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder Haskell/Hatchet/HsSyn.hs \
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder Haskell/Hatchet/Representation.hs \
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder Haskell/Hatchet/Env.hs Hatchet/HatParser.hs
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederatc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maedergenerated_rule_files = $(atc_der_files) $(atc_logic_files)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maedergendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs \
a02a4eb2a2029d27a11fff2ebcc6c460574a74fcKlaus Luettich Comorphisms/Modal2CASL.hs # Comorphisms/CASL2TopSort.hs
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowskigen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederderived_sources += $(drifted_files) hetcats/Version.hs $(happy_files) \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(inline_axiom_files) Modal/ModalSystems.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder# sources that have {-# OPTIONS -cpp #-}
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedercpp_sources = Isabelle/Logic_Isabelle.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Proofs/Proofs.hs hets.hs CASL/CCC/FreeTypes.hs \
e2d849b4152a234bc0afaa2ab3a7c17d28de7565Christian Maeder Comorphisms/LogicList.hs Comorphisms/LogicGraph.hs $(happy_files)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedernondoc_sources = $(wildcard utils/DrIFT-src/*.hs) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(wildcard utils/DrIFT-src/*.lhs) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(wildcard utils/GenerateRules/*.hs) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(wildcard utils/InlineAxioms/*.hs) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(cpp_sources) $(pfe_sources) $(gen_inline_axiom_files) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(genrule_header_files) $(generated_rule_files) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Haskell/PreludeString.append.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Haskell/ProgramaticaPrelude.hs hxt/HXT.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(patsubst %.hs,%.der.hs,$(drifted_files))
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder# this variable holds the modules that should be documented
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederdoc_sources = $(filter-out $(nondoc_sources), $(sources)) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(patsubst %.hs, %.hspp, $(cpp_sources)) $(uni_sources)
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnketax_sources = Taxonomy/AbstractGraphView.hs Taxonomy/MMiSSOntology.hs \
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke Taxonomy/MMiSSOntologyGraph.hs Taxonomy/OntoParser.hs
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnketax_objects = $(patsubst %.hs,%.o,$(tax_sources))
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### targets
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder.PHONY : all hets-opt hets-optimized clean d_clean real_clean bin_clean \
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder lib_clean distclean check capa hacapa h2h clean_genRules genRules \
dd7b93bd69a40191907af1739db375ecc7e6cf18Christian Maeder taxonomy count doc apache_doc post_doc4apache \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder derivedSources install_hets install release
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maeder
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder#.PRECIOUS: sources_hetcats.mk
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich### call run_hc with
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich# $(call run_hc,<command-that-compiles-hetc-with-ghc>)
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich# and it generates hetcats-make
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich# iff there was no error during compilation
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettichrun_hc = ($(1) 2>&1 || $(RM) hetcats-make) | tee hetcats-make
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederhets: $(sources) $(derived_sources)
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich $(call run_hc, $(HC) --make -o $@ hets.hs $(HC_OPTS))
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederhets-opt:
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(MAKE) distclean
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maeder $(MAKE) derivedSources
b10267ae0a6523b73113fc2dee9ea628266fce60Christian Maeder $(MAKE) real_clean
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder $(MAKE) hets-optimized
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederhets-optimized: $(derived_sources)
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich $(call run_hc, $(HC) --make -O -o hets hets.hs $(HC_OPTS))
ed9207cf24e96b0d6f59985822054ae28cb69b2eChristian Maeder strip hets
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maederhets-old: $(objects)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) $@
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maeder $(HC) -o hets $(HC_OPTS) $(objects)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettichhets.cgi: $(sources) GUI/hets_cgi.hs
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_INCLUDE) \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder $(HC_FLAGS) -O
5c69cef4668bbd959d721668313a779126014d1eKlaus Luettich strip hets.cgi
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maedertaxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maeder $(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder###############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### TAGS files for (x)emacs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# load them with "M-x" "visit-tags-table" from
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# "HetCATS/hetcats/hetcats.TAGS"
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# use "M-." to search for a tag
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederhetcats.TAGS: $(sources)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder###############################
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich### count lines of code
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettichcount: $(sources)
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich wc -l $(sources)
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich###############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### Documentation via haddock
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maederdoc: docs/index.html
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder# generate haddock documentation with links to sources
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederdocs/index.html: $(doc_sources)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(HADDOCK) $(doc_sources) -o docs -h -v \
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder -i docs/base.haddock -i docs/parsec.haddock -s ../ \
ef67402074be14deb95e4ff564737d5593144130Klaus Luettich -t 'hets -- a heterogenous Specification (CASL) tool set'
ef67402074be14deb95e4ff564737d5593144130Klaus Luettich
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder# sources are not copied here
ef67402074be14deb95e4ff564737d5593144130Klaus Luettichapache_doc:
5958fabb264ec3f5b2125ac5602121bd34814a79Klaus Luettich $(RM) docs/*.*
5958fabb264ec3f5b2125ac5602121bd34814a79Klaus Luettich cvs up -d
e7e1ab2ac3f1fded8611bb92ae00e8f3b8c693fbKlaus Luettich $(MAKE) hets-opt
ef67402074be14deb95e4ff564737d5593144130Klaus Luettich $(MAKE) doc
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettich $(MAKE) post_doc4apache
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich $(MAKE) o_clean
d784803f9c752667b4fcf7393d698002bedf3f89Klaus Luettich $(MAKE) hets.cgi
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettich
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettichpost_doc4apache:
725a68ec81cba9b8aa8647bebfb5baa449803e7eKlaus Luettich $(PERL) utils/post_process_docs.pl docs \
d579f5b263e6c73d466c265f2fbfd45b0e69ca64Klaus Luettich 'Common.Lib.Map.html:Common.Lib._Map.html'
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maeder cp docs/*.* a-docs/
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder###############################
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### release management
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederderivedSources: $(derived_sources)
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettichutils/DrIFT: $(DRIFT_deps)
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
4e7050bcbcf0f372a5bad32ecd0282bccabf0983Klaus Luettich strip ../DrIFT)
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettichutils/genRules: $(GENERATERULES_deps)
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder (cd utils/GenerateRules; \
7b2177999334c920c5669621bd3c142fe198a8d7Christian Maeder $(HC) --make -i../DrIFT-src -i../.. \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder GenerateRules.hs -o ../genRules && strip ../genRules)
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder$(INLINEAXIOMS): $(INLINEAXIOMS_deps)
e593b89bfd4952698dc37feced21cefe869d87a2Christian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs \
89f270dacbf9c7a9a52ebb1a3b15796e4131d57fChristian Maeder -i../.. -o $(INLINEAXIOMS)
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder strip $(INLINEAXIOMS)
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maederrelease:
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) -r HetCATS
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository\
9c3edf2b283c09d33b2820696886d1ed32fcadc8Christian Maeder co -P HetCATS
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) -r uni
c22d75ec3ea1306219d1c09a5b3e8ff04f753ad6Christian Maeder if [ -d ../uni ] ; then ln -s ../uni uni ; fi
9c3edf2b283c09d33b2820696886d1ed32fcadc8Christian Maeder $(RM) -r programatica
c22d75ec3ea1306219d1c09a5b3e8ff04f753ad6Christian Maeder if [ -d ../programatica ] ; then \
0e71596246d44e470c78cde3029c967b9f1e6734Christian Maeder mkdir programatica; \
0e71596246d44e470c78cde3029c967b9f1e6734Christian Maeder ln -s ../../programatica/tools programatica/tools ; fi
3c09fa452664b01b1f5559f9ca8cc2ddd910688aChristian Maeder (cd HetCATS; $(MAKE) derivedSources; \
3c09fa452664b01b1f5559f9ca8cc2ddd910688aChristian Maeder $(MAKE) clean; ./clean.sh; \
94d3aa05411444596b44ede4531f05dd7ac20fdfChristian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
dc929508a3bd3c666e9b0182d56898fcafb5d66fChristian Maeder $(RM) clean.*; mv Makefile Makefile.orig; \
dc929508a3bd3c666e9b0182d56898fcafb5d66fChristian Maeder mv ReleaseMakefile Makefile)
94d3aa05411444596b44ede4531f05dd7ac20fdfChristian Maeder tar cvf HetCATS.tar HetCATS
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
8410667510a76409aca9bb24ff0eda0420088274Christian Maederinstall-hets:
ddc9315cc0b1f5dd3d8f99a77f1c75064db33b48Christian Maeder chmod g+w hets
ddc9315cc0b1f5dd3d8f99a77f1c75064db33b48Christian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
5d522dff4d0fabf57dd476d4c3de15d354a89f62Christian Maeder cp -p version_nr $(INSTALLDIR)
5d522dff4d0fabf57dd476d4c3de15d354a89f62Christian Maeder (cd $(INSTALLDIR); $(RM) hets; \
5d522dff4d0fabf57dd476d4c3de15d354a89f62Christian Maeder ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder
8410667510a76409aca9bb24ff0eda0420088274Christian Maederinstall: hets-opt install-hets
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder
ac43fa22d2d3f91a17674ac164cba3cf39a17795Klaus Luettich#############################
ac43fa22d2d3f91a17674ac164cba3cf39a17795Klaus Luettich### ATC DrIFT-rule generation
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaedergenRules: $(generated_rule_files)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
42aacf1f63419cbab63a88725e6a0b2c8776f101Christian Maeder$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(foreach file,$(atc_files),$(gen_atc_files))
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCASL/ATC_CASL.der.hs: $(CASL_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o CASL $(CASL_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederHasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederModal/ATC_Modal.der.hs: $(Modal_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o Modal $(Modal_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCoCASL/ATC_CoCASL.der.hs: $(CoCASL_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCOL/ATC_COL.der.hs: $(COL_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o COL $(COL_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCspCASL/ATC_CspCASL.der.hs: $(CspCASL_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
afa6ceaf4359ae437aaa6830949583143ace2752Christian MaederHatchet/ATC_Hatchet.der.hs: $(Hatchet_files) utils/genRules
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder utils/genRules -r $(rule) -o Hatchet -h ATC/Hatchet.header.hs \
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder $(Hatchet_files)
afa6ceaf4359ae437aaa6830949583143ace2752Christian Maeder
c0c2380bced8159ff0297ece14eba948bd236471Christian Maederrule:= ShATermConvertible
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
9e748851c150e1022fb952bab3315e869aaf0214Christian Maedergen_atc_files = \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder then utils/genRules -r $(rule) -o ATC -h \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder else utils/genRules -r $(rule) -o ATC $(file); fi ;
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
ba0ec5e897ef99d420c8c14c2374e0f32b7043dbKlaus Luettichclean_genRules:
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(RM) $(generated_rule_files) $(gendrifted_files)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder###############
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### clean up
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettichclean: bin_clean o_clean
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### removes *.hi and *.o in all include directories
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luetticho_clean:
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder for p in $(CLEAN_PATH) ; do \
6e049108aa87dc46bcff96fae50a4625df1d9648Klaus Luettich (cd $$p ; $(RM) *.hi *.o *.hspp) ; done
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder### remove binaries
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maederbin_clean:
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) hets
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(RM) test_parser
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) CASL/capa
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) HasCASL/hacapa
d67a33b40578beef2e255a274f89bb9c34aaf056Christian Maeder $(RM) Haskell/hapa
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski $(RM) Haskell/hana
d67a33b40578beef2e255a274f89bb9c34aaf056Christian Maeder $(RM) Haskell/wrap
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder $(RM) ToHaskell/h2h
26f228bf3a3fea810223396e5794c217a79a8d5bChristian Maeder $(RM) Syntax/hetpa
26f228bf3a3fea810223396e5794c217a79a8d5bChristian Maeder $(RM) Static/hetana
26f228bf3a3fea810223396e5794c217a79a8d5bChristian Maeder $(RM) GUI/hetdg
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder $(RM) hetpa
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder $(RM) hetana
ba904a15082557e939db689fcfba0c68c9a4f740Christian Maeder $(RM) hetdg
6ae5607d2def114f998fd49bac4eef12a2620fafChristian Maeder $(RM) atctest2
6ae5607d2def114f998fd49bac4eef12a2620fafChristian Maeder $(RM) atctest
6ae5607d2def114f998fd49bac4eef12a2620fafChristian Maeder $(RM) Common/annos
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maeder $(RM) Haskell/Hatchet/hatch
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maeder $(RM) ToHaskell/translateAna
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maeder $(RM) Taxonomy/taxonomyTool
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### additonally removes *.d (dependency files) in every include directory
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### also delete *.d.bak (dependency file backups)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederd_clean: clean
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder for p in $(CLEAN_PATH) ; do \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder (cd $$p ; $(RM) *.d *.d.bak) ; done
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder### remove files also in own libraries
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maederlib_clean:
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder for p in $(COMMONLIB_PATH) ; do \
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder (cd $$p ; $(RM) *.hi *.d *.o) ; done
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### additionally removes the files that define the sources-variable
08e5741dd8b6bf9b7419e89298e384e18bc57f64Christian Maederreal_clean: bin_clean lib_clean clean
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) hetcats-make sources_hetcats.mk
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### additionally removes files not in CVS tree
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckersdistclean: real_clean clean_genRules d_clean
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(RM) $(derived_sources)
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder $(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### test targets
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### a parser to test annotation parser and Id parsers
470ca7a2797069ae4b27c34c1b71419f67be1f84Christian Maedertest_parser: Common/test_parser
470ca7a2797069ae4b27c34c1b71419f67be1f84Christian Maeder
470ca7a2797069ae4b27c34c1b71419f67be1f84Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### interactive
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederghci:
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC)i $(HCI_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### christian's target
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### CASL parser
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maedercapa: CASL/capa
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
481d4fe351800ab00fd323db8974559431227305Christian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### HasCASL parser
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederhacapa: HasCASL/hacapa
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
481d4fe351800ab00fd323db8974559431227305Christian MaederHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski### Haskell analysis
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowskihana: Haskell/hana
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski
c72c1e75a969ff4c336e77481c2a8e42603f13eeChristian MaederHaskell/hana: Haskell/hana.hs Haskell/HatAna.hs Haskell/PreludeString.hs
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder### HasCASL to Haskell translation
23ab8855c58adfbd03a0730584b917b24c603901Christian Maederh2h: ToHaskell/h2h
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder
23ab8855c58adfbd03a0730584b917b24c603901Christian MaederToHaskell/h2h: ToHaskell/h2h.hs ToHaskell/*.hs Haskell/*.hs HasCASL/*.hs
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski $(HC) --make -o $@ $< $(HC_OPTS)
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### HetCASL parser
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maederhetpa: Syntax/hetpa.hs Syntax/*.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### HetCASL parser
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maederhetana: Static/hetana.hs Static/*.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers### ATC test system
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckersatctest: ATC/ATCTest.hs ATC/*.hs
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(HC) --make -o $@ $< $(HC_OPTS)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
6da66254a8cff186a1e550b4ace23fb7bcac0d90Christian Maederatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder Common/ATerm/*.hs Common/Lib/*.hs
c55a0f77be7e88d3620b419ec8961f4379a586e3Klaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
c55a0f77be7e88d3620b419ec8961f4379a586e3Klaus Luettich
5d4038657f6a63e131f5804af2f7957b69e15a43Klaus Luettich### ATerm.Lib test system
6da66254a8cff186a1e550b4ace23fb7bcac0d90Christian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs \
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder Common/ATerm/*.hs Common/Lib/*.hs
5d4038657f6a63e131f5804af2f7957b69e15a43Klaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### HetCASL with dev graph
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederhetdg: GUI/hetdg.hs $(drifted_files) *.hs
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### run tests in other directories
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maedercheck: hetcats
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## Preparing the version of HetCATS
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederhetcats/Version.hs: hetcats/Version.in version_nr
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## two hardcoded dependencies for a correct generation of Version.hs
ba0ec5e897ef99d420c8c14c2374e0f32b7043dbKlaus Luettichhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
efa8f9db01f64e2c719c201e4037743caefae045Klaus Luettichhets.hs: hetcats/Version.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for DrIFT
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder.SUFFIXES:
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
c72c1e75a969ff4c336e77481c2a8e42603f13eeChristian Maeder%: %.hs
c72c1e75a969ff4c336e77481c2a8e42603f13eeChristian Maeder $(HC) --make -o $@ $<
c72c1e75a969ff4c336e77481c2a8e42603f13eeChristian Maeder
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maeder%.hs: %.ly
d67a33b40578beef2e255a274f89bb9c34aaf056Christian Maeder $(HAPPY) $<
d67a33b40578beef2e255a274f89bb9c34aaf056Christian Maeder
fdef3358918491badb0e29e42b5d3b5a01950716Christian Maeder%.hs: %.y
4d5652abf9ed9c5714723ff7fdb80a54f7350fb2Christian Maeder $(HAPPY) -o $@ $<
fdef3358918491badb0e29e42b5d3b5a01950716Christian Maeder
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder%.hs: %.der.hs utils/DrIFT
a368e3bc3e9e92cd1981f08987295234f3441736Christian Maeder ($(DRIFT_ENV); export DERIVEPATH; $(DRIFT) $(DRIFT_OPTS) $< > $@)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski## rules for inlineAxioms
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder%.hs: %.inline.hs $(INLINEAXIOMS)
bf76f4fcf07abaebea587df8135de8356c26a363Till Mossakowski $(INLINEAXIOMS) $< > $@
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder## rule for cpp and haddock
6e049108aa87dc46bcff96fae50a4625df1d9648Klaus Luettich%.hspp: %.hs
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich $(HC) -E -cpp -DUNI_PACKAGE -optP -P $<
6e049108aa87dc46bcff96fae50a4625df1d9648Klaus Luettich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## compiling rules for object and interface files
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.o %.hi: %.hs
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich $(HC) -c $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.o %.hi: %.lhs
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich $(HC) -c $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## compiling rules for dependencies
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.d : %.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.d : %.lhs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
1a6464613c59e35072b90ca296ae402cbe956144Christian Maeder
438f9bd974c8e668203e636b0f2bc80c589af043Klaus Luettich## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
9e748851c150e1022fb952bab3315e869aaf0214Christian MaederModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder utils/genTransMFormFunc.pl $(INLINEAXIOMS)
438f9bd974c8e668203e636b0f2bc80c589af043Klaus Luettich $(PERL) utils/genTransMFormFunc.pl $< $@
438f9bd974c8e668203e636b0f2bc80c589af043Klaus Luettich
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder# hetcats-make is created as side-effect of hets or hets-optimized
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maedersources_hetcats.mk: hetcats-make utils/create_sources.pl
f29371d8bd5a232c974e736b06d0d8a655d320fbKlaus Luettich $(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk