Makefile revision 63f0e65a37b95621334db9ee4ba0cd9d826f5c0f
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# Makefile
25cc5fbba63f84b47e389af749f55abbbde71c8cChristian Maeder# $Header$
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2005
25cc5fbba63f84b47e389af749f55abbbde71c8cChristian Maeder# Year: 2004
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# This Makefile will compile the new hets system and provides also
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# targets for test programs during implementation phases.
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# !!! Note: This makefile is written for GNU make !!!
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# (gmake on solaris)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
d8c71aacc9f1c8cd40a8ad8dcdad9be8854b849fChristian Maederall: hets
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## Some varibles, which control the compilation
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus LuettichINCLUDE_PATH = ghc fgl hxt
a737caf82de97c1907027c03e4b4509eb492b4b8Christian MaederCOMMONLIB_PATH = Common/Lib Common/ATerm fgl/Data/Graph \
a737caf82de97c1907027c03e4b4509eb492b4b8Christian Maeder fgl/Data/Graph/Inductive fgl/Data/Graph/Inductive/Internal \
a737caf82de97c1907027c03e4b4509eb492b4b8Christian Maeder fgl/Data/Graph/Inductive/Monad fgl/Data/Graph/Inductive/Query
a737caf82de97c1907027c03e4b4509eb492b4b8Christian MaederCLEAN_PATH = . utils/DrIFT-src utils/GenerateRules utils/InlineAxioms Common \
473bc1f3f3443f18e0ee83e4642fab42183470f2Christian Maeder Logic CASL CASL/CCC Syntax Static GUI HasCASL Haskell Modal CoCASL COL \
473bc1f3f3443f18e0ee83e4642fab42183470f2Christian Maeder CspCASL ATC ToHaskell Proofs Comorphisms Isabelle Driver $(INCLUDE_PATH) \
473bc1f3f3443f18e0ee83e4642fab42183470f2Christian Maeder Haskell/Hatchet Hatchet Taxonomy $(PFE_PATHS)
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettich
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettich# the 'replacing spaces' example was taken from the (GNU) Make info manual
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettichempty =
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettichspace = $(empty) $(empty)
a737caf82de97c1907027c03e4b4509eb492b4b8Christian Maeder
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich## set ghc imports properly for your system
96646aed2ae087b942ae23f15bbe729a8f7c43d3Christian MaederGHC_IMPORTS = `$(HC) --print-libdir`/imports
01e383014b555bbcf639c0ca60c5810b3eff83c0Christian MaederDRIFT_ENV = \
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski DERIVEPATH=.:ghc:$(GHC_IMPORTS):$(subst $(space),:,$(PFE_PATHS))
df29370ae8d8b41587957f6bcdcb43a3f1927e47Christian Maeder
bd54a9917cd87169b8e40bcc5616c537fed85815Christian Maeder# override on commandline for other architectures
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus LuettichINSTALLDIR = \
a53841f6d6e86ac751c12a33dc8aadf53f59d977Klaus Luettich /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
8c7a54ad8bf776a530ecf907a373d42415cf4faeChristian Maeder
ce8b15da31cd181b7e90593cbbca98f47eda29d6Till MossakowskiDRIFT_deps = utils/DrIFT-src/*hs
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps) Common/Utils.hs
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs Common/ListUtils.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Common/Lib/Pretty.hs Common/Keywords.hs Common/Lib/Set.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Common/Lib/Map.hs Common/Lib/Rel.hs Common/Lib/State.hs Common/Id.hs \
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs CASL/ShowMixfix.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder CASL/Utils.hs Common/Lexer.hs Common/Token.hs Common/Anno_Parser.hs \
2e2094a642e3775b0d76b890556407941d3a53b6Christian Maeder Common/GlobalAnnotations.hs Common/PrettyPrint.hs \
2e2094a642e3775b0d76b890556407941d3a53b6Christian Maeder Common/Print_AS_Annotation.hs Common/PPUtils.hs CASL/LiteralFuns.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder CASL/Print_AS_Basic.hs Common/AnnoState.hs CASL/Formula.hs \
e8db9a65830cf71504e33c6f441a67b4d184a3caChristian Maeder CASL/OpItem.hs CASL/SortItem.hs Common/Result.hs \
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder Common/ConvertLiteral.hs Common/Earley.hs CASL/MixfixParser.hs \
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder CASL/Parse_AS_Basic.hs CASL/Sign.hs CASL/Overload.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder CASL/StaticAna.hs Modal/AS_Modal.hs Modal/Parse_AS.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus LuettichHC = ghc
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian MaederPERL = perl
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichHAPPY = happy -sgca
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichDRIFT = utils/DrIFT
4d56f2fa72e4aec20eb827c11ed49c8cbb7014bdChristian MaederINLINEAXIOMS = utils/outlineAxioms
4cb215739e9ab13447fa21162482ebe485b47455Christian MaederHADDOCK = haddock
8ef75f1cc0437656bf622cec5ac9e8ea221da8f2Christian MaederCPPP = cpp
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederHC_WARN = -Wall
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian MaederHC_FLAGS = $(HC_WARN) -fglasgow-exts -fno-monomorphism-restriction \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -fallow-overlapping-instances -fallow-undecidable-instances
55adfe57a4de1f36adc3e3bfc16f342e44a7d444Christian Maeder# -ddump-minimal-imports
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder# flags also come in via ../uni/uni-package.conf
8d97ef4f234681b11bb5924bd4d03adef858d2d2Christian Maeder# but added it here in case of compilation without uni
8d97ef4f234681b11bb5924bd4d03adef858d2d2Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederHC_INCLUDE = $(addprefix -i, $(INCLUDE_PATH))
e593b89bfd4952698dc37feced21cefe869d87a2Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederlogics = CASL HasCASL Modal CoCASL COL CspCASL Hatchet
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian MaederUNI_PACKAGE_CONF = $(wildcard ../uni/uni-package.conf)
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian Maederifneq ($(strip $(UNI_PACKAGE_CONF)),)
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian MaederHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian Maeder -package uni-server -DUNI_PACKAGE
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian Maeder
0206ab93ef846e4e0885996d052b9b73b9dc66b0Christian Maeder# some modules from uni for haddock
f13d1e86e58da53680e78043e8df182eed867efbChristian Maeder# if uni/server is included also HaXml sources are needed
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian Maederuni_dirs = ../uni/davinci ../uni/graphs ../uni/events \
96646aed2ae087b942ae23f15bbe729a8f7c43d3Christian Maeder ../uni/reactor ../uni/util ../uni/posixutil
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maederuni_sources = $(wildcard $(addsuffix /haddock/*.hs, $(uni_dirs))) \
c6fcd42c6d6d9dae8c7835c24fcb7ce8531a9050Christian Maeder $(wildcard ../uni/htk/haddock/*/*.hs)
31c49f2fa23d4ac089f35145d80a224deb6ea7e4Till Mossakowskiendif
c55a0f77be7e88d3620b419ec8961f4379a586e3Klaus Luettich
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus LuettichPFE_TOOLDIR = $(wildcard ../programatica/tools)
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettichifneq ($(strip $(PFE_TOOLDIR)),)
363939beade943a02b31004cea09dec34fa8a6d9Christian MaederPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder base/parse2/LexerGen base/parse2/LexerSpec base/tests/HbcLibraries \
8cacad2a09782249243b80985f28e9387019fe40Christian Maeder base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder base/transforms base/transforms/Deriving property \
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian Maeder property/syntax property/AST property/transforms \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder property/TI property/defs property/parse2 property/parse2/Parser
8a28707e9155465c6f2236a06eac6580a65c7025Christian Maeder
47b0e9f3cb008cb7997f4e3bae26e4d62dcc887aChristian MaederPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
431d34c7007a787331c4e5ec997badb0f8190fc7Christian Maederpfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederPFE_PATH = $(addprefix -i, $(PFE_PATHS))
d3ae0072823e2ef0d41d4431fcc768e66489c20eChristian MaederPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederhappy_files += $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederLEX_DIR = $(PFE_TOOLDIR)/base/parse2/Lexer
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder$(LEX_DIR)/HsLex.hs: $(LEX_DIR)Gen/HsLexerGen
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $< > $@
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(LEX_DIR)/HsTokens.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(HC) --make -O -package data \
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian Maeder -i$(PFE_TOOLDIR)/base/tests/HbcLibraries \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder -i$(PFE_TOOLDIR)/base/lib \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder $@.hs -o $@
776a1a086df734581431e6edb4343ed4c8d34d55Christian Maeder
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maederlogics += Haskell
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maederderived_sources += Haskell/PreludeString.hs $(LEX_DIR)/HsLex.hs \
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder $(LEX_DIR)Gen/HsLexerGen
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder Haskell/ProgramaticaPrelude.hs
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder## rule for appendHaskellPreludeString
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(APPENDPRELUDESTRING)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(APPENDPRELUDESTRING) < $< > $@
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian MaederAst_Haskell_files = HsDeclStruct HsExpStruct HsFieldsStruct \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder HsModule HsName HsLiteral HsIdent
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
0769e2a25732dc2544b2a7425dfa284e24d23b71Christian MaederOther_PFE_files = property/AST/HsPropStruct base/defs/PNT \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder base/defs/UniqueNames base/Modules/TypedIds base/TI/TiKinds \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder base/parse2/SourceNames base/syntax/SyntaxRec \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder property/syntax/PropSyntaxStruct
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
4017ebc0f692820736d796af3110c3b3018c108aChristian MaederHaskell_files = $(addsuffix .hs, \
ad4889ebb40efae8595b0969dd6ba1162d52bac3Christian Maeder $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder $(addprefix $(PFE_TOOLDIR)/, $(Other_PFE_files)))
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian Maeder## rule for ATC generation
6ff7a91875597d6e4dfaa68c79187d01473e8341Christian MaederHaskell/ATC_Haskell.der.hs: $(Haskell_files) utils/genRules
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(Haskell_files)
4017ebc0f692820736d796af3110c3b3018c108aChristian Maederendif
a9b59eb2ce961014974276cdae0e9df4419bd212Christian Maederhappy_files += Haskell/Hatchet/HsParser.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### Profiling (only for debugging)
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### Attention every module must be compiled with profiling or the linker
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### cannot link the various .o files properly. So after switching on
88318aafc287e92931dceffbb943d58a9310001dChristian Maeder### Profiling, do an 'gmake real_clean; gmake'
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder### and comment out HC_PACKAGE variable definition above.
a3c6d8e0670bf2aa71bc8e2a3b1f45d56dd65e4cChristian Maeder### Comment in the following line for switching on profiling.
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#HC_PROF = -prof -auto-all
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederHCI_OPTS = $(HC_FLAGS) $(HC_INCLUDE) $(HC_PACKAGE) $(PFE_FLAGS)
363939beade943a02b31004cea09dec34fa8a6d9Christian MaederHC_OPTS = $(HCI_OPTS) $(HC_PROF)
363939beade943a02b31004cea09dec34fa8a6d9Christian MaederDRIFT_OPTS = +RTS -K10m -RTS
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder### list of directories to run checks in
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederTESTDIRS = Common CASL HasCASL Haskell/Hatchet/examples ToHaskell
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder####################################################################
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder## sources for hets (semi - manually produced with a perl script)
b568982efd0997d877286faa592d81b03c8c67b8Christian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder#GHCMAKE_OUTPUT = $(wildcard hetcats-make)
0be0db405c49906bd7057255069bf6df53395ac9Klaus Luettich
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder#ifneq ($(strip $(GHCMAKE_OUTPUT)),)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#include sources_hetcats.mk
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#else
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maedernon_sources = Common/LaTeX_maps.svmono.hs CspCASL/Main.hs Logic/Morphism.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder Static/LogicStructured.hs Common/CaslLanguage.hs ./Test.hs
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian MaederSOURCE_PATHS = $(COMMONLIB_PATH) $(CLEAN_PATH)
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maedersources = hets.hs $(filter-out $(non_sources), \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(wildcard $(addsuffix /[A-Z]*hs, $(SOURCE_PATHS))))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder#endif
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederobjects = $(sources:%.hs=%.o)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(gendrifted_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maederatc_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder Common/AS_Annotation.der.hs \
89f7631cbfbd1bb99fc152b434bd362a7799d295Christian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder Static/DevGraph.hs Proofs/Proofs.hs Isabelle/IsaSign.hs
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder
363939beade943a02b31004cea09dec34fa8a6d9Christian Maederatc_der_files = $(foreach file, $(atc_files), \
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder ATC/$(basename $(basename $(notdir $(file)))).der.hs)
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCASL_files = CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder CASL/AS_Basic_CASL.der.hs
f4505a64a089693012a3f5c3b1f12a82cd7a2a5aKlaus Luettich
e7757995211bd395dc79d26fe017d99375f7d2a6Christian MaederHasCASL_files = HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
6b6773cf587b74259178641d811746a235faf056Christian Maeder HasCASL/Sublogic.hs \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
2c619a4dfdc1df27573eba98e81ed1ace906941dChristian MaederModal_files = Modal/AS_Modal.hs Modal/ModalSign.hs
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus LuettichCoCASL_files = CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCOL_files = COL/AS_COL.hs COL/COLSign.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCspCASL_files = CspCASL/AS_CSP_CASL.hs CspCASL/SignCSP.hs
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederHatchet_files = Haskell/Hatchet/AnnotatedHsSyn.hs \
d272062059eea4d7479e1c6e8517469f02f61287Christian Maeder Haskell/Hatchet/MultiModuleBasics.hs Haskell/Hatchet/HsSyn.hs \
7c5c311d67e187280877c45bd89dcba9038bc0a3Christian Maeder Haskell/Hatchet/Representation.hs Haskell/Hatchet/Class.hs \
7c5c311d67e187280877c45bd89dcba9038bc0a3Christian Maeder Haskell/Hatchet/KindInference.hs Haskell/Hatchet/Env.hs \
7c5c311d67e187280877c45bd89dcba9038bc0a3Christian Maeder Hatchet/HatParser.hs
7c5c311d67e187280877c45bd89dcba9038bc0a3Christian Maeder
7c5c311d67e187280877c45bd89dcba9038bc0a3Christian Maederatc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
7c5c311d67e187280877c45bd89dcba9038bc0a3Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergenerated_rule_files = $(atc_der_files) $(atc_logic_files)
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedergendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Comorphisms/Modal2CASL.hs Comorphisms/CASL2TopSort.hs
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs, $(inline_axiom_files))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederderived_sources += $(drifted_files) Driver/Version.hs $(happy_files) \
9df11f85fd7f8c4745d64464876e84ec4e263692Christian Maeder $(inline_axiom_files) Modal/ModalSystems.hs
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
010c56c4cf12dd7977ca36efe85219b91e265ee3Christian Maeder# sources that have {-# OPTIONS -cpp #-}
fb328c4f646dd3dd78a9391c5cb58450a3dd0aa9Klaus Luettichcpp_sources = Common/DFiniteMap.hs Common/DynamicUtils.hs \
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski Isabelle/Logic_Isabelle.hs \
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder Proofs/Proofs.hs hets.hs CASL/CCC/FreeTypes.hs \
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers Comorphisms/LogicList.hs Comorphisms/LogicGraph.hs $(happy_files)
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedernondoc_sources = $(wildcard utils/DrIFT-src/*.hs) \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(wildcard utils/DrIFT-src/*.lhs) \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder $(wildcard utils/GenerateRules/*.hs) \
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(wildcard utils/InlineAxioms/*.hs) \
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder $(cpp_sources) $(pfe_sources) $(gen_inline_axiom_files) \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(genrule_header_files) $(generated_rule_files) \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder Modal/GeneratePatterns.inline.hs \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder Haskell/PreludeString.append.hs Haskell/ProgramaticaPrelude.hs \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder hxt/HXT.hs hxt/Net.hs $(patsubst %.hs, %.der.hs, $(drifted_files))
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder# this variable holds the modules that should be documented
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maederdoc_sources = $(filter-out $(nondoc_sources), $(sources)) \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder $(patsubst %.hs, %.hspp, $(cpp_sources)) $(uni_sources)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedertax_sources = Taxonomy/AbstractGraphView.hs Taxonomy/MMiSSOntology.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder Taxonomy/MMiSSOntologyGraph.hs Taxonomy/OntoParser.hs
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maedertax_objects = $(patsubst %.hs, %.o, $(tax_sources))
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder####################################################################
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### targets
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder.PHONY : all hets-opt hets-optimized clean d_clean real_clean bin_clean \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder lib_clean distclean check capa hacapa h2h clean_genRules genRules \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder taxonomy count doc apache_doc post_doc4apache \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder derivedSources install_hets install release
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder#.PRECIOUS: sources_hetcats.mk
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### call run_hc with
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder# $(call run_hc,<command-that-compiles-hetc-with-ghc>)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder# and it generates hetcats-make
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder# iff there was no error during compilation
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederrun_hc = ($(1) 2>&1 || $(RM) hetcats-make) | tee hetcats-make
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederhets: $(sources) $(derived_sources)
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder $(call run_hc, $(HC) --make -o $@ hets.hs $(HC_OPTS))
6fe9628743562678acf97d6730ebcfee5e9e50c2Christian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maederhets-opt:
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(MAKE) distclean
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(MAKE) derivedSources
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski $(MAKE) real_clean
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder $(MAKE) hets-optimized
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederhets-optimized: $(derived_sources)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(call run_hc, $(HC) --make -O -o hets hets.hs $(HC_OPTS))
fb328c4f646dd3dd78a9391c5cb58450a3dd0aa9Klaus Luettich strip hets
fb328c4f646dd3dd78a9391c5cb58450a3dd0aa9Klaus Luettich
e96a0bf4040fd789339958c01f145c5057d26db6René Wagnerhets-old: $(objects)
e96a0bf4040fd789339958c01f145c5057d26db6René Wagner $(RM) $@
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich $(HC) -o hets $(HC_OPTS) $(objects)
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederhets.cgi: $(sources) GUI/hets_cgi.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_INCLUDE) \
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(HC_FLAGS) -O
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder strip hets.cgi
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
b9b960bc75e34658e70c4a0231dbc6a6e7373f2dChristian Maedertaxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
18a4d5cb6828f080db9c5f9551785c5151027271Christian Maeder $(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
0be0db405c49906bd7057255069bf6df53395ac9Klaus Luettich
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder###############################
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder### TAGS files for (x)emacs
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski# load them with "M-x" "visit-tags-table" from
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# "HetCATS/hetcats.TAGS"
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder# use "M-." to search for a tag
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski# !!Beware this is somewhat instable, because it uses an absolute path!!
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederhetcats.TAGS: $(sources)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
c9acb8681bcc512245b4f0d1a9f2b189c60e10d4Christian Maeder $(sources); mv TAGS $@; mv tags hetcats.tags
38352346eb1a67ba0f4eab8ad6f718528cf0cde0Christian Maeder
356fa49fe3e6a8398f92d13e9f920d0f093697ecChristian Maeder###############################
63e50b4c36074d5fb9de872c4007b688b4bce534Christian Maeder### count lines of code
63e50b4c36074d5fb9de872c4007b688b4bce534Christian Maedercount: $(sources)
bd54a9917cd87169b8e40bcc5616c537fed85815Christian Maeder wc -l $(sources)
11b55e6fbbc397b9fa41a7d61be53c6f4f027824Christian Maeder###############################
6d48df27e647ee84056df7985f09b60e1877bad6Christian Maeder### Documentation via haddock
11b55e6fbbc397b9fa41a7d61be53c6f4f027824Christian Maederdoc: docs/index.html
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder# generate haddock documentation with links to sources
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maederdocs/index.html: $(doc_sources)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(HADDOCK) $(doc_sources) -o docs -h -v \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder -i docs/base.haddock -i docs/parsec.haddock -s ../ \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -t 'hets -- a heterogenous Specification (CASL) tool set'
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# sources are not copied here
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederapache_doc:
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(RM) docs/*.*
6bf24e5eb644064ad650eb3fd9774483fccbf601Christian Maeder cvs up -d ; echo "CVS exited with: " $$?
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(MAKE) hets-opt
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(MAKE) doc
ffd3a0c7339cc3637f022c38e66a7aa9f0cf10d3Rainer Grabbe $(MAKE) post_doc4apache
e8db9a65830cf71504e33c6f441a67b4d184a3caChristian Maeder $(MAKE) o_clean
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(MAKE) hets.cgi
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maederpost_doc4apache:
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(PERL) utils/post_process_docs.pl docs \
6bf24e5eb644064ad650eb3fd9774483fccbf601Christian Maeder 'Common.Lib.Map.html:Common.Lib._Map.html'
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder cp docs/*.* a-docs/
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder###############################
53818ced114da21321063fff307aa41c1ab31dd3Achim Mahnke### release management
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
53818ced114da21321063fff307aa41c1ab31dd3Achim MahnkederivedSources: $(derived_sources)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederutils/DrIFT: $(DRIFT_deps)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich strip ../DrIFT)
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
f443a57f2a8e0ca3daa7431b0c89a18ba52c337aChristian Maederutils/genRules: $(GENERATERULES_deps)
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder (cd utils/GenerateRules; \
1f63599faaa311cd024d6413f82bff8caae8de24Christian Maeder $(HC) --make -i../DrIFT-src -i../.. $(HC_WARN) \
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maeder GenerateRules.hs -o ../genRules && strip ../genRules)
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowski
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich$(INLINEAXIOMS): $(INLINEAXIOMS_deps)
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs $(HC_WARN) \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder -i../.. -o $(INLINEAXIOMS)
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder strip $(INLINEAXIOMS)
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maederrelease:
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder $(RM) -r HetCATS
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository\
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder co -P HetCATS
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder $(RM) -r uni
0c355dd0b739631ee472f9a656e266be27fa4e64Christian Maeder if [ -d ../uni ] ; then ln -s ../uni uni ; fi
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder $(RM) -r programatica
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder if [ -d ../programatica ] ; then \
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maeder mkdir programatica; \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder ln -s ../../programatica/tools programatica/tools ; fi
b49276c9f50038e0bd499ad49f7bd6444566a834Christian Maeder (cd HetCATS; $(MAKE) derivedSources; \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(MAKE) clean; ./clean.sh; \
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich $(RM) clean.*; mv Makefile Makefile.orig; \
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich mv ReleaseMakefile Makefile)
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich tar cvf HetCATS.tar HetCATS
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettichinstall-hets:
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich chmod g+w hets
a883cd4d01fe39d23219cf5333425f195be24d8bChristian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
5c69cef4668bbd959d721668313a779126014d1eKlaus Luettich cp -p version_nr $(INSTALLDIR)
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich (cd $(INSTALLDIR); $(RM) hets; \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederinstall: hets-opt install-hets
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder#############################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### ATC DrIFT-rule generation
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaedergenRules: $(generated_rule_files)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich $(foreach file, $(atc_files), $(gen_atc_files))
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus LuettichCASL/ATC_CASL.der.hs: $(CASL_files) utils/genRules
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich utils/genRules -r $(rule) -o CASL $(CASL_files)
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus LuettichHasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) utils/genRules
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus LuettichModal/ATC_Modal.der.hs: $(Modal_files) utils/genRules
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich utils/genRules -r $(rule) -o Modal $(Modal_files)
c4ef79587a902327f36277c45a8d91d1e67bd6d5Klaus Luettich
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederCoCASL/ATC_CoCASL.der.hs: $(CoCASL_files) utils/genRules
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich
b905126bab9454b89041f92b3c50bb9efc85e427Klaus LuettichCOL/ATC_COL.der.hs: $(COL_files) utils/genRules
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich utils/genRules -r $(rule) -o COL $(COL_files)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian MaederCspCASL/ATC_CspCASL.der.hs: $(CspCASL_files) utils/genRules
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian MaederHatchet/ATC_Hatchet.der.hs: $(Hatchet_files) utils/genRules
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder utils/genRules -r $(rule) -o Hatchet -h ATC/Hatchet.header.hs \
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder $(Hatchet_files)
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder
68aab98a58d1460c77a1573a86c32a891756a420Christian Maederrule = ShATermConvertible
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maedergen_atc_files = \
96646aed2ae087b942ae23f15bbe729a8f7c43d3Christian Maeder if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; \
96646aed2ae087b942ae23f15bbe729a8f7c43d3Christian Maeder then utils/genRules -r $(rule) -o ATC -h \
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
3a7788e09dd23b364a46c9488cbd1522369113dbChristian Maeder else utils/genRules -r $(rule) -o ATC $(file); fi ;
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
ef67402074be14deb95e4ff564737d5593144130Klaus Luettichclean_genRules:
dbe752ee940baae7f9f231f29c62284bb0f90a25Christian Maeder $(RM) $(generated_rule_files) $(gendrifted_files)
ef67402074be14deb95e4ff564737d5593144130Klaus Luettich
462d9dc583444aab82732e14a75610684d2dc7e9Christian Maeder###############
c9e197862d9d8ef2585270dd08f5194b3aed4a9dKlaus Luettich### clean up
e7e1ab2ac3f1fded8611bb92ae00e8f3b8c693fbKlaus Luettich
ef67402074be14deb95e4ff564737d5593144130Klaus Luettichclean: bin_clean o_clean
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettich
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich### removes *.hi and *.o in all include directories
d784803f9c752667b4fcf7393d698002bedf3f89Klaus Luetticho_clean:
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettich for p in $(CLEAN_PATH) ; do \
1323eba62fc519b068f5aaec4f9d2be05ffabea9Klaus Luettich (cd $$p ; $(RM) *.hi *.o *.hspp) ; done
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder### remove binaries
462d9dc583444aab82732e14a75610684d2dc7e9Christian Maederbin_clean:
5d39c60274aaa76506292d2d9e885fccd27e1eabChristian Maeder $(RM) hets
5d39c60274aaa76506292d2d9e885fccd27e1eabChristian Maeder $(RM) test_parser
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder $(RM) CASL/capa
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) HasCASL/hacapa
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) Haskell/hapa
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) Haskell/hana
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) Haskell/wrap
1f8a7f8343f7df719768d2b1d7e3077ee291a1caChristian Maeder $(RM) ToHaskell/h2h
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) Syntax/hetpa
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich $(RM) Static/hetana
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich $(RM) GUI/hetdg
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(RM) hetpa
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) hetana
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich $(RM) hetdg
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) atctest2
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(RM) atctest
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(RM) Common/annos
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder $(RM) Haskell/Hatchet/hatch
f2d9352f2999f82c36b4b65535d14a6a40ae5a82Christian Maeder $(RM) ToHaskell/translateAna
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder $(RM) Taxonomy/taxonomyTool
43bb71dfe7ec405f563864d57c1cacdaa8ce9a80Christian Maeder
f2d9352f2999f82c36b4b65535d14a6a40ae5a82Christian Maeder### additonally removes *.d (dependency files) in every include directory
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder### also delete *.d.bak (dependency file backups)
fdb2d618144159395f7bf8ce3327b3c112a17dd3Till Mossakowskid_clean: clean
aa6c527682224a4e1434f80eae8bc2ef67fb6ca6Christian Maeder for p in $(CLEAN_PATH) ; do \
aa6c527682224a4e1434f80eae8bc2ef67fb6ca6Christian Maeder (cd $$p ; $(RM) *.d *.d.bak) ; done
37951dbd8e5f2418a07f072d9bf551d0c3a1eafcChristian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### remove files also in own libraries
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maederlib_clean:
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder for p in $(COMMONLIB_PATH) ; do \
aa6c527682224a4e1434f80eae8bc2ef67fb6ca6Christian Maeder (cd $$p ; $(RM) *.hi *.d *.o) ; done
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
c22d75ec3ea1306219d1c09a5b3e8ff04f753ad6Christian Maeder### additionally removes the files that define the sources-variable
9c3edf2b283c09d33b2820696886d1ed32fcadc8Christian Maederreal_clean: bin_clean lib_clean clean
c22d75ec3ea1306219d1c09a5b3e8ff04f753ad6Christian Maeder $(RM) hetcats-make sources_hetcats.mk
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
68b77966b2cf7bf2e340bf0fb6b9efc3e6a00467Christian Maeder### additionally removes files not in CVS tree
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maederdistclean: real_clean clean_genRules d_clean
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder $(RM) $(derived_sources)
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder $(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder####################################################################
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder### test targets
94d3aa05411444596b44ede4531f05dd7ac20fdfChristian Maeder####################################################################
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder### a parser to test annotation parser and Id parsers
ddc9315cc0b1f5dd3d8f99a77f1c75064db33b48Christian Maedertest_parser: Common/test_parser
ddc9315cc0b1f5dd3d8f99a77f1c75064db33b48Christian Maeder
5d522dff4d0fabf57dd476d4c3de15d354a89f62Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
5d522dff4d0fabf57dd476d4c3de15d354a89f62Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
5d522dff4d0fabf57dd476d4c3de15d354a89f62Christian Maeder
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder### interactive
8410667510a76409aca9bb24ff0eda0420088274Christian Maederghci:
8410667510a76409aca9bb24ff0eda0420088274Christian Maeder $(HC)i $(HCI_OPTS)
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder
e62d49c0dc2893da75faad896bd135e2e9a7087bKlaus Luettich### christian's target
e62d49c0dc2893da75faad896bd135e2e9a7087bKlaus Luettich### CASL parser
e62d49c0dc2893da75faad896bd135e2e9a7087bKlaus Luettichcapa: CASL/capa
e62d49c0dc2893da75faad896bd135e2e9a7087bKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### HasCASL parser
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettichhacapa: HasCASL/hacapa
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichHasCASL/hacapa: HasCASL/hacapa.hs Common/*.hs HasCASL/*.hs
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### Haskell analysis
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettichhana: Haskell/hana
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus LuettichHaskell/hana: Haskell/hana.hs Haskell/HatAna.hs Haskell/PreludeString.hs
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich### HasCASL to Haskell translation
ac43fa22d2d3f91a17674ac164cba3cf39a17795Klaus Luettichh2h: ToHaskell/h2h
ac43fa22d2d3f91a17674ac164cba3cf39a17795Klaus Luettich
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix ReckersToHaskell/h2h: ToHaskell/h2h.hs ToHaskell/*.hs Haskell/*.hs HasCASL/*.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### HetCASL parser
18c1d987ce5818ecf0bfc8af3f43aed2ce86e1eaChristian Maederhetpa: Syntax/hetpa.hs Syntax/*.hs
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
1c9a63e4f7c6879f51fe0f32154a9116f2c126dbChristian Maeder### HetCASL parser
6fe9628743562678acf97d6730ebcfee5e9e50c2Christian Maederhetana: Static/hetana.hs Static/*.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder### ATC test system
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederatctest: ATC/ATCTest.hs ATC/*.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
fb328c4f646dd3dd78a9391c5cb58450a3dd0aa9Klaus Luettich
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowskiatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs \
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski Common/Lib/*.hs
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski $(HC) --make -o $@ $< $(HC_OPTS)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### ATerm.Lib test system
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder Common/ATerm/*.hs Common/Lib/*.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### HetCASL with dev graph
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederhetdg: GUI/hetdg.hs $(drifted_files) *.hs
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(HC) --make -o $@ $< $(HC_OPTS)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder### run tests in other directories
e96a0bf4040fd789339958c01f145c5057d26db6René Wagnercheck:
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich####################################################################
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich## Preparing the version of HetCATS
abf2487c3aece95c371ea89ac64319370dcb6483Klaus LuettichDriver/Version.hs: Driver/Version.in version_nr
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettich $(PERL) utils/build_version.pl version_nr < Driver/Version.in > $@
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder## two hardcoded dependencies for a correct generation of Version.hs
83394c6b6e6de128e71b67c9251ed7a84485d082Christian MaederDriver/Options.hs Driver/WriteFn.hs Driver/ReadFn.hs: Driver/Version.hs
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maederhets.hs: Driver/Version.hs
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for DrIFT
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder.SUFFIXES:
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich%: %.hs
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich $(HC) --make -o $@ $<
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich%.hs: %.ly
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(HAPPY) $<
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.hs: %.y
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder $(HAPPY) -o $@ $<
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.hs: %.der.hs utils/DrIFT
d0652648f9879c67a194f8b03baafe2700c68eb4Christian Maeder ($(DRIFT_ENV); export DERIVEPATH; $(DRIFT) $(DRIFT_OPTS) $< > $@)
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for inlineAxioms
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder%.hs: %.inline.hs $(INLINEAXIOMS)
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(INLINEAXIOMS) $< > $@
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich## rule for cpp and haddock
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder%.hspp: %.hs
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettich $(HC) -E -cpp -DUNI_PACKAGE -optP -P $<
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder## compiling rules for object and interface files
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettich%.o %.hi: %.hs
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder $(HC) -c $< $(HC_OPTS)
c5e3fc166373b0d90f6e36e8aa234396a1dcd879Christian Maeder
340706b6c0c6e3dbacdd7003e20e9cab7f9aa765Christian Maeder%.o %.hi: %.lhs
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(HC) -c $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## compiling rules for dependencies
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.d : %.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.d : %.lhs
2c619a4dfdc1df27573eba98e81ed1ace906941dChristian Maeder $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
2c619a4dfdc1df27573eba98e81ed1ace906941dChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian MaederModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in \
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder utils/genTransMFormFunc.pl $(INLINEAXIOMS)
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder $(PERL) utils/genTransMFormFunc.pl $< $@
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# hetcats-make is created as side-effect of hets or hets-optimized
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maedersources_hetcats.mk: hetcats-make utils/create_sources.pl
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(PERL) utils/create_sources.pl hetcats-make sources_hetcats.mk
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder