Makefile revision 6374
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner# 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 !!!
d23ecf32e56cce69bc42eb5c96dddf7909c623abjelmd# (gmake on solaris ; make on linux)
d23ecf32e56cce69bc42eb5c96dddf7909c623abjelmd####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## Some varibles, which control the compilation
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerCOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerCLEAN_PATH = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:Isabelle:$(INCLUDE_PATH):Haskell/Hatchet
7d0ee72ee91ec305408688b969c43f07b9667c80Christian Maeder## set ghc imports properly for your system
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.2/imports:${GHC_IMPORTS}'
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### Profiling and Warnings (only for debugging)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### Attention every module must be compiled with profiling or the linker
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### cannot link the various .o files properly. So after switching on
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### Profiling, do an 'gmake clean; gmake'
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### If you need Profiling comment out the following line
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa#HC_PROF = -prof -auto-all
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen KuksaHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa### list of directories to run checks in
a389e88e0acb83d8489bdc5e55bc5522b152bbecEugen Kuksa####################################################################
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa## sources for hetcats (semi - manually produced with a perl script)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroedergenrule_header_files = $(wildcard ATC/*.header.hs)
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder HasCASL/Morphism.hs HasCASL/AsToIds.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
bab2d88d650448628730ed3b65c9f99c52500e8cChristian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs \
6a2dad705deefd1b7a7e09b84fd2d75f2213be47Christian Maeder HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs \
014dc30f64ec25e4790cca987d4d1e6635430510Christian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
feca1d35123d8c31aee238c9ce79947b0bf65494Christian Maeder# this variable holds the modules that should be documented
431d34c7007a787331c4e5ec997badb0f8190fc7Christian Maeder# the imported parsec library is not included!
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederdoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
db675e8302ddb0d6528088ce68f5e98a00e890e3Christian Maeder####################################################################
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(HC) --make -o $@ hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(HC) --make -O -o hets hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder###############################
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder### TAGS files for (x)emacs
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder# load them with "M-x" "visit-tags-table" from
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder# use "M-." to search for a tag
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder###############################
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder### Documentation via haddock
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# index for prelude is missing
8037b7d21021a94b69e4a092f5c98e491333d939cmaeder -t 'hets -- a heterogenous Specification (CASL) tool set'
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder###############################
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von Schroeder### release management
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian MaederderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs
06dd4e7c29f33f6122a910719e3bd9062256e397Andy Gimblett (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT)
7bb0a9e92bc7a6f868eaa0b9c3212c0af4f96b7fEugen Kuksa $(HC) --make -i../.. -package text GenerateRules.hs -o ../genRules)
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
140287998aa8592c9c403bd9e308e447ba92ae11Christian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs -r $(RM) -r; \
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder $(RM) clean.*; $(RM) Makefile; mv ReleaseMakefile Makefile)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers#############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### ATC DrIFT-rule generation
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaedergenRules: $(generated_rule_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian 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 \
3554301a34639efb6c9961a8571775d0061284c9Christian Maeder utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian 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 \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maedergen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder utils/genRules -r $(rule) -o ATC $(file); \
3554301a34639efb6c9961a8571775d0061284c9Christian Maederatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder###############
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder### removes *.hi and *.o in all include directories
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### remove binaries
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder### additonally removes *.d (dependency files) in every include directory
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder### also delete *.d.bak (dependency file backups)
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maeder### remove files also in own libraries
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder### additionally removes the files that define the sources-variable
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### additionally removes files not in CVS tree
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maederdistclean: real_clean clean_genRules d_clean
31d6d9286988dc31639d105841296759aeb743e0Jonathan von Schroeder# $(RM) $(happy_files)
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder####################################################################
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### test targets
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder####################################################################
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke### a parser to test annotation parser and Id parsers
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von SchroederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder### interactive
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### christian's target
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### CASL parser
5afff1a0f62394414c33b06141175b3ab0b117a5Christian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maeder### HasCASL parser
dd6f22b9dcff2695181b86372e4df03d5b96e92dKristina SojakovaHasCASL/hacapa: HasCASL/hacapa.hs CASL/capa HasCASL/*.hs
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder### Haskell parser
74a992bd019d3319df2f21f9d358ff06cafb5f7eMihaela TurcuHaskell/hapa: Haskell/hapa.hs Haskell/Hatchet/*.hs $(happy_files)
c2e192ace9ef7cfb0e59563f1b24477b2b65cff3Dominik Dietrich### HetCASL parser
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder### HetCASL parser
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz### ATC test system
7834a982096d93301a4626f444dd9ea5f9fe17eaChristian Maederatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
7bb0a9e92bc7a6f868eaa0b9c3212c0af4f96b7fEugen Kuksa### HetCASL with dev graph
18c1d987ce5818ecf0bfc8af3f43aed2ce86e1eaChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke### run tests in other directories
b891e9ad7dd358a7df24b59bf00d51515078497cChristian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
5ad5dffe06818a13e1632b1119fbca7881085fc1Dominik Luecke####################################################################
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder## Preparing the version of HetCATS
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroederhetcats/Version.hs: hetcats/Version.in version_nr
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu## two hardcoded dependencies for a correct generation of Version.hs
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescuhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder####################################################################
1c9a63e4f7c6879f51fe0f32154a9116f2c126dbChristian Maeder## rules for DrIFT
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von Schroeder## compiling rules for object and interface files
b5a6fff5181dad64c4d31e8e4fbb82d4f79813d8Till Mossakowski## compiling rules for dependencies
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder####################################################################
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder## Setting a global search path (for dependency files)
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maeder## include every .d file in INCLUDE_PATH
5199920ca3b698b2149c8cb9d2ce2e98a280ff9dChristian Maedersources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)