Makefile revision e593b89bfd4952698dc37feced21cefe869d87a2
1185N/A# hetcats/Makefile
1185N/A# $Header$
1185N/A# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
1185N/A# Year: 2004
1185N/A
1185N/A# This Makefile will compile the new hetcats system and provides also
1185N/A# targets for test programs during implementation phases.
1185N/A
1185N/A# !!! Note: This makefile is written for GNU make !!!
1185N/A# (gmake on solaris ; make on linux)
1185N/A
1185N/A####################################################################
1185N/A## Some varibles, which control the compilation
1185N/A
1185N/AINCLUDE_PATH = ghc:hetcats
1185N/ACOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
1185N/ACLEAN_PATH = utils/DrIFT-src:utils/GenerateRules:Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:Isabelle:$(INCLUDE_PATH):Haskell/Hatchet
1185N/A## set ghc imports properly for your system
1220N/ALINUX_IMPORTS = $(wildcard /home/linux-bkb/ghc/ghc-latest/lib/ghc-*/imports)
1185N/ADRIFT_ENV = DERIVEPATH='.:ghc:hetcats:${LINUX_IMPORTS}:${GHC_IMPORTS}'
1185N/A
1458N/ADRIFT_deps = utils/DrIFT-src/*hs
1185N/AGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps)
1185N/AINLINEAXIOMS_deps = utils/InlineAxioms/*hs
1185N/A
1185N/AHC = ghc
1185N/APERL = perl
1185N/AHAPPY = happy
1185N/ADRIFT = $(DRIFT_ENV) utils/DrIFT
1185N/AINLINEAXIOMS = utils/outlineAxioms
1185N/AHADDOCK = haddock
1185N/A
1244N/AHC_FLAGS = -Wall
1244N/A# -fglasgow-exts comes in via ../uni/uni-package.conf
1185N/A
1198N/AHC_INCLUDE = -i$(INCLUDE_PATH)
1213N/AHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
1185N/A -package uni-server
1194N/A
1194N/A### Profiling and Warnings (only for debugging)
1185N/A### Attention every module must be compiled with profiling or the linker
1185N/A### cannot link the various .o files properly. So after switching on
1367N/A### Profiling, do an 'gmake clean; gmake'
1185N/A### If you need Profiling comment out the following line
1185N/A#HC_PROF = -prof -auto-all
1185N/A
1185N/AHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
1185N/AHC_OPTS = $(HCI_OPTS) $(HC_PROF)
1185N/ADRIFT_OPTS = +RTS -K10m -RTS
1185N/A
1185N/A### list of directories to run checks in
1470N/ATESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples
1185N/A
1185N/A
1185N/A####################################################################
1185N/A## sources for hetcats (semi - manually produced with a perl script)
1185N/A
1185N/Aifneq ($(MAKECMDGOALS),clean)
1194N/Aifneq ($(MAKECMDGOALS),bin_clean)
1185N/Aifneq ($(MAKECMDGOALS),d_clean)
1185N/Aifneq ($(MAKECMDGOALS),real_clean)
1190N/Aifneq ($(MAKECMDGOALS),distclean)
1367N/Aifneq ($(MAKECMDGOALS),genRules)
1367N/Aifneq ($(MAKECMDGOALS),utils/genRules)
1367N/Aifneq ($(MAKECMDGOALS),hets-opt)
1185N/Aifneq ($(MAKECMDGOALS),hets-optimized)
1190N/Aifneq ($(MAKECMDGOALS),derivedSources)
1190N/Aifneq ($(MAKECMDGOALS),utils/outlineAxioms)
1190N/Aifneq ($(MAKECMDGOALS),release)
1185N/Aifneq ($(MAKECMDGOALS),check)
1190N/Aifneq ($(MAKECMDGOALS),apache_doc)
1185N/Aifneq ($(MAKECMDGOALS),clean_genRules)
1185N/Aifneq ($(MAKECMDGOALS),atctest2)
1185N/Aifneq ($(MAKECMDGOALS),hetana)
1185N/Ainclude sources_hetcats.mk
1190N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1210N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1470N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/A
1185N/Aobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
1185N/A
1185N/Adrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
1185N/A Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
1185N/A $(gendrifted_files)
1185N/A
1185N/Agenrule_header_files = $(wildcard ATC/*.header.hs)
1213N/A
1185N/Agenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
1244N/A Common/AS_Annotation.der.hs \
1185N/A Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
1185N/A Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
1185N/A CASL/Sublogic.hs \
1211N/A CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
1211N/A HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
1185N/A Modal/AS_Modal.hs Modal/ModalSign.hs \
1190N/A CspCASL/AS_CSP_CASL.hs \
1185N/A Static/DevGraph.hs \
1190N/A Haskell/Hatchet/AnnotatedHsSyn.hs \
1185N/A Haskell/Hatchet/MultiModuleBasics.hs \
1185N/A Haskell/Hatchet/HsSyn.hs \
1185N/A Haskell/Hatchet/Representation.hs\
1185N/A Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
1185N/A Haskell/Hatchet/Env.hs \
1185N/A Isabelle/IsaSign.hs
1185N/A
1185N/Agendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
1185N/A ATC/AS_Library.hs ATC/GlobalAnnotations.hs \
1185N/A ATC/AS_Structured.hs ATC/AS_Architecture.hs \
1185N/A ATC/DevGraph.hs \
1185N/A CASL/ATC_CASL.hs Haskell/ATC_Haskell.hs \
1185N/A HasCASL/ATC_HasCASL.hs CspCASL/ATC_CspCASL.hs \
1190N/A Modal/ATC_Modal.hs ATC/IsaSign.hs
1185N/A
1185N/Agenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
1185N/A
1185N/Ainline_axiom_files = Comorphisms/CASL2PCFOL.hs
1185N/Agen_inline_axiom_files = $(patsubst %.hs,%.inline.hs,$(inline_axiom_files))
1185N/A
1185N/Ahappy_files = Haskell/Hatchet/HsParser.hs
1185N/A
1185N/A# this variable holds the modules that should be documented
1185N/A# the imported parsec library is not included!
1190N/Adoc_sources = $(filter-out ./Isabelle/IsaSign.hs ,$(sources))
1190N/A
1190N/A####################################################################
1185N/A### targets
1465N/A
1185N/A.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
1461N/A clean_genRules genRules
1185N/A
1185N/A.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
1388N/A#.PRECIOUS: sources_hetcats.mk
1185N/A
1185N/Aall: hets
1185N/A
1185N/Ahets: $(sources)
1388N/A $(HC) --make -o $@ hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
1212N/A
1185N/Ahets-opt: hetcats/Version.hs
1185N/A $(MAKE) distclean
1185N/A $(MAKE) derivedSources
1185N/A $(MAKE) hets-optimized
1185N/A
1185N/Ahets-optimized:
1185N/A $(HC) --make -O -o hets hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
1212N/A strip hets
1388N/A
1185N/Ahets-old: $(objects)
1185N/A $(RM) $@
1465N/A $(HC) -o hets $(HC_OPTS) $(objects)
1465N/A
1388N/Ahetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files) $(inline_axiom_files)
1388N/A $(RM) hetcats-make sources_hetcats.mk
1388N/A $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
1388N/A
1185N/A###############################
1388N/A### TAGS files for (x)emacs
1388N/A# load them with "M-x" "visit-tags-table" from
1185N/A# "HetCATS/hetcats/hetcats.TAGS"
1185N/A# use "M-." to search for a tag
1388N/A# !!Beware this is somewhat instable, because it uses an absolute path!!
1226N/Ahetcats.TAGS: $(sources)
1465N/A /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
1465N/A $(sources); mv TAGS $@; mv tags hetcats.tags
1465N/A
1465N/A###############################
1465N/A### Documentation via haddock
1465N/Adoc: docs/index.html
1465N/A
1465N/A# index for prelude is missing
1465N/Adocs/index.html: $(doc_sources)
1465N/A $(HADDOCK) $(doc_sources) -o docs -h \
1465N/A -i docs/base.haddock \
1469N/A -t 'hets -- a heterogenous Specification (CASL) tool set'
1465N/A
1465N/Aapache_doc:
1185N/A $(RM) docs/*.*
1465N/A cvs up -d
1465N/A $(MAKE) hets-opt
1465N/A $(MAKE) doc
1465N/A $(MAKE) post_doc4apache
1465N/A
1465N/Apost_doc4apache:
1465N/A $(PERL) utils/post_process_docs.pl docs \
1185N/A 'Common.Lib.Map.html:Common.Lib._Map.html'
1465N/A cp docs/*.* a-docs/
1465N/A $(RM) docs/index.html
1465N/A
1226N/A###############################
1226N/A### release management
1185N/A
1465N/AderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs $(inline_axiom_files)
1465N/A
1465N/Autils/DrIFT: $(DRIFT_deps)
1465N/A (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
1465N/A strip ../DrIFT)
1465N/A
1465N/Autils/genRules: $(GENERATERULES_deps)
1185N/A (cd utils/GenerateRules; \
1185N/A $(HC) --make '-i../..:../DrIFT-src' -package text GenerateRules.hs -o ../genRules && \
1465N/A strip ../genRules)
1465N/A
1465N/Autils/outlineAxioms: $(INLINEAXIOMS_deps)
1465N/A $(HC) --make utils/InlineAxioms/InlineAxioms.hs \
1465N/A $(HC_OPTS) -o utils/outlineAxioms
1465N/A strip utils/outlineAxioms
1465N/A
1465N/Arelease:
1465N/A $(RM) -r HetCATS
1465N/A cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
1465N/A $(RM) -r uni
1465N/A ln -s ../uni uni
1465N/A (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
1465N/A find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
1465N/A $(RM) clean.*; $(RM) Makefile; mv ReleaseMakefile Makefile)
1185N/A tar cvf HetCATS.tar HetCATS
1465N/A
1465N/A#############################
1465N/A### ATC DrIFT-rule generation
1465N/A
1465N/AgenRules: $(generated_rule_files) utils/genRules
1185N/A
1465N/A$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
1185N/A $(MAKE) clean_genRules
1465N/A $(foreach file,$(atc_files),$(gen_atc_files))
1465N/A utils/genRules -r $(rule) -o CASL $(casl_files)
1465N/A utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs \
1465N/A $(hascasl_files)
1465N/A utils/genRules -r $(rule) -o Modal $(modal_files)
1465N/A utils/genRules -r $(rule) -o CspCASL $(cspcasl_files)
1465N/A utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
1465N/A $(haskell_files)
1465N/A
1185N/Arule = ShATermConvertible
1465N/A
1465N/Agen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
1469N/A utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
1465N/A else \
1465N/A utils/genRules -r $(rule) -o ATC $(file); \
1465N/A fi ;
1465N/A
1465N/Aatc_files := $(filter-out CASL/% HasCASL/% Modal/% CspCASL/% Haskell/% ,$(genrule_files))
1465N/Acasl_files := $(filter CASL/% ,$(genrule_files))
1185N/Ahascasl_files := $(filter HasCASL/% ,$(genrule_files))
1185N/Amodal_files := $(filter Modal/% ,$(genrule_files))
1185N/Acspcasl_files := $(filter CspCASL/% ,$(genrule_files))
1185N/Ahaskell_files := $(filter Haskell/%,$(genrule_files))
1185N/A
1185N/Aclean_genRules:
1185N/A $(RM) $(generated_rule_files)
1185N/A
1185N/A###############
1185N/A### clean up
1185N/A
1185N/A### removes *.hi and *.o in all include directories
1185N/Aclean: bin_clean
1185N/A for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
1185N/A (cd $$p ; $(RM) *.hi *.o) ; done
1185N/A
1185N/A### remove binaries
1190N/Abin_clean:
1190N/A $(RM) hets
1190N/A $(RM) test_parser
1185N/A $(RM) CASL/capa
1185N/A $(RM) HasCASL/hacapa
1185N/A $(RM) Haskell/hapa
1185N/A $(RM) Haskell/wrap
1185N/A $(RM) Syntax/hetpa
1185N/A $(RM) Static/hetana
1185N/A $(RM) Static/hetana
1226N/A $(RM) GUI/hetdg
1185N/A $(RM) hetpa
1190N/A $(RM) hetana
1185N/A $(RM) hetdg
1190N/A $(RM) atctest2
1190N/A $(RM) atctest
1226N/A $(RM) Common/annos
1190N/A
1185N/A### additonally removes *.d (dependency files) in every include directory
1474N/A### also delete *.d.bak (dependency file backups)
1185N/Ad_clean: clean
1185N/A for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
1474N/A (cd $$p ; $(RM) *.d *.d.bak) ; done
1474N/A
1185N/A### remove files also in own libraries
1185N/Alib_clean: clean
1473N/A for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
1473N/A (cd $$p ; $(RM) *.hi *.d *.o) ; done
1473N/A
1473N/A### additionally removes the files that define the sources-variable
1473N/Areal_clean: bin_clean lib_clean
1473N/A $(RM) hetcats-make sources_hetcats.mk
1473N/A
1473N/A### additionally removes files not in CVS tree
1473N/Adistclean: real_clean clean_genRules d_clean
1473N/A $(RM) hetcats/Version.hs
1466N/A $(RM) $(drifted_files)
1466N/A $(RM) utils/DrIFT utils/genRules
1474N/A# $(RM) $(happy_files)
1474N/A
1474N/A####################################################################
1474N/A### test targets
1474N/A####################################################################
1474N/A
1474N/A### a parser to test annotation parser and Id parsers
1474N/Atest_parser: Common/test_parser
1474N/A
1474N/ACommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
1474N/A $(RM) $@
1474N/A $(HC) --make -o $@ $< $(HC_OPTS)
1474N/A
1185N/A### interactive
1475N/Aghci:
1475N/A $(HC)i $(HCI_OPTS)
1475N/A
1185N/A### christian's target
1474N/A### CASL parser
1474N/Acapa: CASL/capa
1474N/A
1474N/ACASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
1477N/A $(RM) $@
1477N/A $(HC) --make -o $@ $< $(HC_OPTS)
1477N/A
1474N/A### HasCASL parser
1474N/Ahacapa: HasCASL/hacapa
1474N/A
1185N/AHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
1185N/A $(RM) $@
1185N/A $(HC) --make -o $@ $< $(HC_OPTS)
1466N/A
1474N/A### Haskell parser
1474N/Ahapa: Haskell/hapa
1474N/A
1474N/AHaskell/hapa: Haskell/hapa.hs Haskell/Hatchet/*.hs $(happy_files)
1474N/A $(RM) $@
1474N/A $(HC) --make -o $@ $< $(HC_OPTS)
1474N/A
1226N/A### HetCASL parser
1185N/Ahetpa: Syntax/hetpa.hs Syntax/*.hs
1185N/A $(RM) $@
1185N/A $(HC) --make -o $@ $< $(HC_OPTS)
1185N/A
1185N/A### HetCASL parser
1185N/Ahetana: Static/hetana.hs Static/*.hs
1185N/A $(RM) $@
1185N/A $(HC) --make -o $@ $< $(HC_OPTS)
1185N/A
1243N/A### ATC test system
1244N/Aatctest: ATC/ATCTest.hs ATC/*.hs
1243N/A $(RM) $@
1245N/A $(HC) --make -o $@ $< $(HC_OPTS)
1185N/A
1185N/Aatctest2: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs Common/ATerm/*.hs Common/Lib/*.hs
1185N/A $(RM) $@
1244N/A $(HC) --make -o $@ $< $(HC_OPTS)
1243N/A
1244N/A### ATerm.Lib test system
1185N/Aatermlibtest: Common/ATerm/ATermLibTest.hs Common/ATerm/*.hs Common/SimpPretty.hs
1244N/A $(RM) $@
1243N/A $(HC) --make -o $@ $< $(HC_OPTS)
1244N/A
1244N/A### HetCASL with dev graph
1244N/Ahetdg: GUI/hetdg.hs $(drifted_files) *.hs
1245N/A $(RM) $@
1244N/A $(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
1244N/A
1185N/A
1185N/A### run tests in other directories
1243N/Acheck: hetcats
1185N/A for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
1185N/A
1185N/A####################################################################
1185N/A## Preparing the version of HetCATS
1185N/Ahetcats/Version.hs: hetcats/Version.in version_nr
1185N/A $(PERL) utils/build_version.pl version_nr < hetcats/Version.in > $@
1185N/A
1185N/A## two hardcoded dependencies for a correct generation of Version.hs
1185N/Ahetcats/Options.hs hetcats/WriteFn.hs hetcats/ReadFn.hs: hetcats/Version.hs
1185N/Ahets.hs: hetcats/Version.hs
1185N/A####################################################################
1185N/A## rules for DrIFT
1190N/A
1185N/A%.hs: %.ly
1185N/A $(HAPPY) $<
1185N/A
1185N/A%.hs: %.der.hs utils/DrIFT
1185N/A $(DRIFT) $(DRIFT_OPTS) $< > $@
1185N/A
1185N/A## rules for inlineAxioms
1185N/A%.hs: %.inline.hs utils/outlineAxioms
1185N/A $(INLINEAXIOMS) $< > $@
1185N/A
1185N/A## compiling rules for object and interface files
1185N/A%.o %.hi: %.hs
1185N/A $(HC) -c $< $(HC_OPTS)
1185N/A
1185N/A%.o %.hi: %.lhs
1185N/A $(HC) -c $< $(HC_OPTS)
1185N/A
1185N/A## compiling rules for dependencies
1185N/A%.d : %.hs
1185N/A $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
1185N/A
1185N/A%.d : %.lhs
1185N/A $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
1185N/A
1185N/A####################################################################
1185N/A## Setting a global search path (for dependency files)
1185N/A
1210N/Aifneq ($(MAKECMDGOALS),clean)
1185N/Aifneq ($(MAKECMDGOALS),real_clean)
1185N/Aifneq ($(MAKECMDGOALS),d_clean)
1185N/Aifneq ($(MAKECMDGOALS),real_clean)
1185N/Aifneq ($(MAKECMDGOALS),distclean)
1185N/Aifneq ($(MAKECMDGOALS),genRules)
1210N/Aifneq ($(MAKECMDGOALS),utils/genRules)
1185N/Aifneq ($(MAKECMDGOALS),derivedSources)
1185N/Aifneq ($(MAKECMDGOALS),release)
1327N/Aifneq ($(MAKECMDGOALS),clean_genRules)
1327N/Aifeq ($(MAKECMDGOALS),hets-old)
1185N/A## include every .d file in INCLUDE_PATH
1185N/A-include $(objects:.o=.d)
1210N/Aendif
1185N/A
1185N/Asources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
1185N/A $(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1185N/Aendif
1190N/A