Makefile revision 8b0f493ae42bad8b94918cc0957f1af57096cda4
f743002678eb67b99bbc29fee116b65d9530fec0wrowe
80833bb9a1bf25dcf19e814438a4b311d2e1f4cffuankg# hetcats/Makefile
6736c640e65e06990ef33af71ee81fac4df4ff5fjim# $Id$
6bb524f1895f30265a1431afc460977d391cb36bsf# Author: Klaus L�ttich
6bb524f1895f30265a1431afc460977d391cb36bsf# Year: 2003
6bb524f1895f30265a1431afc460977d391cb36bsf
6bb524f1895f30265a1431afc460977d391cb36bsf# This Makefile will compile the new hetcats system and provides also
8233250a7f6c06225752db92bf32117bd9648c1dsf# targets for test programs during implementation phases.
8233250a7f6c06225752db92bf32117bd9648c1dsf
8233250a7f6c06225752db92bf32117bd9648c1dsf# !!! Note: This makefile is written for GNU make !!!
b40bfdb714672f972887f9f1f1e154e00125bb68covener# (gmake on solaris ; make on linux)
b40bfdb714672f972887f9f1f1e154e00125bb68covener
b40bfdb714672f972887f9f1f1e154e00125bb68covener####################################################################
b40bfdb714672f972887f9f1f1e154e00125bb68covener## Some varibles, which control the compilation
e6dd71992459d05a676b98b7963423dc5dc1e24aminfrin
e6dd71992459d05a676b98b7963423dc5dc1e24aminfrinINCLUDE_PATH = ghc:hetcats
e6dd71992459d05a676b98b7963423dc5dc1e24aminfrinCOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
e6dd71992459d05a676b98b7963423dc5dc1e24aminfrinCLEAN_PATH = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Haskell/Language:Modal:CspCASL:$(INCLUDE_PATH)
23f1535d6a60817d2846bac0aea230ea475d7dccminfrin
23f1535d6a60817d2846bac0aea230ea475d7dccminfrinHC = ghc
23f1535d6a60817d2846bac0aea230ea475d7dccminfrinPERL = perl
23f1535d6a60817d2846bac0aea230ea475d7dccminfrinHAPPY = happy
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungDRIFT = $(PERL) utils/DrIFT
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungAG = $(PERL) utils/ag
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungHADDOCK = $(PERL) utils/haddock
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjung
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungHC_FLAGS = -fglasgow-exts -fallow-overlapping-instances -Wall
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungHC_INCLUDE = -i$(INCLUDE_PATH)
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjung
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjungAG_FLAGS = -mdcfs
ec7520b24cd80d34d82bbcaca153cbb23cc04bc0rjung
6249dfa569d3b4f1f539665b979a80c6e335d93etrawick### Profiling and Warnings (only for debugging)
6249dfa569d3b4f1f539665b979a80c6e335d93etrawick### Attention every module must be compiled with profiling or the linker
0827cb14e550f6f65018431c22c2c913631c8f25kbrand### cannot link the various .o files properly. So after switching on
6249dfa569d3b4f1f539665b979a80c6e335d93etrawick### Profiling, do an 'gmake clean; gmake'
ae600ca541efc686b34f8b1f21bd3d0741d37674covener### If you need Profiling comment out the following line
6249dfa569d3b4f1f539665b979a80c6e335d93etrawick#HC_PROF = -prof -auto-all -Wall
cfa64348224b66dd1c9979b809406c4d15b1c137fielding
74499a117b3b2cd9666715a14f90c0e5d1a4ee8ajimHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
cfa64348224b66dd1c9979b809406c4d15b1c137fieldingHC_OPTS = $(HCI_OPTS) $(HC_PROF)
74499a117b3b2cd9666715a14f90c0e5d1a4ee8ajimDRIFT_OPTS = +RTS -K10 -RTS
cfa64348224b66dd1c9979b809406c4d15b1c137fielding
74499a117b3b2cd9666715a14f90c0e5d1a4ee8ajim### list of directories to run checks in
cfa64348224b66dd1c9979b809406c4d15b1c137fieldingTESTDIRS = CASL HasCASL test
74499a117b3b2cd9666715a14f90c0e5d1a4ee8ajim
cfa64348224b66dd1c9979b809406c4d15b1c137fielding####################################################################
## sources for hetcats (semi - manually produced with a perl script)
ifneq ($(MAKECMDGOALS),clean)
ifneq ($(MAKECMDGOALS),bin_clean)
ifneq ($(MAKECMDGOALS),d_clean)
ifneq ($(MAKECMDGOALS),real_clean)
ifneq ($(MAKECMDGOALS),distclean)
ifneq ($(MAKECMDGOALS),genRules)
ifneq ($(MAKECMDGOALS),apache_doc)
ifneq ($(MAKECMDGOALS),clean_genRules)
include sources_hetcats.mk
endif
endif
endif
endif
endif
endif
endif
endif
objects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
drifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
$(gendrifted_files)
genrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs Common/AS_Annotation.der.hs Common/Named.hs \
Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
CASL/Morphism.hs CASL/StaticAna.hs CASL/AS_Basic_CASL.der.hs \
Haskell/Language/Syntax.hs \
HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs HasCASL/Morphism.hs \
CspCASL/AS_CSP_CASL.hs \
Static/DevGraph.hs
gendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs ATC/Named.hs \
ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
ATC/AS_Structured.hs ATC/AS_Architecture.hs ATC/DevGraph.hs \
CASL/ATC_CASL.hs Haskell/ATC_Haskell.hs HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs
generated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
happy_files = Haskell/Language/Parser.hs
# this variable holds the modules that should be documented
# the imported parsec library is not included!
doc_sources = $(filter-out Nothing/Nothing% ,$(sources))
####################################################################
### targets
.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg hets all clean_genRules genRules
.SECONDARY : %.hs %.d $(generated_rule_files)
#.PRECIOUS: sources_hetcats.mk
all: hets
hets: $(sources)
$(HC) --make -o $@ hets.hs $(HC_OPTS)
hets-old: $(objects)
$(RM) $@
$(HC) -o hets $(HC_OPTS) $(objects)
hetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
$(RM) hetcats-make sources_hetcats.mk
$(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make && \
$(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk
###############################
### TAGS files for (x)emacs
# load them with "M-x" "visit-tags-table" from
# "HetCATS/hetcats/hetcats.TAGS"
# use "M-." to search for a tag
# !!Beware this is somewhat instable, because it uses an absolute path!!
hetcats.TAGS: $(sources)
/home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
$(sources); mv TAGS $@; mv tags hetcats.tags
###############################
### Documentation via haddock
doc: docs/index.html utils/hd-lib
docs/index.html: $(doc_sources)
$(HADDOCK) $(doc_sources) -o docs -h \
-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 \
-t 'hets -- a heterogenous Specification (CASL) tool set'
apache_doc:
cvs up -d
$(MAKE) distclean
$(MAKE) hetcats-make
$(RM) docs/*.html
$(MAKE) doc
$(PERL) utils/post_process_docs.pl docs \
'Common.Lib.Map.html:Common.Lib._Map.html'
mv docs/* a-docs/
##########################
### DrIFT-rule generation
$(generated_rule_files): genRules
genRules: $(genrule_files) clean_genRules
$(foreach file,$(atc_files),$(gen_atc_files))
utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs $(casl_files)
utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs $(hascasl_files)
utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs $(cspcasl_files)
utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs $(haskell_files)
rule = ShATermConvertible
gen_atc_files = if [ -e ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
else \
utils/genRules -r $(rule) -o ATC $(file); \
fi ;
atc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
casl_files := $(filter CASL/% ,$(genrule_files))
hascasl_files := $(filter HasCASL/% ,$(genrule_files))
cspcasl_files := $(filter CspCASL/% ,$(genrule_files))
haskell_files := $(filter Haskell/%,$(genrule_files))
clean_genRules:
$(RM) ATC/*.der.hs CASL/ATC_CASL.der.hs HasCASL/ATC_HasCASL.der.hs Haskell/ATC_Haskell.der.hs CspCASL/ATC_CspCASL.der.hs
###############
### clean up
### removes *.hi and *.o in all include directories
clean: bin_clean
for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
(cd $$p ; $(RM) *.hi *.o) ; done
### remove binaries
bin_clean:
$(RM) hets
$(RM) test_parser
$(RM) CASL/capa
$(RM) HasCASL/hacapa
$(RM) Haskell/hapa
$(RM) Haskell/wrap
$(RM) Syntax/hetpa
$(RM) Static/hetana
$(RM) Static/hetana
$(RM) GUI/hetdg
$(RM) hetpa
$(RM) hetana
$(RM) hetdg
### additonally removes *.d (dependency files) in every include directory
### also delete *.d.bak (dependency file backups)
d_clean: clean
for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
(cd $$p ; $(RM) *.d *.d.bak) ; done
### remove files also in own libraries
lib_clean: clean
for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
(cd $$p ; $(RM) *.hi *.d *.o) ; done
### additionally removes the files that define the sources-variable
real_clean: bin_clean lib_clean
$(RM) hetcats-make sources_hetcats.mk
$(RM) AS_*.hs
### additionally removes files not in CVS tree
distclean: real_clean clean_genRules d_clean
$(RM) hetcats/Version.hs
$(RM) $(drifted_files)
$(RM) Haskell/Language/Parser.hs
####################################################################
### test targets
####################################################################
### a parser to test annotation parser and Id parsers
test_parser: Common/test_parser
Common/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### interactive
ghci:
$(HC)i $(HCI_OPTS)
### christian's target
### CASL parser
capa: CASL/capa
CASL/capa: CASL/capa.lhs Common/*.hs CASL/*.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### HasCASL parser
hacapa: HasCASL/hacapa
HasCASL/hacapa: HasCASL/hacapa.lhs CASL/capa HasCASL/*.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### Haskell parser
hapa: Haskell/hapa
Haskell/hapa: Haskell/hapa.lhs Haskell/*.hs Haskell/Language/*.hs $(happy_files)
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### Haskell wrap parser
wrap: Haskell/wrap
Haskell/wrap: Haskell/wrap.lhs Haskell/*.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### HetCASL parser
hetpa: Syntax/hetpa.hs Syntax/*.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### HetCASL parser
hetana: Static/hetana.hs Static/*.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### ATC test system
atctest: ATC/ATCTest.hs ATC/*.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS)
### HetCASL with dev graph
hetdg: GUI/hetdg.hs $(drifted_files) *.hs
$(RM) $@
$(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
### run tests in other directories
check: hetcats
for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
####################################################################
## Preparing the version of HetCATS
hetcats/Version.hs: hetcats/Version.in version_nr
$(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
## two hardcoded dependencies for a correct generation of Version.hs
hetcats/Options.hs: hetcats/Version.hs
hets.hs: hetcats/Version.hs
####################################################################
## rules for DrIFT
%.hs: %.ly
$(HAPPY) $<
%.hs: %.ag.hs
$(AG) $<
%.hs: %.der.hs
$(DRIFT) $(DRIFT_OPTS) $< > $@
%.hs: %.ag
$(AG) $< -o $@
%.lhs: %.der.lhs
$(DRIFT) $< > $@
## compiling rules for object and interface files
%.o %.hi: %.hs
$(HC) -c $< $(HC_OPTS)
%.o %.hi: %.lhs
$(HC) -c $< $(HC_OPTS)
## compiling rules for dependencies
%.d : %.hs
$(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
%.d : %.lhs
$(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
####################################################################
## Setting a global search path (for dependency files)
ifneq ($(MAKECMDGOALS),clean)
ifneq ($(MAKECMDGOALS),real_clean)
ifneq ($(MAKECMDGOALS),d_clean)
ifneq ($(MAKECMDGOALS),real_clean)
ifneq ($(MAKECMDGOALS),distclean)
ifneq ($(MAKECMDGOALS),genRules)
ifneq ($(MAKECMDGOALS),clean_genRules)
ifeq ($(MAKECMDGOALS),hets-old)
## include every .d file in INCLUDE_PATH
-include $(objects:.o=.d)
endif
sources_hetcats.mk: hetcats-make hetcats/Version.hs
endif
endif
endif
endif
endif
endif
endif