rules revision 5dbb9048bd3e9df82afc5f5fdbf3d88d73a57854
0N/A# hetcats/Makefile
1N/A# $Id$
1N/A# Author: Klaus L�ttich
1N/A# Year: 2003
1N/A
1N/A# This Makefile will compile the new hetcats system and provides also
1N/A# targets for test programs during implementation phases.
1N/A
1N/A# !!! Note: This makefile is written for GNU make !!!
1N/A# (gmake on solaris ; make on linux)
1N/A
1N/A####################################################################
1N/A## Some varibles, which control the compilation
1N/A
1N/AINCLUDE_PATH = ghc:hetcats
1N/ACOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
1N/ACLEAN_PATH = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Haskell/Language:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:$(INCLUDE_PATH)
1N/A
1N/ADRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.0/imports'
1N/A
1N/AHC = ghc
221N/APERL = perl
1N/AHAPPY = happy
1N/ADRIFT = $(DRIFT_ENV) $(PERL) utils/DrIFT
22N/AAG = $(PERL) utils/ag
22N/AHADDOCK = $(PERL) utils/haddock
0N/A
0N/AHC_FLAGS = -fglasgow-exts -fallow-overlapping-instances -Wall
221N/AHC_INCLUDE = -i$(INCLUDE_PATH)
14N/AHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
14N/A
221N/AAG_FLAGS = -mdcfs
14N/A
14N/A### Profiling and Warnings (only for debugging)
221N/A### Attention every module must be compiled with profiling or the linker
14N/A### cannot link the various .o files properly. So after switching on
14N/A### Profiling, do an 'gmake clean; gmake'
22N/A### If you need Profiling comment out the following line
22N/A#HC_PROF = -prof -auto-all -Wall
22N/A
22N/AHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
22N/AHC_OPTS = $(HCI_OPTS) $(HC_PROF)
22N/ADRIFT_OPTS = +RTS -K10 -RTS
14N/A
0N/A### list of directories to run checks in
116N/ATESTDIRS = CASL HasCASL test
204N/A
0N/A####################################################################
0N/A## sources for hetcats (semi - manually produced with a perl script)
0N/A
192N/Aifneq ($(MAKECMDGOALS),clean)
0N/Aifneq ($(MAKECMDGOALS),bin_clean)
0N/Aifneq ($(MAKECMDGOALS),d_clean)
285N/Aifneq ($(MAKECMDGOALS),real_clean)
0N/Aifneq ($(MAKECMDGOALS),distclean)
26N/Aifneq ($(MAKECMDGOALS),genRules)
50N/Aifneq ($(MAKECMDGOALS),apache_doc)
119N/Aifneq ($(MAKECMDGOALS),clean_genRules)
235N/Ainclude sources_hetcats.mk
296N/Aendif
26N/Aendif
301N/Aendif
301N/Aendif
301N/Aendif
301N/Aendif
301N/Aendif
301N/Aendif
301N/A
301N/Aobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
192N/A
0N/Adrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
0N/A Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
0N/A $(gendrifted_files)
301N/A
301N/Agenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs Common/AS_Annotation.der.hs Common/Named.hs \
301N/A Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
301N/A CASL/Morphism.hs CASL/StaticAna.hs CASL/AS_Basic_CASL.der.hs \
301N/A Haskell/Language/Syntax.hs \
215N/A HasCASL/Le.hs HasCASL/As.hs HasCASL/Symbol.hs HasCASL/Morphism.hs \
162N/A CspCASL/AS_CSP_CASL.hs \
301N/A Static/DevGraph.hs
301N/A
204N/Agendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs ATC/Named.hs \
235N/A ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
301N/A ATC/AS_Structured.hs ATC/AS_Architecture.hs ATC/DevGraph.hs \
301N/A CASL/ATC_CASL.hs Haskell/ATC_Haskell.hs HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs
104N/A
285N/Agenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
26N/A
0N/Ahappy_files = Haskell/Language/Parser.hs
22N/A
0N/A# this variable holds the modules that should be documented
0N/A# the imported parsec library is not included!
0N/Adoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
22N/A
116N/A####################################################################
0N/A### targets
0N/A
301N/A.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg clean_genRules genRules
301N/A.SECONDARY : %.hs %.d $(generated_rule_files)
301N/A#.PRECIOUS: sources_hetcats.mk
301N/A
301N/Aall: hets
301N/A
301N/Ahets: $(sources)
301N/A $(HC) --make -o $@ hets.hs $(HC_OPTS)
104N/A
104N/Ahets-old: $(objects)
104N/A $(RM) $@
104N/A $(HC) -o hets $(HC_OPTS) $(objects)
104N/A
301N/Ahetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
219N/A $(RM) hetcats-make sources_hetcats.mk
221N/A $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
219N/A
221N/A###############################
301N/A### TAGS files for (x)emacs
221N/A# load them with "M-x" "visit-tags-table" from
301N/A# "HetCATS/hetcats/hetcats.TAGS"
219N/A# use "M-." to search for a tag
219N/A# !!Beware this is somewhat instable, because it uses an absolute path!!
219N/Ahetcats.TAGS: $(sources)
219N/A /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
221N/A $(sources); mv TAGS $@; mv tags hetcats.tags
221N/A
301N/A###############################
301N/A### Documentation via haddock
219N/Adoc: docs/index.html utils/hd-lib
219N/A
219N/Adocs/index.html: $(doc_sources)
219N/A $(HADDOCK) $(doc_sources) -o docs -h \
219N/A -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 \
301N/A -t 'hets -- a heterogenous Specification (CASL) tool set'
301N/A
301N/Aapache_doc:
219N/A cvs up -d
301N/A $(MAKE) distclean
301N/A $(MAKE) hetcats-make
301N/A $(RM) docs/*.html
219N/A $(MAKE) doc
301N/A $(MAKE) post_doc4apache
219N/A
301N/Apost_doc4apache:
219N/A $(PERL) utils/post_process_docs.pl docs \
219N/A 'Common.Lib.Map.html:Common.Lib._Map.html' \
219N/A '/home/linux-bkb/ghc/ghc-6.0/share/ghc-6.0/html/:'
219N/A mv docs/* a-docs/
219N/A ln -s /home/linux-bkb/ghc/ghc-6.0/share/ghc-6.0/html/base a-docs
219N/A
219N/A#############################
219N/A### ATC DrIFT-rule generation
221N/A
301N/AgenRules: $(generated_rule_files)
301N/A
301N/A$(generated_rule_files): $(genrule_files)
301N/A $(MAKE) clean_genRules
301N/A $(foreach file,$(atc_files),$(gen_atc_files))
301N/A utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs $(casl_files)
301N/A utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs $(hascasl_files)
301N/A utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs $(cspcasl_files)
301N/A utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs $(haskell_files)
301N/A
301N/Arule = ShATermConvertible
221N/A
221N/Agen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
301N/A utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
301N/A else \
301N/A utils/genRules -r $(rule) -o ATC $(file); \
301N/A fi ;
301N/A
301N/Aatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
301N/Acasl_files := $(filter CASL/% ,$(genrule_files))
301N/Ahascasl_files := $(filter HasCASL/% ,$(genrule_files))
301N/Acspcasl_files := $(filter CspCASL/% ,$(genrule_files))
301N/Ahaskell_files := $(filter Haskell/%,$(genrule_files))
219N/A
301N/Aclean_genRules:
301N/A $(RM) $(generated_rule_files)
301N/A
301N/A###############
301N/A### clean up
301N/A
301N/A### removes *.hi and *.o in all include directories
301N/Aclean: bin_clean
301N/A for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
301N/A (cd $$p ; $(RM) *.hi *.o) ; done
301N/A
301N/A### remove binaries
301N/Abin_clean:
301N/A $(RM) hets
301N/A $(RM) test_parser
301N/A $(RM) CASL/capa
219N/A $(RM) HasCASL/hacapa
219N/A $(RM) Haskell/hapa
301N/A $(RM) Haskell/wrap
221N/A $(RM) Syntax/hetpa
219N/A $(RM) Static/hetana
301N/A $(RM) Static/hetana
219N/A $(RM) GUI/hetdg
219N/A $(RM) hetpa
301N/A $(RM) hetana
219N/A $(RM) hetdg
219N/A
219N/A### additonally removes *.d (dependency files) in every include directory
301N/A### also delete *.d.bak (dependency file backups)
219N/Ad_clean: clean
221N/A for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
32N/A (cd $$p ; $(RM) *.d *.d.bak) ; done
301N/A
235N/A### remove files also in own libraries
235N/Alib_clean: clean
235N/A for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
235N/A (cd $$p ; $(RM) *.hi *.d *.o) ; done
235N/A
236N/A### additionally removes the files that define the sources-variable
251N/Areal_clean: bin_clean lib_clean
236N/A $(RM) hetcats-make sources_hetcats.mk
235N/A
235N/A### additionally removes files not in CVS tree
222N/Adistclean: real_clean clean_genRules d_clean
235N/A $(RM) hetcats/Version.hs
301N/A $(RM) $(drifted_files)
301N/A $(RM) Haskell/Language/Parser.hs
301N/A
301N/A####################################################################
301N/A### test targets
301N/A####################################################################
301N/A
301N/A### a parser to test annotation parser and Id parsers
301N/Atest_parser: Common/test_parser
301N/A
301N/ACommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
301N/A $(RM) $@
301N/A $(HC) --make -o $@ $< $(HC_OPTS)
301N/A
301N/A### interactive
301N/Aghci:
301N/A $(HC)i $(HCI_OPTS)
301N/A
301N/A### christian's target
301N/A### CASL parser
235N/Acapa: CASL/capa
235N/A
235N/ACASL/capa: CASL/capa.lhs Common/*.hs CASL/*.hs
235N/A $(RM) $@
235N/A $(HC) --make -o $@ $< $(HC_OPTS)
222N/A
227N/A### HasCASL parser
235N/Ahacapa: HasCASL/hacapa
235N/A
227N/AHasCASL/hacapa: HasCASL/hacapa.lhs CASL/capa HasCASL/*.hs
227N/A $(RM) $@
227N/A $(HC) --make -o $@ $< $(HC_OPTS)
227N/A
235N/A### Haskell parser
235N/Ahapa: Haskell/hapa
235N/A
235N/AHaskell/hapa: Haskell/hapa.lhs Haskell/*.hs Haskell/Language/*.hs $(happy_files)
235N/A $(RM) $@
301N/A $(HC) --make -o $@ $< $(HC_OPTS)
235N/A
235N/A### Haskell wrap parser
222N/Awrap: Haskell/wrap
266N/A
266N/AHaskell/wrap: Haskell/wrap.lhs Haskell/*.hs
301N/A $(RM) $@
301N/A $(HC) --make -o $@ $< $(HC_OPTS)
301N/A
301N/A### HetCASL parser
301N/Ahetpa: Syntax/hetpa.hs Syntax/*.hs
301N/A $(RM) $@
222N/A $(HC) --make -o $@ $< $(HC_OPTS)
227N/A
222N/A### HetCASL parser
235N/Ahetana: Static/hetana.hs Static/*.hs
301N/A $(RM) $@
227N/A $(HC) --make -o $@ $< $(HC_OPTS)
301N/A
235N/A### ATC test system
235N/Aatctest: ATC/ATCTest.hs ATC/*.hs
235N/A $(RM) $@
235N/A $(HC) --make -o $@ $< $(HC_OPTS)
235N/A
227N/A
235N/A### HetCASL with dev graph
235N/Ahetdg: GUI/hetdg.hs $(drifted_files) *.hs
235N/A $(RM) $@
235N/A $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
235N/A
301N/A
227N/A### run tests in other directories
235N/Acheck: hetcats
235N/A for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
301N/A
301N/A####################################################################
235N/A## Preparing the version of HetCATS
227N/Ahetcats/Version.hs: hetcats/Version.in version_nr
235N/A $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
235N/A
235N/A## two hardcoded dependencies for a correct generation of Version.hs
301N/Ahetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
222N/Ahets.hs: hetcats/Version.hs
227N/A####################################################################
222N/A## rules for DrIFT
235N/A
227N/A%.hs: %.ly
227N/A $(HAPPY) $<
227N/A
222N/A#%.hs: %.ag.hs
222N/A# $(AG) $<
172N/A
172N/A%.hs: %.der.hs
172N/A $(DRIFT) $(DRIFT_OPTS) $< > $@
172N/A
172N/A#%.hs: %.ag
172N/A# $(AG) $< -o $@
172N/A
172N/A%.lhs: %.der.lhs
235N/A $(DRIFT) $< > $@
172N/A
242N/A## compiling rules for object and interface files
172N/A%.o %.hi: %.hs
172N/A $(HC) -c $< $(HC_OPTS)
172N/A
172N/A
172N/A%.o %.hi: %.lhs
172N/A $(HC) -c $< $(HC_OPTS)
235N/A
235N/A## compiling rules for dependencies
235N/A%.d : %.hs
172N/A $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
235N/A
235N/A%.d : %.lhs
235N/A $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
172N/A
172N/A####################################################################
172N/A## Setting a global search path (for dependency files)
235N/A
172N/Aifneq ($(MAKECMDGOALS),clean)
172N/Aifneq ($(MAKECMDGOALS),real_clean)
301N/Aifneq ($(MAKECMDGOALS),d_clean)
251N/Aifneq ($(MAKECMDGOALS),real_clean)
251N/Aifneq ($(MAKECMDGOALS),distclean)
251N/Aifneq ($(MAKECMDGOALS),genRules)
251N/Aifneq ($(MAKECMDGOALS),clean_genRules)
251N/Aifeq ($(MAKECMDGOALS),hets-old)
172N/A## include every .d file in INCLUDE_PATH
104N/A-include $(objects:.o=.d)
50N/Aendif
104N/A
32N/Asources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
104N/A $(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk
104N/Aendif
301N/Aendif
32N/Aendif
242N/Aendif
111N/Aendif
32N/Aendif
242N/Aendif
63N/A