Makefile revision 8b4c68db8b465107cabef8b9cd5b6bc216e1b156
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)
7cc09dd93962a2155c34d209d1d4cd7d7b838264Christian Maeder# -fglasgow-exts comes in via ../uni/uni-package.conf
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder# but added it here in case of compilation without uni
f041c9a6bda23de33a38490e35b831ae18d96b45Christian MaederHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### Profiling (only for debugging)
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### Attention every module must be compiled with profiling or the linker
c3053d57f642ca507cdf79512e604437c4546cb9Christian Maeder### cannot link the various .o files properly. So after switching on
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder### Profiling, do an 'gmake real_clean; gmake'
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian Maeder### and comment out HC_PACKAGE variable definition above.
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian Maeder### Comment in the following line for switching on profiling.
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder#HC_PROF = -prof -auto-all
1cd4f6541984962658add5cfaa9f28a93879881bChristian MaederHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### list of directories to run checks in
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian MaederTESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell/test
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder## sources for hetcats (semi - manually produced with a perl script)
a5e5b8c3e5c11177e5034ef2423813a5d28979edChristian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
a42fbfe7becf0eae2d624123eb0db73a794593f0Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
a42fbfe7becf0eae2d624123eb0db73a794593f0Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
1cd4f6541984962658add5cfaa9f28a93879881bChristian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
0be0db405c49906bd7057255069bf6df53395ac9Klaus Luettichgendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs \
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder Modal/ATC_Modal.hs CoCASL/ATC_CoCASL.hs COL/ATC_COL.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs Comorphisms/Modal2CASL.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder# this variable holds the modules that should be documented
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# the imported parsec library is not included!
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedercpp_sources = ./Isabelle/IsaProve.hs ./Isabelle/Logic_Isabelle.hs ./Proofs/Proofs.hs hets.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederdoc_sources = $(filter-out ./Isabelle/IsaSign.hs $(cpp_sources) ,$(sources)) \
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder####################################################################
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian 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
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder $(HC) --make -O -o hets hets.hs $(HC_OPTS) -w 2>&1 | tee hetcats-make
328a85c807f2a95c3f147d10b05927eaf862ebebChristian Maeder ghc --make -package-conf /home/luettich/ghc-pkg/package.conf -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_OPTS) -O
06dd4e7c29f33f6122a910719e3bd9062256e397Andy Gimbletthetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files) $(inline_axiom_files) Modal/ModalSystems.hs
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder###############################
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers### TAGS files for (x)emacs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# load them with "M-x" "visit-tags-table" from
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# use "M-." to search for a tag
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### count lines of code
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Documentation via haddock
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder# index for prelude is missing
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder###############################
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maeder### release management
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian MaederderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs $(inline_axiom_files) Modal/ModalSystems.hs
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder $(HC) --make '-i../..:../DrIFT-src' -package text GenerateRules.hs -o ../genRules && \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
4fc9de0da898448f1d3597ebbd8c04a066464c21Christian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(RM) clean.*; mv Makefile Makefile.orig; \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder#############################
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### ATC DrIFT-rule generation
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von SchroedergenRules: $(generated_rule_files) utils/genRules
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke $(foreach file,$(atc_files),$(gen_atc_files))
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke utils/genRules -r $(rule) -o CASL $(casl_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o HasCASL $(hascasl_files)
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder utils/genRules -r $(rule) -o Modal $(modal_files)
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder utils/genRules -r $(rule) -o CoCASL $(cocasl_files)
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder utils/genRules -r $(rule) -o COL $(col_files)
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski utils/genRules -r $(rule) -o CspCASL $(cspcasl_files)
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maedergen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
1b3a2f98d1cd01fc9e0591f69507e20526727559Dominik Luecke utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
247cc88aa55d0a7b6831767cd593ea885c6747a0Christian Maeder utils/genRules -r $(rule) -o ATC $(file); \
ea3bff3e547a1ac714d4db39c5efef95e02b2e7dChristian Maederatc_files := $(filter-out CASL/% HasCASL/% Modal/% CoCASL/% COL/% CspCASL/% Haskell/% ,$(genrule_files))
dd6f22b9dcff2695181b86372e4df03d5b96e92dKristina Sojakovacasl_files := $(filter CASL/% ,$(genrule_files))
005e0f0c6b0cc898003b03801158c208f3071fc5Kristina Sojakovahascasl_files := $(filter HasCASL/% ,$(genrule_files))
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettichmodal_files := $(filter Modal/% ,$(genrule_files))
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maedercocasl_files := $(filter CoCASL/% ,$(genrule_files))
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maedercol_files := $(filter COL/% ,$(genrule_files))
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
6b75c206b317eb30a08d88a8f27e0295ffeb1546Christian Maeder###############
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder### removes *.hi and *.o in all include directories
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### remove binaries
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### additonally removes *.d (dependency files) in every include directory
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### also delete *.d.bak (dependency file backups)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### remove files also in own libraries
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder 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
48aa0645e25883048369afc02aac3f49b14a50daChristian Maeder### interactive
79834070d6d3c63a098e570b12fa3405c607dc70Kristina Sojakova### christian's target
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder### CASL parser
8a78868bae2ec6838c87366c35c57e109154c51eChristian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
624e6701e0deb7ac6c03c0cba0190fbc5033cf93Ewaryst Schulz### HasCASL parser
7165a916d2fa1bf87c4741ec63b253413eebbf69Karl LucHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder### Haskell parser
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederHaskell/hapa: Haskell/hapa.hs Haskell/Hatchet/*.hs $(happy_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Haskell analysis
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederHaskell/hana: Haskell/hana.hs Haskell/HatAna.hs Haskell/Hatchet/*.hs $(happy_files)
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder### HetCASL parser
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### HetCASL parser
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### ATC test system
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maederatctest2: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder### HetCASL with dev graph
10883d13973c46cac98964b66ace7a52b2d059abChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
10883d13973c46cac98964b66ace7a52b2d059abChristian Maeder### run tests in other directories
bf25e8c286cda74ef89a9cbc3c2143557e0d49c3Christian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
05a62e84edac8c64de04f8349dee418598d216b9Christian Maeder####################################################################
10883d13973c46cac98964b66ace7a52b2d059abChristian Maeder## Preparing the version of HetCATS
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maederhetcats/Version.hs: hetcats/Version.in version_nr
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder## two hardcoded dependencies for a correct generation of Version.hs
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maederhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder####################################################################
0c355dd0b739631ee472f9a656e266be27fa4e64Christian Maeder## rules for DrIFT
810746aea00b81c1eec27dae84d73a43599ff056Christian Maeder## rules for inlineAxioms
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maeder## rule for cpp and haddock
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder## compiling rules for object and interface files
ef67402074be14deb95e4ff564737d5593144130Klaus Luettich## compiling rules for dependencies
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in utils/genTransMFormFunc.pl $(INLINEAXIOMS)
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder####################################################################
43bb71dfe7ec405f563864d57c1cacdaa8ce9a80Christian Maeder## Setting a global search path (for dependency files)
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder## include every .d file in INCLUDE_PATH
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maedersources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)