Makefile revision d4892fa7401ceef014ea59d2d900773eaf88fcbd
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2005
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# This Makefile will compile the new hets 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)
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder####################################################################
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder## Some varibles, which control the compilation
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederCOMMONLIB_PATH = Common/Lib Common/ATerm fgl/Data/Graph \
a1ed34933c266ce85066acb0d7b20c90cb8eb213Christian Maeder fgl/Data/Graph/Inductive fgl/Data/Graph/Inductive/Internal \
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder fgl/Data/Graph/Inductive/Monad fgl/Data/Graph/Inductive/Query
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus LuettichCLEAN_PATH = . utils/DrIFT-src utils/GenerateRules utils/InlineAxioms Common \
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder Logic CASL CASL/CCC Syntax Static GUI HasCASL Haskell Modal CoCASL COL \
ad270004874ce1d0697fb30d7309f180553bb315Christian Maeder CspCASL ATC ToHaskell Proofs Comorphisms Isabelle Driver $(INCLUDE_PATH) \
4d56f2fa72e4aec20eb827c11ed49c8cbb7014bdChristian Maeder Haskell/Hatchet Hatchet Taxonomy $(PFE_PATHS)
8ef75f1cc0437656bf622cec5ac9e8ea221da8f2Christian Maeder# the 'replacing spaces' example was taken from the (GNU) Make info manual
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder## set ghc imports properly for your system
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian MaederGHC_IMPORTS = `$(HC) --print-libdir`/imports
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder DERIVEPATH=.:ghc:$(GHC_IMPORTS):$(subst $(space),:,$(PFE_PATHS))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# override on commandline for other architectures
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
1aee4aaddde105264c1faf394d88e302c05094ffChristian MaederGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps) Common/Utils.hs
1aee4aaddde105264c1faf394d88e302c05094ffChristian MaederINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs Common/ListUtils.hs \
51d769d55d88dfa88bdf54bee78d8fa85a2deba8Christian Maeder Common/Lib/Pretty.hs Common/Keywords.hs Common/Lib/Set.hs \
f041c9a6bda23de33a38490e35b831ae18d96b45Christian Maeder Common/Lib/Map.hs Common/Lib/Rel.hs Common/Lib/State.hs Common/Id.hs \
7cc09dd93962a2155c34d209d1d4cd7d7b838264Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs CASL/ShowMixfix.hs \
51d769d55d88dfa88bdf54bee78d8fa85a2deba8Christian Maeder CASL/Utils.hs Common/Lexer.hs Common/Token.hs Common/Anno_Parser.hs \
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder Common/GlobalAnnotations.hs Common/PrettyPrint.hs \
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder Common/Print_AS_Annotation.hs Common/PPUtils.hs CASL/LiteralFuns.hs \
c3053d57f642ca507cdf79512e604437c4546cb9Christian Maeder CASL/Print_AS_Basic.hs Common/AnnoState.hs CASL/Formula.hs \
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder CASL/OpItem.hs CASL/SortItem.hs CASL/Inject.hs Common/Result.hs \
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian Maeder Common/ConvertLiteral.hs Common/Earley.hs CASL/MixfixParser.hs \
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian Maeder CASL/Parse_AS_Basic.hs CASL/Sign.hs CASL/Overload.hs \
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder CASL/StaticAna.hs Modal/AS_Modal.hs Modal/Parse_AS.hs \
05a62e84edac8c64de04f8349dee418598d216b9Christian Maeder Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian MaederHC_FLAGS = $(HC_WARN) -fglasgow-exts -fno-monomorphism-restriction \
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder -fallow-overlapping-instances -fallow-undecidable-instances
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder# -ddump-minimal-imports
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder# flags also come in via ../uni/uni-package.conf
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian Maeder# but added it here in case of compilation without uni
014dc30f64ec25e4790cca987d4d1e6635430510Christian MaederHC_INCLUDE = $(addprefix -i, $(INCLUDE_PATH))
6aea82c63ba1d2efc0329bc784a14e521469ec20Christian Maederlogics = CASL HasCASL Modal CoCASL COL CspCASL Hatchet
431d34c7007a787331c4e5ec997badb0f8190fc7Christian MaederUNI_PACKAGE_CONF = $(wildcard ../uni/uni-package.conf)
498aa48bdb931ab50990d3b74318a5db2312186cChristian MaederHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder# some modules from uni for haddock
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder# if uni/server is included also HaXml sources are needed
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederuni_dirs = ../uni/davinci ../uni/graphs ../uni/events \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder ../uni/reactor ../uni/util ../uni/posixutil
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederuni_sources = $(wildcard $(addsuffix /haddock/*.hs, $(uni_dirs))) \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederPFE_TOOLDIR = $(wildcard ../programatica/tools)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder base/parse2/LexerGen base/parse2/LexerSpec base/tests/HbcLibraries \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder base/transforms base/transforms/Deriving property \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder property/syntax property/AST property/transforms \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder property/TI property/defs property/parse2 property/parse2/Parser
a5e5b8c3e5c11177e5034ef2423813a5d28979edChristian MaederPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
bc8cbf12aa172bf5673b92a9e7a0151d4aa4c315Christian Maederpfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
2d130d212db7208777ca896a7ecad619a8944971Christian MaederPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
51d769d55d88dfa88bdf54bee78d8fa85a2deba8Christian Maederhappy_files += $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder$(LEX_DIR)/HsLex.hs: $(LEX_DIR)Gen/HsLexerGen
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maederderived_sources += Haskell/PreludeString.hs $(LEX_DIR)/HsLex.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian MaederAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder## rule for appendHaskellPreludeString
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederAst_Haskell_files = HsDeclStruct HsExpStruct HsFieldsStruct \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
0be0db405c49906bd7057255069bf6df53395ac9Klaus LuettichOther_PFE_files = property/AST/HsPropStruct base/defs/PNT \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder base/defs/UniqueNames base/Modules/TypedIds base/TI/TiKinds \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder base/parse2/SourceNames base/syntax/SyntaxRec \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder $(addprefix $(PFE_TOOLDIR)/, $(Other_PFE_files)))
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder## rule for ATC generation
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian MaederHaskell/ATC_Haskell.der.hs: $(Haskell_files) utils/genRules
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder### Profiling (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
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder### Profiling, do an 'gmake real_clean; gmake'
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder### and comment out HC_PACKAGE variable definition above.
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### Comment in the following line for switching on profiling.
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder#HC_PROF = -prof -auto-all
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian MaederHCI_OPTS = $(HC_FLAGS) $(HC_INCLUDE) $(HC_PACKAGE) $(PFE_FLAGS)
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder### list of directories to run checks in
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian MaederTESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder####################################################################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## sources for hets (semi - manually produced with a perl script)
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder#GHCMAKE_OUTPUT = $(wildcard hetcats-make)
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder#ifneq ($(strip $(GHCMAKE_OUTPUT)),)
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maedernon_sources = Common/LaTeX_maps.svmono.hs CspCASL/Main.hs Logic/Morphism.hs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder Static/LogicStructured.hs Common/CaslLanguage.hs ./Test.hs
0e5b095a19790411e5352fa7cf57cb0388e70472Christian MaederSOURCE_PATHS = $(COMMONLIB_PATH) $(CLEAN_PATH)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maedersources = hets.hs $(filter-out $(non_sources), \
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder $(wildcard $(addsuffix /[A-Z]*hs, $(SOURCE_PATHS))))
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
06dd4e7c29f33f6122a910719e3bd9062256e397Andy Gimblettgenrule_header_files = $(wildcard ATC/*.header.hs)
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maederatc_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Static/DevGraph.hs Proofs/Proofs.hs Isabelle/IsaSign.hs
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maederatc_der_files = $(foreach file, $(atc_files), \
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder ATC/$(basename $(basename $(notdir $(file)))).der.hs)
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian MaederCASL_files = CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
9e748851c150e1022fb952bab3315e869aaf0214Christian MaederHasCASL_files = HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederModal_files = Modal/AS_Modal.hs Modal/ModalSign.hs
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian MaederCoCASL_files = CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian MaederCspCASL_files = CspCASL/AS_CSP_CASL.hs CspCASL/SignCSP.hs
aded505f9b42cc38975559c2a5d175ae95de436bChristian MaederHatchet_files = Haskell/Hatchet/AnnotatedHsSyn.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Haskell/Hatchet/MultiModuleBasics.hs Haskell/Hatchet/HsSyn.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Haskell/Hatchet/Representation.hs Haskell/Hatchet/Class.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Haskell/Hatchet/KindInference.hs Haskell/Hatchet/Env.hs \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maederatc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maedergenerated_rule_files = $(atc_der_files) $(atc_logic_files)
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maedergendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder Comorphisms/Modal2CASL.hs Comorphisms/CASL2TopSort.hs
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs, $(inline_axiom_files))
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maederderived_sources += $(drifted_files) Driver/Version.hs $(happy_files) \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder $(inline_axiom_files) Modal/ModalSystems.hs
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian Maeder# sources that have {-# OPTIONS -cpp #-}
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maedercpp_sources = Common/DFiniteMap.hs Common/DynamicUtils.hs \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder Proofs/Proofs.hs hets.hs CASL/CCC/FreeTypes.hs \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder Comorphisms/LogicList.hs Comorphisms/LogicGraph.hs $(happy_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedernondoc_sources = $(wildcard utils/DrIFT-src/*.hs) \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder $(cpp_sources) $(pfe_sources) $(gen_inline_axiom_files) \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(genrule_header_files) $(generated_rule_files) \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder Haskell/PreludeString.append.hs Haskell/ProgramaticaPrelude.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder hxt/HXT.hs hxt/Net.hs $(patsubst %.hs, %.der.hs, $(drifted_files))
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder# this variable holds the modules that should be documented
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederdoc_sources = $(filter-out $(nondoc_sources), $(sources)) \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(patsubst %.hs, %.hspp, $(cpp_sources)) $(uni_sources)
80c2d23821d095b55d9a547f48fc3fcdc27df405Christian Maedertax_sources = Taxonomy/AbstractGraphView.hs Taxonomy/MMiSSOntology.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Taxonomy/MMiSSOntologyGraph.hs Taxonomy/OntoParser.hs
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maedertax_objects = $(patsubst %.hs, %.o, $(tax_sources))
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maeder####################################################################
986d3f255182539098a97ac86da9eeee5b7a72e3Christian Maeder.PHONY : all hets-opt hets-optimized clean d_clean real_clean bin_clean \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder lib_clean distclean check capa hacapa h2h clean_genRules genRules \
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder taxonomy count doc apache_doc post_doc4apache \
5ad5dffe06818a13e1632b1119fbca7881085fc1Dominik Luecke.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder### call run_hc with
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke# $(call run_hc,<command-that-compiles-hetc-with-ghc>)
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke# and it generates hetcats-make
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# iff there was no error during compilation
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maederrun_hc = ($(1) 2>&1 || $(RM) hetcats-make) | tee hetcats-make
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski $(call run_hc, $(HC) --make -o $@ hets.hs $(HC_OPTS))
247cc88aa55d0a7b6831767cd593ea885c6747a0Christian Maeder $(call run_hc, $(HC) --make -O -o hets hets.hs $(HC_OPTS))
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maeder ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maeder -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_INCLUDE) \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maedertaxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### TAGS files for (x)emacs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# load them with "M-x" "visit-tags-table" from
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# use "M-." to search for a tag
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### count lines of code
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Documentation via haddock
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# generate haddock documentation with links to sources
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder -i docs/base.haddock -i docs/parsec.haddock -s ../ \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# sources are not copied here
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### release management
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder $(HC) --make -i../DrIFT-src -i../.. $(HC_WARN) \
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder GenerateRules.hs -o ../genRules && strip ../genRules)
c70ef4c3b3a62764f715510c9fd67dde3acfe454Christian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs $(HC_WARN) \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository\
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder if [ -d ../uni ] ; then ln -s ../uni uni ; fi
2b33802ca26124644f4311db4319376ecffdc8d2Christian Maeder if [ -d ../programatica ] ; then \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ln -s ../../programatica/tools programatica/tools ; fi
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder $(RM) clean.*; mv Makefile Makefile.orig; \
1aee4aaddde105264c1faf394d88e302c05094ffChristian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
e284004f10a315dbdb624c8b2522f65d485eaa48Martin Kühl ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder#############################
dcbd32289a7bdf1e6edd06c6ab0698c6a9dbf37aChristian Maeder### ATC DrIFT-rule generation
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder $(foreach file, $(atc_files), $(gen_atc_files))
10883d13973c46cac98964b66ace7a52b2d059abChristian MaederCASL/ATC_CASL.der.hs: $(CASL_files) utils/genRules
10883d13973c46cac98964b66ace7a52b2d059abChristian Maeder utils/genRules -r $(rule) -o CASL $(CASL_files)
10883d13973c46cac98964b66ace7a52b2d059abChristian MaederHasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) utils/genRules
10883d13973c46cac98964b66ace7a52b2d059abChristian Maeder utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
bf25e8c286cda74ef89a9cbc3c2143557e0d49c3Christian MaederModal/ATC_Modal.der.hs: $(Modal_files) utils/genRules
10883d13973c46cac98964b66ace7a52b2d059abChristian Maeder utils/genRules -r $(rule) -o Modal $(Modal_files)
10883d13973c46cac98964b66ace7a52b2d059abChristian MaederCoCASL/ATC_CoCASL.der.hs: $(CoCASL_files) utils/genRules
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian MaederCOL/ATC_COL.der.hs: $(COL_files) utils/genRules
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder utils/genRules -r $(rule) -o COL $(COL_files)
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian MaederCspCASL/ATC_CspCASL.der.hs: $(CspCASL_files) utils/genRules
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian MaederHatchet/ATC_Hatchet.der.hs: $(Hatchet_files) utils/genRules
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder utils/genRules -r $(rule) -o Hatchet -h ATC/Hatchet.header.hs \
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; \
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich else utils/genRules -r $(rule) -o ATC $(file); fi ;
5818d884784339c1b8aa6c6d972bad4eafd36ccbKlaus Luettich $(RM) $(generated_rule_files) $(gendrifted_files)
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich###############
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### removes *.hi and *.o in all include directories
e112e83352048f3db8c8f93ae104193e7338c10fChristian Maeder### remove binaries
1dfba1f850f6a43094962b459998d1ea11472461Christian Maeder### additonally removes *.d (dependency files) in every include directory
1dfba1f850f6a43094962b459998d1ea11472461Christian Maeder### also delete *.d.bak (dependency file backups)
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maeder### remove files also in own libraries
c22d75ec3ea1306219d1c09a5b3e8ff04f753ad6Christian Maeder### additionally removes the files that define the sources-variable
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder### additionally removes files not in CVS tree
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maederdistclean: real_clean clean_genRules d_clean
c59d1c38ef94b4fb1c8d9fda9573bc1e1d2801e7Christian Maeder $(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maeder####################################################################
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### test targets
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder####################################################################
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### a parser to test annotation parser and Id parsers
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### interactive
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### christian's target
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### CASL parser
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich### HasCASL parser
5f0e3e4cb7dd31033c9682cafa712d2a66b2f3bcChristian MaederHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder### Haskell analysis
d0652648f9879c67a194f8b03baafe2700c68eb4Christian MaederHaskell/hana: Haskell/hana.hs Haskell/HatAna.hs Haskell/PreludeString.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### HasCASL to Haskell translation
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichToHaskell/h2h: ToHaskell/h2h.hs ToHaskell/*.hs Haskell/*.hs HasCASL/*.hs
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettich### HetCASL parser
2d130d212db7208777ca896a7ecad619a8944971Christian Maeder### HetCASL parser
68d10d143f29fcff3c637ba24f90e983995ceae6Christian Maeder### ATC test system
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettichatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs \
e284004f10a315dbdb624c8b2522f65d485eaa48Martin Kühl### HetCASL with dev graph
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### run tests in other directories
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maeder####################################################################
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maeder## Preparing the version of HetCATS
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederDriver/Version.hs: Driver/Version.in version_nr
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(PERL) utils/build_version.pl version_nr < Driver/Version.in > $@
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## two hardcoded dependencies for a correct generation of Version.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederDriver/Options.hs Driver/WriteFn.hs Driver/ReadFn.hs: Driver/Version.hs
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski####################################################################
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski## rules for DrIFT
47b0e9f3cb008cb7997f4e3bae26e4d62dcc887aChristian Maeder ($(DRIFT_ENV); export DERIVEPATH; $(DRIFT) $(DRIFT_OPTS) $< > $@)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for inlineAxioms
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maeder## rule for cpp and haddock
d5d349836d8b1fa93ea49a59d977b106c6e9233bKlaus Luettich## compiling rules for object and interface files
9096f6c6aaded6cd8288656ceccd4c7b3bd0747eChristian Maeder## compiling rules for dependencies
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
e112e83352048f3db8c8f93ae104193e7338c10fChristian MaederModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# hetcats-make is created as side-effect of hets or hets-optimized
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maedersources_hetcats.mk: hetcats-make utils/create_sources.pl