Makefile revision 33d042fe6a9eb27a4c48f840b80838f3e7d98e34
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)
d8c71aacc9f1c8cd40a8ad8dcdad9be8854b849fChristian Maeder####################################################################
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder## Some varibles, which control the compilation
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
dba1eafdf5b025161058f973c44b2c880e6b8241Christian MaederCLEAN_PATH = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Haskell/Language:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:$(INCLUDE_PATH):Haskell/Hatchet
a737caf82de97c1907027c03e4b4509eb492b4b8Christian Maeder## set ghc imports properly for your system
a737caf82de97c1907027c03e4b4509eb492b4b8Christian MaederDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.0.1/imports'
a737caf82de97c1907027c03e4b4509eb492b4b8Christian MaederHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### Profiling and Warnings (only for debugging)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### Attention every module must be compiled with profiling or the linker
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### cannot link the various .o files properly. So after switching on
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### Profiling, do an 'gmake clean; gmake'
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### If you need Profiling comment out the following line
2e2094a642e3775b0d76b890556407941d3a53b6Christian Maeder#HC_PROF = -prof -auto-all
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder#DRIFT_OPTS = +RTS -K10 -RTS
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### list of directories to run checks in
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich####################################################################
eee4b2ee739f163e09d6af6e45c025681e6c01a0Christian Maeder## sources for hetcats (semi - manually produced with a perl script)
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
c6fcd42c6d6d9dae8c7835c24fcb7ce8531a9050Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
31c49f2fa23d4ac089f35145d80a224deb6ea7e4Till Mossakowski Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
8cacad2a09782249243b80985f28e9387019fe40Christian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder Common/AS_Annotation.der.hs Common/Named.hs \
0206ab93ef846e4e0885996d052b9b73b9dc66b0Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
431d34c7007a787331c4e5ec997badb0f8190fc7Christian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
d3ae0072823e2ef0d41d4431fcc768e66489c20eChristian Maeder CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
776a1a086df734581431e6edb4343ed4c8d34d55Christian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederhappy_files = Haskell/Language/Parser.hs Haskell/Hatchet/HsParser.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# this variable holds the modules that should be documented
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder# the imported parsec library is not included!
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederdoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder####################################################################
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder.SECONDARY : %.hs %.d $(generated_rule_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian 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
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder###############################
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder### TAGS files for (x)emacs
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder# load them with "M-x" "visit-tags-table" from
0be0db405c49906bd7057255069bf6df53395ac9Klaus Luettich# use "M-." to search for a tag
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder###############################
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder### Documentation via haddock
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder# index for prelude is missing
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder###############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### release management
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs
2c619a4dfdc1df27573eba98e81ed1ace906941dChristian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT)
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder $(HC) --make -i../.. -package text GenerateRules.hs -o ../genRules)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(RM) clean.*; $(RM) Makefile; mv ReleaseMakefile Makefile)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### ATC DrIFT-rule generation
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix ReckersgenRules: $(generated_rule_files) utils/genRules
fb328c4f646dd3dd78a9391c5cb58450a3dd0aa9Klaus Luettich$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder $(foreach file,$(atc_files),$(gen_atc_files))
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian 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 \
9e748851c150e1022fb952bab3315e869aaf0214Christian 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); \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder utils/genRules -r $(rule) -o ATC $(file); \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder###############
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### removes *.hi and *.o in all include directories
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### remove binaries
fb328c4f646dd3dd78a9391c5cb58450a3dd0aa9Klaus Luettich### additonally removes *.d (dependency files) in every include directory
e96a0bf4040fd789339958c01f145c5057d26db6René Wagner### also delete *.d.bak (dependency file backups)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### remove files also in own libraries
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
b565cd55a13dbccc4e66c344316da525c961e4caTill Mossakowski### additionally removes the files that define the sources-variable
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### additionally removes files not in CVS tree
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowskidistclean: real_clean clean_genRules d_clean
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder####################################################################
c9acb8681bcc512245b4f0d1a9f2b189c60e10d4Christian Maeder### test targets
38352346eb1a67ba0f4eab8ad6f718528cf0cde0Christian Maeder####################################################################
63e50b4c36074d5fb9de872c4007b688b4bce534Christian Maeder### a parser to test annotation parser and Id parsers
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### interactive
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### christian's target
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### CASL parser
7fd65519c95c4a8c2e0290ae6346bce134855cadChristian MaederCASL/capa: CASL/capa.lhs Common/*.hs CASL/*.hs
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder### HasCASL parser
6bf24e5eb644064ad650eb3fd9774483fccbf601Christian MaederHasCASL/hacapa: HasCASL/hacapa.lhs CASL/capa HasCASL/*.hs
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke### Haskell parser
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederHaskell/hapa: Haskell/hapa.lhs Haskell/*.hs Haskell/Language/*.hs $(happy_files)
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### Haskell wrap parser
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder### HetCASL parser
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### HetCASL parser
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### ATC test system
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich### ATerm.Lib test system
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettichatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich### HetCASL with dev graph
5c69cef4668bbd959d721668313a779126014d1eKlaus Luettich $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### run tests in other directories
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder## Preparing the version of HetCATS
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederhetcats/Version.hs: hetcats/Version.in version_nr
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich## two hardcoded dependencies for a correct generation of Version.hs
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettichhetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich####################################################################
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich## rules for DrIFT
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich## compiling rules for object and interface files
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder## compiling rules for dependencies
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder####################################################################
96646aed2ae087b942ae23f15bbe729a8f7c43d3Christian Maeder## Setting a global search path (for dependency files)
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettich## include every .d file in INCLUDE_PATH
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettichsources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)