Makefile revision 670691f757fefac75f63a15f6aa14706e05fe155
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# Author: Klaus L�ttich
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:Haskell/Language:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:$(INCLUDE_PATH):Haskell/Hatchet
a1ed34933c266ce85066acb0d7b20c90cb8eb213Christian MaederDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.0.1/imports'
ef9e8535c168d3f774d9e74368a2317a9eda5826Christian MaederHC_FLAGS = -fglasgow-exts -fallow-overlapping-instances -Wall
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian MaederHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### Profiling and Warnings (only for debugging)
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### Attention every module must be compiled with profiling or the linker
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### cannot link the various .o files properly. So after switching on
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### Profiling, do an 'gmake clean; gmake'
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder### If you need Profiling comment out the following line
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder#HC_PROF = -prof -auto-all -Wall
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
ed1b8e97e72b2e3e92edaf2eb22a4b5373d705f1Felix Gabriel Mance### list of directories to run checks in
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian Maeder####################################################################
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder## sources for hetcats (semi - manually produced with a perl script)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
dc679edd4ca027663212afdf00926ae2ce19b555Christian Maedergenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs Common/AS_Annotation.der.hs Common/Named.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder CASL/Morphism.hs CASL/StaticAna.hs CASL/AS_Basic_CASL.der.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs HasCASL/Morphism.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder Haskell/Hatchet/AnnotatedHsSyn.hs Haskell/Hatchet/MultiModuleBasics.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs ATC/Named.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ATC/AS_Structured.hs ATC/AS_Architecture.hs ATC/DevGraph.hs \
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder CASL/ATC_CASL.hs Haskell/ATC_Haskell.hs HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maedergenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maederhappy_files = Haskell/Language/Parser.hs Haskell/Hatchet/HsParser.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# this variable holds the modules that should be documented
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder# the imported parsec library is not included!
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder####################################################################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg clean_genRules genRules
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files)
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maederhetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
b2ac5a92cf36382e8deea5661c1964566caf72b3Christian Maeder###############################
59138b404f12352d103eeffbeaeb3957b90e75fdChristian Maeder### TAGS files for (x)emacs
b2ac5a92cf36382e8deea5661c1964566caf72b3Christian Maeder# load them with "M-x" "visit-tags-table" from
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder# use "M-." to search for a tag
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
0e5b095a19790411e5352fa7cf57cb0388e70472Christian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
f1a913f880e409e7327b5deae95738b5448379a1Christian Maeder###############################
f1a913f880e409e7327b5deae95738b5448379a1Christian Maeder### Documentation via haddock
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder --read-interface=http://www.haskell.org/ghc/docs/latest/html/base,/home/linux-bkb/ghc/ghc-6.0.1/share/ghc-6.0.1/html/base/base.haddock \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder 'Common.Lib.Map.html:Common.Lib._Map.html' \
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers '/home/linux-bkb/ghc/ghc-6.0.1/share/ghc-6.0.1/html/:'
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#############################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### ATC DrIFT-rule generation
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs $(casl_files)
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs $(hascasl_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs $(cspcasl_files)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs $(haskell_files)
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); \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder utils/genRules -r $(rule) -o ATC $(file); \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maederatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maedercasl_files := $(filter CASL/% ,$(genrule_files))
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maederhascasl_files := $(filter HasCASL/% ,$(genrule_files))
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maedercspcasl_files := $(filter CspCASL/% ,$(genrule_files))
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maederhaskell_files := $(filter Haskell/%,$(genrule_files))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder###############
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder### removes *.hi and *.o in all include directories
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder### remove binaries
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### additonally removes *.d (dependency files) in every include directory
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### also delete *.d.bak (dependency file backups)
4fc9de0da898448f1d3597ebbd8c04a066464c21Christian Maeder for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder### remove files also in own libraries
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder### additionally removes the files that define the sources-variable
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### additionally removes files not in CVS tree
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdistclean: real_clean clean_genRules d_clean
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder####################################################################
5ad5dffe06818a13e1632b1119fbca7881085fc1Dominik Luecke### test targets
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder####################################################################
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### a parser to test annotation parser and Id parsers
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai CodescuCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder### christian's target
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder### CASL parser
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian MaederCASL/capa: CASL/capa.lhs Common/*.hs CASL/*.hs
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maeder### HasCASL parser
1b3a2f98d1cd01fc9e0591f69507e20526727559Dominik LueckeHasCASL/hacapa: HasCASL/hacapa.lhs CASL/capa HasCASL/*.hs
ea3bff3e547a1ac714d4db39c5efef95e02b2e7dChristian Maeder### Haskell parser
abf2487c3aece95c371ea89ac64319370dcb6483Klaus LuettichHaskell/hapa: Haskell/hapa.lhs Haskell/*.hs Haskell/Language/*.hs $(happy_files)
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maeder### Haskell wrap parser
9a4b469ca0a7f44a598e551a973c75195207db58Eugen Kuksa### HetCASL parser
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder### HetCASL parser
a604cbad8e2202147b5c6bb9f2e06ae61162d654Felix Gabriel Mance### ATC test system
bab2d88d650448628730ed3b65c9f99c52500e8cChristian 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####################################################################
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
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## rules for DrIFT
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# $(AG) $< -o $@
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## compiling rules for object and interface files
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## compiling rules for dependencies
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder## Setting a global search path (for dependency files)
79834070d6d3c63a098e570b12fa3405c607dc70Kristina Sojakova## include every .d file in INCLUDE_PATH
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maedersources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)