Makefile revision 3ac400e01fbeffd928e06b170d40e8fc84652b7f
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# This Makefile will compile the new hetcats system and provides also
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# targets for test programs during implementation phases.
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# !!! Note: This makefile is written for GNU make !!!
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# (gmake on solaris ; make on linux)
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder####################################################################
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder## Some varibles, which control the compilation
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCOMMONLIB_PATH = Common/Lib:Common/ATerm:fgl/Data/Graph:fgl/Data/Graph/Inductive:fgl/Data/Graph/Inductive/Aux:fgl/Data/Graph/Inductive/Monad:fgl/Data/Graph/Inductive/Query
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCLEAN_PATH = utils/DrIFT-src:utils/GenerateRules:utils/InlineAxioms:Common:Logic:CASL:CASL/CCC:Syntax:Static:GUI:HasCASL:Haskell:Modal:CoCASL:COL:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:Isabelle:$(INCLUDE_PATH):Haskell/Hatchet:Taxonomy:$(PFE_PATHS)
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettich## set ghc imports properly for your system
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus LuettichLINUX_IMPORTS = $(wildcard /home/linux-bkb/ghc/ghc-latest/lib/ghc-*/imports)
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus LuettichDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:${LINUX_IMPORTS}:${GHC_IMPORTS}'
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# the 'replacing spaces' example was taken from the (GNU) Make info manual
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski# override on commandline for other architectures
9dac90ec2be2a72e03893095461960d483fe2fc2Christian MaederINSTALLDIR = /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
ce8b15da31cd181b7e90593cbbca98f47eda29d6Till MossakowskiGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederINLINEAXIOMS_deps = utils/InlineAxioms/*hs $(drifted_files)
4cb215739e9ab13447fa21162482ebe485b47455Christian MaederHC_FLAGS = -Wall -fglasgow-exts -fno-monomorphism-restriction \
8ef75f1cc0437656bf622cec5ac9e8ea221da8f2Christian Maeder -fallow-overlapping-instances -fallow-undecidable-instances
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich# -ddump-minimal-imports
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# flags also come in via ../uni/uni-package.conf
74eed04be26f549d2f7ca35c370e1c03879b28b1Christian Maeder# but added it here in case of compilation without uni
254df6f22d01eacf7c57b85729e0445747b630d9Christian MaederUNI_PACKAGE_CONF := $(wildcard ../uni/uni-package.conf)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder# some modules from uni for haddock
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# if uni/server is included also HaXml sources are needed
7cc09dd93962a2155c34d209d1d4cd7d7b838264Christian Maederuni_sources = $(wildcard ../uni/davinci/haddock/*.hs) \
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian MaederPFE_TOOLDIR := $(wildcard ../programatica/tools)
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian MaederPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
d0279930f87bf39843e0bd2992a4789322662144Christian Maeder base/transforms base/transforms/Deriving hs2html pfe property base \
8be81a0578b59f08641da7fad1479e1f9e83c6e9Kristina Sojakova property/pfe property/syntax property/AST property/transforms \
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder property/TI property/defs property/parse2 property/parse2/Parser \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian MaederPFE_PATH = $(addprefix -i$(PFE_TOOLDIR)/, $(PFE_DIRS))
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder# add PFE_PATHS to DERIVEPATH if needed
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder# but name clashes currently prevent ATC generation in a single file
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian MaederPFE_PATHS = $(subst $(space),:,$(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS)))
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederpfe_sources = $(wildcard $(subst :,/*hs , $(PFE_PATHS)))
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian MaederPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder#-fallow-undecidable-instances -fno-monomorphism-restriction
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian Maeder### Profiling (only for debugging)
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder### Attention every module must be compiled with profiling or the linker
8a28707e9155465c6f2236a06eac6580a65c7025Christian Maeder### cannot link the various .o files properly. So after switching on
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettich### Profiling, do an 'gmake real_clean; gmake'
797ccd67cb8ae127be097cd43448801b673e3b69Christian Maeder### and comment out HC_PACKAGE variable definition above.
797ccd67cb8ae127be097cd43448801b673e3b69Christian Maeder### Comment in the following line for switching on profiling.
431d34c7007a787331c4e5ec997badb0f8190fc7Christian Maeder#HC_PROF = -prof -auto-all
498aa48bdb931ab50990d3b74318a5db2312186cChristian MaederHCI_OPTS = $(HC_FLAGS) $(HC_INCLUDE) $(HC_PACKAGE) $(PFE_FLAGS)
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder### list of directories to run checks in
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder####################################################################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder## sources for hetcats (semi - manually produced with a perl script)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederSOURCE_PATHS = $(COMMON_LIB_PATH):$(CLEAN_PATH)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedersources = $(wildcard $(subst :,/*hs , $(SOURCE_PATHS))/*hs)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
bc8cbf12aa172bf5673b92a9e7a0151d4aa4c315Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
2d130d212db7208777ca896a7ecad619a8944971Christian Maederatc_files := Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederatc_der_files = $(foreach file, $(atc_files), \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder ATC/$(basename $(basename $(notdir $(file)))).der.hs)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederCASL_files := CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederHasCASL_files := HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
dc679edd4ca027663212afdf00926ae2ce19b555Christian MaederModal_files := Modal/AS_Modal.hs Modal/ModalSign.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederCoCASL_files := CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederCspCASL_files := CspCASL/AS_CSP_CASL.hs CspCASL/SignCSP.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederlogics := CASL HasCASL Modal CoCASL COL CspCASL
4017ebc0f692820736d796af3110c3b3018c108aChristian Maederatc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maedergenerated_rule_files = $(atc_der_files) $(atc_logic_files)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maedergendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Comorphisms/Modal2CASL.hs # Comorphisms/CASL2TopSort.hs
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maederderived_sources = $(drifted_files) hetcats/Version.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder $(inline_axiom_files) Modal/ModalSystems.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# sources that have {-# OPTIONS -cpp #-}
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedercpp_sources = ./Isabelle/Logic_Isabelle.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ./Proofs/Proofs.hs hets.hs ./CASL/CCC/FreeTypes.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ./Comorphisms/LogicList.hs ./Comorphisms/LogicGraph.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder# this variable holds the modules that should be documented
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdoc_sources = $(filter-out $(cpp_sources), $(filter-out $(pfe_sources), \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(sources))) $(patsubst %.hs, %.hspp, $(cpp_sources))
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maedertax_sources = Taxonomy/AbstractGraphView.hs Taxonomy/MMiSSOntology.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder Taxonomy/MMiSSOntologyGraph.hs Taxonomy/OntoParser.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedertax_objects = $(patsubst %.hs,%.o,$(tax_sources))
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder####################################################################
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder.PHONY : all hets-opt hets-optimized clean d_clean real_clean bin_clean \
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian Maeder lib_clean distclean check capa hacapa clean_genRules genRules \
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian Maeder taxonomy hets.cgi count doc apache_doc post_doc4apache \
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder derivedSources install_hets install release
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HC) --make -o $@ hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder $(HC) --make -O -o hets hets.hs $(HC_OPTS) -w 2>&1 | tee hetcats-make
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_INCLUDE) \
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maedertaxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder $(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder###############################
328a85c807f2a95c3f147d10b05927eaf862ebebChristian Maeder### TAGS files for (x)emacs
a6db617ca58eb6a0587b6366e913107dfecb71b5Heng Jiang# load them with "M-x" "visit-tags-table" from
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder# use "M-." to search for a tag
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder###############################
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder### count lines of code
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder### Documentation via haddock
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# generate haddock documentation with links to sources
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder $(HADDOCK) $(doc_sources) $(uni_sources) -o docs -h -v \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder -i docs/base.haddock -i docs/parsec.haddock -s ../ \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder# sources are not copied here
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder###############################
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder### release management
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder GenerateRules.hs -o ../genRules && strip ../genRules)
ac34194a668399bb8ef238da77c3a09e93fb253bChristian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository\
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
01e278bdd7dce13b9303ed3d79683d83c89d09f9Liam O'Reilly find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(RM) clean.*; mv Makefile Makefile.orig; \
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#############################
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### ATC DrIFT-rule generation
1b3a2f98d1cd01fc9e0591f69507e20526727559Dominik Luecke$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettich $(foreach file,$(atc_files),$(gen_atc_files))
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian MaederCASL/ATC_CASL.der.hs: $(CASL_files) utils/genRules
f8e1a1eca871a26a535a4ee7d51902ba94b1db1eChristian Maeder utils/genRules -r $(rule) -o CASL $(CASL_files)
abf2487c3aece95c371ea89ac64319370dcb6483Klaus LuettichHasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) utils/genRules
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian MaederModal/ATC_Modal.der.hs: $(Modal_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o Modal $(Modal_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCoCASL/ATC_CoCASL.der.hs: $(CoCASL_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCOL/ATC_COL.der.hs: $(COL_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o COL $(COL_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCspCASL/ATC_CspCASL.der.hs: $(CspCASL_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder else utils/genRules -r $(rule) -o ATC $(file); fi ;
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) $(generated_rule_files) $(gendrifted_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder#############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### programatica stuff
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder$(LEX_DIR)/HsLex.hs: $(LEX_DIR)Gen/HsLexerGen
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder -i$(LEX_DIR):$(LEX_DIR)Gen:$(LEX_DIR)Spec \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## bad rule without programatica
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederHaskell/HatParser.o: $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### removes *.hi and *.o in all include directories
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### remove binaries
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### additonally removes *.d (dependency files) in every include directory
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski### also delete *.d.bak (dependency file backups)
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### remove files also in own libraries
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder### additionally removes the files that define the sources-variable
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder### additionally removes files not in CVS tree
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maederdistclean: real_clean clean_genRules d_clean
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder $(RM) $(drifted_file) $(inline_axiom_files)
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder $(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
a6c557605b327b033d881e74cc9f3cdbe3713b47Christian Maeder####################################################################
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder### test targets
4e9e95ba35a68f3c767bc0b23ebf9e904e442517Christian Maeder####################################################################
2686d4438ffde954ffbb3a3f307642a893b33570Christian Maeder### a parser to test annotation parser and Id parsers
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### interactive
6bf24e5eb644064ad650eb3fd9774483fccbf601Christian Maeder### christian's target
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### CASL parser
e8db9a65830cf71504e33c6f441a67b4d184a3caChristian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### HasCASL parser
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### Haskell analysis
368c26b8ad68a4b2c42963626087667000c2eebfChristian MaederHaskell/hana: Haskell/hana.hs Haskell/HatAna.hs
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski### HetCASL parser
12251a9d23f842673978d0ad6692527ef320c55dChristian Maeder### HetCASL parser
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### ATC test system
27785f379d6810811b4e6d23feab18845fde9a98Christian Maederatctest2: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs \
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder### HetCASL with dev graph
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder### run tests in other directories
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich## Preparing the version of HetCATS
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettichhetcats/Version.hs: hetcats/Version.in version_nr
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich## two hardcoded dependencies for a correct generation of Version.hs
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettichhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich####################################################################
5818d884784339c1b8aa6c6d972bad4eafd36ccbKlaus Luettich## rules for DrIFT
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder## rules for inlineAxioms
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder## rule for cpp and haddock
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder## compiling rules for object and interface files
c1bf9cc3bc3729b0bf925be3be123cbb59bea2a6Christian Maeder## compiling rules for dependencies
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
ef67402074be14deb95e4ff564737d5593144130Klaus LuettichModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in \
e05fd774e0181e93963d4302303b20698603a505Christian Maeder# hetcats-make is created as side-effect of hets or hets-optimized
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maedersources_hetcats.mk: hetcats-make utils/create_sources.pl