Makefile revision ba0ec5e897ef99d420c8c14c2374e0f32b7043db
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner# Author: Klaus L�ttich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# This Makefile will compile the new hetcats system and provides also
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner# targets for test programs during implementation phases.
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# !!! Note: This makefile is written for GNU make !!!
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner# (gmake on solaris ; make on linux)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner####################################################################
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian 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:Haskell/Language:Modal:CspCASL:$(INCLUDE_PATH)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.0/imports'
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerHC_FLAGS = -fglasgow-exts -fallow-overlapping-instances -Wall
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### Profiling and Warnings (only for debugging)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### Attention every module must be compiled with profiling or the linker
ab4256496e72886018b78571057331f373da6883Eugen Kuksa### cannot link the various .o files properly. So after switching on
ab4256496e72886018b78571057331f373da6883Eugen Kuksa### Profiling, do an 'gmake clean; gmake'
ab4256496e72886018b78571057331f373da6883Eugen Kuksa### If you need Profiling comment out the following line
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner#HC_PROF = -prof -auto-all -Wall
a84a8d508a0778b13a4d097a6dd34b95feae78acJens ElknerHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### list of directories to run checks in
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner####################################################################
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner## sources for hetcats (semi - manually produced with a perl script)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs Common/AS_Annotation.der.hs Common/Named.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder CASL/Morphism.hs CASL/StaticAna.hs CASL/AS_Basic_CASL.der.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs HasCASL/Morphism.hs \
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs ATC/Named.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs ATC/DevGraph.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder CASL/ATC_CASL.hs Haskell/ATC_Haskell.hs HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maeder# this variable holds the modules that should be documented
4b4a0b61b72cf8478a5d4d5002bca9f699401363Christian Maeder# the imported parsec library is not included!
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maederdoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
d62661e54e2662d53b583ae48609f5037701078dcmaeder####################################################################
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg clean_genRules genRules
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files)
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make && \
961087225d1d2b9534152a346d1a3755ed952fcdJens Elkner $(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk
961087225d1d2b9534152a346d1a3755ed952fcdJens Elkner###############################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### TAGS files for (x)emacs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian 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!!
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
a3c6d8e0670bf2aa71bc8e2a3b1f45d56dd65e4cChristian Maeder###############################
dc679edd4ca027663212afdf00926ae2ce19b555Christian Maeder### Documentation via haddock
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder -i/home/linux-bkb/ghc/ghc-6.0/share/ghc-6.0/html/base,/home/linux-bkb/ghc/ghc-6.0/share/ghc-6.0/html/base/base.haddock \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder##########################
a84a8d508a0778b13a4d097a6dd34b95feae78acJens Elkner### DrIFT-rule generation
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(foreach file,$(atc_files),$(gen_atc_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs $(casl_files)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs $(hascasl_files)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs $(cspcasl_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs $(haskell_files)
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maedergen_atc_files = if [ -e ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
961087225d1d2b9534152a346d1a3755ed952fcdJens Elkner utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder utils/genRules -r $(rule) -o ATC $(file); \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
961087225d1d2b9534152a346d1a3755ed952fcdJens Elknercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
328a85c807f2a95c3f147d10b05927eaf862ebebChristian Maeder### removes *.hi and *.o in all include directories
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder### remove binaries
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### additonally removes *.d (dependency files) in every include directory
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### also delete *.d.bak (dependency file backups)
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
3554301a34639efb6c9961a8571775d0061284c9Christian Maeder### remove files also in own libraries
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder### additionally removes the files that define the sources-variable
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder### additionally removes files not in CVS tree
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maederdistclean: real_clean clean_genRules d_clean
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder####################################################################
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder### test targets
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder####################################################################
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maeder### a parser to test annotation parser and Id parsers
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder### interactive
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### christian's target
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### CASL parser
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian MaederCASL/capa: CASL/capa.lhs Common/*.hs CASL/*.hs
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder### HasCASL parser
ac34194a668399bb8ef238da77c3a09e93fb253bChristian MaederHasCASL/hacapa: HasCASL/hacapa.lhs CASL/capa HasCASL/*.hs
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder### Haskell parser
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian MaederHaskell/hapa: Haskell/hapa.lhs Haskell/*.hs Haskell/Language/*.hs $(happy_files)
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder### Haskell wrap parser
01e278bdd7dce13b9303ed3d79683d83c89d09f9Liam O'Reilly### HetCASL parser
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### HetCASL parser
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### ATC test system
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von Schroeder### HetCASL with dev graph
81f49ee02aaa3bc870401f8883bf52742eb3ea7aJonathan von Schroederhetdg: GUI/hetdg.hs $(drifted_files) *.hs
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski### run tests in other directories
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maeder####################################################################
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maeder## Preparing the version of HetCATS
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maederhetcats/Version.hs: hetcats/Version.in version_nr
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettich## two hardcoded dependencies for a correct generation of Version.hs
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maederhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
ea3bff3e547a1ac714d4db39c5efef95e02b2e7dChristian Maeder####################################################################
dd6f22b9dcff2695181b86372e4df03d5b96e92dKristina Sojakova## rules for DrIFT
6b75c206b317eb30a08d88a8f27e0295ffeb1546Christian Maeder# $(AG) $< -o $@
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder## compiling rules for object and interface files
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder## compiling rules for dependencies
1f9274bb2aa44ea236327814dce99946be52e348Felix Gabriel Mance $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
d62661e54e2662d53b583ae48609f5037701078dcmaeder####################################################################
9f226cec9f978edaba67aee4c4e04e3d3b994b87Daniel Calegari## Setting a global search path (for dependency files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## include every .d file in INCLUDE_PATH