Makefile revision 5452
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 = utils/DrIFT-src:utils/GenerateRules:Common:Logic:CASL:CASL/CCC:Syntax:Static:GUI:HasCASL:Haskell:Modal:CoCASL:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:Isabelle:$(INCLUDE_PATH):Haskell/Hatchet
7d0ee72ee91ec305408688b969c43f07b9667c80Christian Maeder## set ghc imports properly for your system
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederLINUX_IMPORTS = $(wildcard /home/linux-bkb/ghc/ghc-latest/lib/ghc-*/imports)
0e5b095a19790411e5352fa7cf57cb0388e70472Christian MaederDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:${LINUX_IMPORTS}:${GHC_IMPORTS}'
d23ecf32e56cce69bc42eb5c96dddf7909c623abjelmd# override on commandline for other architectures
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian MaederINSTALLDIR = /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner# -fglasgow-exts comes in via ../uni/uni-package.conf
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen KuksaHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa### Profiling and Warnings (only for debugging)
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa### Attention every module must be compiled with profiling or the linker
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa### cannot link the various .o files properly. So after switching on
a389e88e0acb83d8489bdc5e55bc5522b152bbecEugen Kuksa### Profiling, do an 'gmake clean; gmake'
a389e88e0acb83d8489bdc5e55bc5522b152bbecEugen Kuksa### If you need Profiling comment out the following line
f8597aabc9db75dcf504e3151faf220a165c90d1Eugen Kuksa#HC_PROF = -prof -auto-all
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
60e6795dd310e10194e12bb660575aadf941328bEugen Kuksa### list of directories to run checks in
60e6795dd310e10194e12bb660575aadf941328bEugen KuksaTESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell/test
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner####################################################################
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner## sources for hetcats (semi - manually produced with a perl script)
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
bab2d88d650448628730ed3b65c9f99c52500e8cChristian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
6a2dad705deefd1b7a7e09b84fd2d75f2213be47Christian Maeder HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs \
961087225d1d2b9534152a346d1a3755ed952fcdJens Elkner Modal/ATC_Modal.hs CoCASL/ATC_CoCASL.hs ATC/IsaSign.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder# this variable holds the modules that should be documented
a3c6d8e0670bf2aa71bc8e2a3b1f45d56dd65e4cChristian Maeder# the imported parsec library is not included!
dc679edd4ca027663212afdf00926ae2ce19b555Christian Maederdoc_sources = $(filter-out ./Isabelle/IsaSign.hs ,$(sources))
a2d6702f18737cc5fff8e8631c08f221f8375c4bChristian Maeder####################################################################
c72c1e75a969ff4c336e77481c2a8e42603f13eeChristian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_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) -w 2>&1 | tee hetcats-make
8037b7d21021a94b69e4a092f5c98e491333d939cmaederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files) $(inline_axiom_files)
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
961087225d1d2b9534152a346d1a3755ed952fcdJens Elkner###############################
e6d5dbbc3308f05197868806e0b860f4f53875f1Christian Maeder### TAGS files for (x)emacs
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder# load them with "M-x" "visit-tags-table" from
961087225d1d2b9534152a346d1a3755ed952fcdJens Elkner# use "M-." to search for a tag
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder###############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### Documentation via haddock
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von Schroeder# index for prelude is missing
8fb127028cb7dd361e348a3252e33487f73428bcJonathan von Schroeder -t 'hets -- a heterogenous Specification (CASL) tool set'
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder###############################
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder### release management
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix ReckersderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs $(inline_axiom_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder $(HC) --make '-i../..:../DrIFT-src' -package text GenerateRules.hs -o ../genRules && \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder $(RM) clean.*; mv Makefile Makefile.orig; \
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maeder ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder#############################
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder### ATC DrIFT-rule generation
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian MaedergenRules: $(generated_rule_files) utils/genRules
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder $(foreach file,$(atc_files),$(gen_atc_files))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o CASL $(casl_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o Modal $(modal_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o CoCASL $(cocasl_files)
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder utils/genRules -r $(rule) -o CspCASL $(cspcasl_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedergen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder utils/genRules -r $(rule) -o ATC $(file); \
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maederatc_files := $(filter-out CASL/% HasCASL/% Modal/% CoCASL/% CspCASL/% Haskell/% ,$(genrule_files))
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maedermodal_files := $(filter Modal/% ,$(genrule_files))
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maedercocasl_files := $(filter CoCASL/% ,$(genrule_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
986d3f255182539098a97ac86da9eeee5b7a72e3Christian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
5ad5dffe06818a13e1632b1119fbca7881085fc1Dominik Luecke###############
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### removes *.hi and *.o in all include directories
31d6d9286988dc31639d105841296759aeb743e0Jonathan von Schroeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### remove binaries
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### additonally removes *.d (dependency files) in every include directory
1b3a2f98d1cd01fc9e0591f69507e20526727559Dominik Luecke### also delete *.d.bak (dependency file backups)
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
dd6f22b9dcff2695181b86372e4df03d5b96e92dKristina Sojakova### remove files also in own libraries
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder### additionally removes the files that define the sources-variable
878a5ecd6acf973907e25e5be6e4a792ea19a05eEwaryst Schulz### additionally removes files not in CVS tree
48aa0645e25883048369afc02aac3f49b14a50daChristian Maeder# $(RM) $(happy_files)
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder####################################################################
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder### test targets
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder####################################################################
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis Tsogias### a parser to test annotation parser and Id parsers
a604cbad8e2202147b5c6bb9f2e06ae61162d654Felix Gabriel ManceCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
1f9274bb2aa44ea236327814dce99946be52e348Felix Gabriel Mance### interactive
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maeder### christian's target
d62661e54e2662d53b583ae48609f5037701078dcmaeder### CASL parser
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### HasCASL parser
05a206508bc898f87fe6ab6e069814df3c29d303Dominik LueckeHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### Haskell parser
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai CodescuHaskell/hapa: Haskell/hapa.hs Haskell/Hatchet/*.hs $(happy_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### HetCASL parser
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### HetCASL parser
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von Schroeder### ATC test system
b5a6fff5181dad64c4d31e8e4fbb82d4f79813d8Till Mossakowskiatctest2: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowskiatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### HetCASL with dev graph
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### run tests in other directories
e96a0bf4040fd789339958c01f145c5057d26db6René Wagner for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettich####################################################################
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich## Preparing the version of HetCATS
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maederhetcats/Version.hs: hetcats/Version.in version_nr
7868299829c1318b888152243ec2cea4f598b568Christian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
f8e1a1eca871a26a535a4ee7d51902ba94b1db1eChristian Maeder## two hardcoded dependencies for a correct generation of Version.hs
5199920ca3b698b2149c8cb9d2ce2e98a280ff9dChristian Maederhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
ea06324815fff0b73f7524f11af3672c2389f7ecChristian Maeder####################################################################
ea06324815fff0b73f7524f11af3672c2389f7ecChristian Maeder## rules for DrIFT
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder## rules for inlineAxioms
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder## compiling rules for object and interface files
7165a916d2fa1bf87c4741ec63b253413eebbf69Karl Luc## compiling rules for dependencies
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis Tsogias####################################################################
fc09e0a6af734edbd944dd8082bb51985c233b43Alexis Tsogias## Setting a global search path (for dependency files)
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maeder## include every .d file in INCLUDE_PATH
9f226cec9f978edaba67aee4c4e04e3d3b994b87Daniel Calegarisources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)