Makefile revision 31c49f2fa23d4ac089f35145d80a224deb6ea7e4
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
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederCOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian 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
a1ed34933c266ce85066acb0d7b20c90cb8eb213Christian Maeder## set ghc imports properly for your system
c0c2380bced8159ff0297ece14eba948bd236471Christian MaederLINUX_IMPORTS = $(wildcard /home/linux-bkb/ghc/ghc-latest/lib/ghc-*/imports)
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus LuettichDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:${LINUX_IMPORTS}:${GHC_IMPORTS}'
ad270004874ce1d0697fb30d7309f180553bb315Christian Maeder# override on commandline for other architectures
4d56f2fa72e4aec20eb827c11ed49c8cbb7014bdChristian MaederINSTALLDIR = /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus LuettichGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# -fglasgow-exts comes in via ../uni/uni-package.conf
c3053d57f642ca507cdf79512e604437c4546cb9Christian Maeder# but added it here in case of compilation without uni
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian MaederHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
1cd4f6541984962658add5cfaa9f28a93879881bChristian Maeder### Profiling and Warnings (only for debugging)
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### Attention every module must be compiled with profiling or the linker
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### cannot link the various .o files properly. So after switching on
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### Profiling, do an 'gmake clean; gmake'
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### If you need Profiling comment out the following line
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder#HC_PROF = -prof -auto-all
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian MaederHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz### list of directories to run checks in
8cacad2a09782249243b80985f28e9387019fe40Christian MaederTESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell/test
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder####################################################################
014dc30f64ec25e4790cca987d4d1e6635430510Christian Maeder## sources for hetcats (semi - manually produced with a perl script)
2d130d212db7208777ca896a7ecad619a8944971Christian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
a9b59eb2ce961014974276cdae0e9df4419bd212Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
dc679edd4ca027663212afdf00926ae2ce19b555Christian Maeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder Modal/ATC_Modal.hs CoCASL/ATC_CoCASL.hs COL/ATC_COL.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs Comorphisms/Modal2CASL.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder# this variable holds the modules that should be documented
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder# the imported parsec library is not included!
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maederdoc_sources = $(filter-out ./Isabelle/IsaSign.hs ,$(sources))
e6d5dbbc3308f05197868806e0b860f4f53875f1Christian Maeder####################################################################
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder $(HC) --make -o $@ hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederproblematic_objs = Common/Lib/Rel.o Common/Id.o Common/Lexer.o Common/Lib/Pretty.o Common/GlobalAnnotations.o Common/PPUtils.o
f1a913f880e409e7327b5deae95738b5448379a1Christian Maeder $(HC) --make -O -o hets hets.hs $(HC_OPTS) -w 2>&1 | tee hetcats-make
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder ghc --make -package-conf /home/luettich/ghc-pkg/package.conf -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_OPTS)
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files) $(inline_axiom_files) Modal/ModalSystems.hs
328a85c807f2a95c3f147d10b05927eaf862ebebChristian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
06dd4e7c29f33f6122a910719e3bd9062256e397Andy Gimblett###############################
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder### TAGS files for (x)emacs
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder# load them with "M-x" "visit-tags-table" from
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder# use "M-." to search for a tag
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers# !!Beware this is somewhat instable, because it uses an absolute path!!
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
d6697ad2479099b816203fd2c36f593c72c73c76Christian Maeder###############################
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder### count lines of code
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Documentation via haddock
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder# index for prelude is missing
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder###############################
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### release management
54ea981a0503c396c2923a1c06421c6235baf27fChristian MaederderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs $(inline_axiom_files) Modal/ModalSystems.hs
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder $(HC) --make '-i../..:../DrIFT-src' -package text GenerateRules.hs -o ../genRules && \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(RM) clean.*; mv Makefile Makefile.orig; \
4fc9de0da898448f1d3597ebbd8c04a066464c21Christian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder#############################
01e278bdd7dce13b9303ed3d79683d83c89d09f9Liam O'Reilly### ATC DrIFT-rule generation
5ad5dffe06818a13e1632b1119fbca7881085fc1Dominik LueckegenRules: $(generated_rule_files) utils/genRules
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
31d6d9286988dc31639d105841296759aeb743e0Jonathan von Schroeder utils/genRules -r $(rule) -o CASL $(casl_files)
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu utils/genRules -r $(rule) -o HasCASL $(hascasl_files)
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder utils/genRules -r $(rule) -o Modal $(modal_files)
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder utils/genRules -r $(rule) -o CoCASL $(cocasl_files)
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder utils/genRules -r $(rule) -o COL $(col_files)
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder utils/genRules -r $(rule) -o CspCASL $(cspcasl_files)
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maedergen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o ATC $(file); \
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maederatc_files := $(filter-out CASL/% HasCASL/% Modal/% CoCASL/% COL/% CspCASL/% Haskell/% ,$(genrule_files))
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
1b3a2f98d1cd01fc9e0591f69507e20526727559Dominik Lueckemodal_files := $(filter Modal/% ,$(genrule_files))
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettichcocasl_files := $(filter CoCASL/% ,$(genrule_files))
247cc88aa55d0a7b6831767cd593ea885c6747a0Christian Maedercol_files := $(filter COL/% ,$(genrule_files))
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
f8e1a1eca871a26a535a4ee7d51902ba94b1db1eChristian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder###############
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maeder### removes *.hi and *.o in all include directories
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
6b75c206b317eb30a08d88a8f27e0295ffeb1546Christian Maeder### remove binaries
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### additonally removes *.d (dependency files) in every include directory
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### also delete *.d.bak (dependency file backups)
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu### remove files also in own libraries
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### additionally removes the files that define the sources-variable
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### additionally removes files not in CVS tree
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederdistclean: real_clean clean_genRules d_clean
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) $(drifted_file) $(inline_axiom_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# $(RM) $(happy_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### test targets
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### a parser to test annotation parser and Id parsers
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### interactive
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### christian's target
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### CASL parser
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### HasCASL parser
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
48aa0645e25883048369afc02aac3f49b14a50daChristian Maeder### Haskell parser
79834070d6d3c63a098e570b12fa3405c607dc70Kristina SojakovaHaskell/hapa: Haskell/hapa.hs Haskell/Hatchet/*.hs $(happy_files)
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder### HetCASL parser
624e6701e0deb7ac6c03c0cba0190fbc5033cf93Ewaryst Schulz### HetCASL parser
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder### ATC test system
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maederatctest2: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz### ATerm.Lib test system
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulzatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
c70ef4c3b3a62764f715510c9fd67dde3acfe454Christian Maeder### HetCASL with dev graph
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### run tests in other directories
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
2b33802ca26124644f4311db4319376ecffdc8d2Christian Maeder## Preparing the version of HetCATS
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederhetcats/Version.hs: hetcats/Version.in version_nr
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## two hardcoded dependencies for a correct generation of Version.hs
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maederhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for DrIFT
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maeder## rules for inlineAxioms
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder## compiling rules for object and interface files
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder## compiling rules for dependencies
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in utils/genTransMFormFunc.pl $(INLINEAXIOMS)
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich####################################################################
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich## Setting a global search path (for dependency files)
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder## include every .d file in INCLUDE_PATH
e112e83352048f3db8c8f93ae104193e7338c10fChristian Maedersources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)