Makefile revision 94d3aa05411444596b44ede4531f05dd7ac20fdf
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 = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:Isabelle:$(INCLUDE_PATH):Haskell/Hatchet
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder## set ghc imports properly for your system
a1ed34933c266ce85066acb0d7b20c90cb8eb213Christian MaederGHC_IMPORTS = $(wildcard /home/linux-bkb/ghc/ghc-latest/lib/ghc-*/imports)
c0c2380bced8159ff0297ece14eba948bd236471Christian MaederDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:${GHC_IMPORTS}'
ad270004874ce1d0697fb30d7309f180553bb315Christian MaederGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
ef9e8535c168d3f774d9e74368a2317a9eda5826Christian MaederHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### Profiling and Warnings (only for debugging)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### Attention every module must be compiled with profiling or the linker
7cc09dd93962a2155c34d209d1d4cd7d7b838264Christian Maeder### cannot link the various .o files properly. So after switching on
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### Profiling, do an 'gmake clean; gmake'
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder### If you need Profiling comment out the following line
51d769d55d88dfa88bdf54bee78d8fa85a2deba8Christian Maeder#HC_PROF = -prof -auto-all
7cc09dd93962a2155c34d209d1d4cd7d7b838264Christian MaederHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
c3053d57f642ca507cdf79512e604437c4546cb9Christian Maeder### list of directories to run checks in
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder####################################################################
05a62e84edac8c64de04f8349dee418598d216b9Christian Maeder## sources for hetcats (semi - manually produced with a perl script)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
a5e5b8c3e5c11177e5034ef2423813a5d28979edChristian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder HasCASL/As.hs HasCASL/Le.hs HasCASL/SymbItem.hs \
1cd4f6541984962658add5cfaa9f28a93879881bChristian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian 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))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# this variable holds the modules that should be documented
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder# the imported parsec library is not included!
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdoc_sources = $(filter-out ./Isabelle/IsaSign.hs ,$(sources))
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder####################################################################
b568982efd0997d877286faa592d81b03c8c67b8Christian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files)
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder $(HC) --make -o $@ hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(HC) --make -O -o hets hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
e6d5dbbc3308f05197868806e0b860f4f53875f1Christian Maeder###############################
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder### TAGS files for (x)emacs
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder# load them with "M-x" "visit-tags-table" from
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian Maeder# use "M-." to search for a tag
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian 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 \
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder### Documentation via haddock
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder# index for prelude is missing
b2ac5a92cf36382e8deea5661c1964566caf72b3Christian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### release management
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian MaederderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder $(HC) --make '-i../..:../DrIFT-src' -package text GenerateRules.hs -o ../genRules && \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
d6697ad2479099b816203fd2c36f593c72c73c76Christian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder $(RM) clean.*; $(RM) Makefile; mv ReleaseMakefile Makefile)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder#############################
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder### ATC DrIFT-rule generation
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaedergenRules: $(generated_rule_files) utils/genRules
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder $(foreach file,$(atc_files),$(gen_atc_files))
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maedergen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o ATC $(file); \
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maederatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder###############
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### removes *.hi and *.o in all include directories
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder### remove binaries
986d3f255182539098a97ac86da9eeee5b7a72e3Christian Maeder### additonally removes *.d (dependency files) in every include directory
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### also delete *.d.bak (dependency file backups)
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### remove files also in own libraries
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu### additionally removes the files that define the sources-variable
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder $(RM) hetcats-make sources_hetcats.mk
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### additionally removes files not in CVS tree
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder# $(RM) $(happy_files)
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder####################################################################
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski### test targets
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder####################################################################
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### a parser to test annotation parser and Id parsers
5afff1a0f62394414c33b06141175b3ab0b117a5Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
247cc88aa55d0a7b6831767cd593ea885c6747a0Christian Maeder### interactive
dd6f22b9dcff2695181b86372e4df03d5b96e92dKristina Sojakova### christian's target
005e0f0c6b0cc898003b03801158c208f3071fc5Kristina Sojakova### CASL parser
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder### HasCASL parser
6b75c206b317eb30a08d88a8f27e0295ffeb1546Christian MaederHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder### Haskell parser
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis TsogiasHaskell/hapa: Haskell/hapa.hs Haskell/Hatchet/*.hs $(happy_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### HetCASL parser
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### HetCASL parser
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### ATC test system
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### HetCASL with dev graph
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### run tests in other directories
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## Preparing the version of HetCATS
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederhetcats/Version.hs: hetcats/Version.in version_nr
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## two hardcoded dependencies for a correct generation of Version.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## rules for DrIFT
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## compiling rules for object and interface files
48aa0645e25883048369afc02aac3f49b14a50daChristian Maeder## compiling rules for dependencies
79834070d6d3c63a098e570b12fa3405c607dc70Kristina Sojakova $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder####################################################################
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder## Setting a global search path (for dependency files)
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder## include every .d file in INCLUDE_PATH
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis Tsogiassources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)