Makefile revision 5f990c66bbf9fdb0fb10a9a69db7b8bcfad6b9fa
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# This Makefile will compile the new hetcats system and provides also
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# targets for test programs during implementation phases.
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# !!! Note: This makefile is written for GNU make !!!
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# (gmake on solaris ; make on linux)
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian Maeder####################################################################
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder## Some varibles, which control the compilation
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
68d10d143f29fcff3c637ba24f90e983995ceae6Christian MaederCLEAN_PATH = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Haskell/Language:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:$(INCLUDE_PATH):Haskell/Hatchet
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettich## set ghc imports properly for your system
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus LuettichDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.0.1/imports'
ce8b15da31cd181b7e90593cbbca98f47eda29d6Till MossakowskiHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### Profiling and Warnings (only for debugging)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### Attention every module must be compiled with profiling or the linker
a1ed34933c266ce85066acb0d7b20c90cb8eb213Christian Maeder### cannot link the various .o files properly. So after switching on
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder### Profiling, do an 'gmake clean; gmake'
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder### If you need Profiling comment out the following line
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder#HC_PROF = -prof -auto-all
8410667510a76409aca9bb24ff0eda0420088274Christian MaederHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder#DRIFT_OPTS = +RTS -K10 -RTS
4d56f2fa72e4aec20eb827c11ed49c8cbb7014bdChristian Maeder### list of directories to run checks in
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich####################################################################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder## sources for hetcats (semi - manually produced with a perl script)
4ed0007ac9caea5b468f202521352d153481423cChristian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
0206ab93ef846e4e0885996d052b9b73b9dc66b0Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
79e80c4b3f0ebb337d84415a50f29ccfc793e68bChristian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
79e80c4b3f0ebb337d84415a50f29ccfc793e68bChristian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettich Common/AS_Annotation.der.hs Common/Named.hs \
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettich Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettich Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
64d532f676706149814b58c97cd064ca5993cccfChristian Maederhappy_files = Haskell/Language/Parser.hs Haskell/Hatchet/HsParser.hs
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder# this variable holds the modules that should be documented
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder# the imported parsec library is not included!
498aa48bdb931ab50990d3b74318a5db2312186cChristian Maederdoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder####################################################################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder.SECONDARY : %.hs %.d $(generated_rule_files)
2d130d212db7208777ca896a7ecad619a8944971Christian Maederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder###############################
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder### TAGS files for (x)emacs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder# load them with "M-x" "visit-tags-table" from
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian Maeder# use "M-." to search for a tag
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
a9b59eb2ce961014974276cdae0e9df4419bd212Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder###############################
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### Documentation via haddock
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder# index for prelude is missing
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder###############################
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder### release management
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian MaederderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(HC) --make -i../.. -package text GenerateRules.hs -o ../genRules)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder $(RM) clean.*; $(RM) Makefile; mv ReleaseMakefile Makefile)
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder#############################
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### ATC DrIFT-rule generation
363939beade943a02b31004cea09dec34fa8a6d9Christian MaedergenRules: $(generated_rule_files) utils/genRules
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(foreach file,$(atc_files),$(gen_atc_files))
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs \
13731dfbb4b6a31b35dd210e832e920065b6ac45Christian Maeder utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs \
b9b331bded61b8860edacac91df16ee19e465b42Christian Maeder utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
42b12fba6830ada5057949f825fc27edf5574e5fChristian Maedergen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o ATC $(file); \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder###############
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### removes *.hi and *.o in all include directories
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### remove binaries
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder### additonally removes *.d (dependency files) in every include directory
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### also delete *.d.bak (dependency file backups)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### remove files also in own libraries
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### additionally removes the files that define the sources-variable
ac34194a668399bb8ef238da77c3a09e93fb253bChristian Maeder### additionally removes files not in CVS tree
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederdistclean: real_clean clean_genRules d_clean
986d3f255182539098a97ac86da9eeee5b7a72e3Christian Maeder####################################################################
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### test targets
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder####################################################################
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### a parser to test annotation parser and Id parsers
8c812cd83569e973f10cf69a342424ceabc07af9Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke### interactive
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder### christian's target
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### CASL parser
8c812cd83569e973f10cf69a342424ceabc07af9Christian MaederCASL/capa: CASL/capa.lhs Common/*.hs CASL/*.hs
a6db617ca58eb6a0587b6366e913107dfecb71b5Heng Jiang### HasCASL parser
abf2487c3aece95c371ea89ac64319370dcb6483Klaus LuettichHasCASL/hacapa: HasCASL/hacapa.lhs CASL/capa HasCASL/*.hs
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers### Haskell parser
b9b960bc75e34658e70c4a0231dbc6a6e7373f2dChristian MaederHaskell/hapa: Haskell/hapa.lhs Haskell/*.hs Haskell/Language/*.hs $(happy_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### Haskell wrap parser
70731e5459a18fc473bdc962ca94d1c12de974afChristian Maeder### HetCASL parser
809f779e1f197b18e3ce57e6ed37c00817298721Christian Maeder### HetCASL parser
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### ATC test system
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettichatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder### HetCASL with dev graph
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke### run tests in other directories
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## Preparing the version of HetCATS
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettichhetcats/Version.hs: hetcats/Version.in version_nr
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
368c26b8ad68a4b2c42963626087667000c2eebfChristian Maeder## two hardcoded dependencies for a correct generation of Version.hs
368c26b8ad68a4b2c42963626087667000c2eebfChristian Maederhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder####################################################################
a5e5b8c3e5c11177e5034ef2423813a5d28979edChristian Maeder## rules for DrIFT
d0279930f87bf39843e0bd2992a4789322662144Christian Maeder## compiling rules for object and interface files
d0279930f87bf39843e0bd2992a4789322662144Christian Maeder## compiling rules for dependencies
d0279930f87bf39843e0bd2992a4789322662144Christian Maeder####################################################################
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder## Setting a global search path (for dependency files)
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder## include every .d file in INCLUDE_PATH
dc5779c9b7625d5d2fa8891c043cefc4cdfb0588Christian Maedersources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)