Makefile revision 4d56f2fa72e4aec20eb827c11ed49c8cbb7014bd
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# Makefile
c63ebf815c8a874525cf18670ad74847f7fc7b26Christian Maeder# $Header$
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2005
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# Year: 2004
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# This Makefile will compile the new hets system and provides also
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# targets for test programs during implementation phases.
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder# !!! Note: This makefile is written for GNU make !!!
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder# (gmake on solaris)
f4a2a20e49f41b2afa657e5e64d9e349c7faa091Christian Maeder
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian Maederall: hets
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder####################################################################
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder## Some varibles, which control the compilation
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederINCLUDE_PATH = ghc fgl hxt
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) \
404166b9366552e9ec5abb87a37c76ec8a815fb7Klaus Luettich Haskell/Hatchet Hatchet Taxonomy $(PFE_PATHS)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder# the 'replacing spaces' example was taken from the (GNU) Make info manual
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maederempty =
ef9e8535c168d3f774d9e74368a2317a9eda5826Christian Maederspace = $(empty) $(empty)
bab2d88d650448628730ed3b65c9f99c52500e8cChristian Maeder
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder## set ghc imports properly for your system
ef9e8535c168d3f774d9e74368a2317a9eda5826Christian MaederGHC_IMPORTS = `$(HC) --print-libdir`/imports
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederDRIFT_ENV = \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder DERIVEPATH=.:ghc:$(GHC_IMPORTS):$(subst $(space),:,$(PFE_PATHS))
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder# override on commandline for other architectures
3dde4051c307b609159a097f08a05108fdd036efJonathan von SchroederINSTALLDIR = \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder /home/www/agbkb/forschung/formal_methods/CoFI/hets/`utils/sysname.sh`
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder
3dde4051c307b609159a097f08a05108fdd036efJonathan von SchroederDRIFT_deps = utils/DrIFT-src/*hs
3dde4051c307b609159a097f08a05108fdd036efJonathan von SchroederGENERATERULES_deps = utils/GenerateRules/*hs $(DRIFT_deps) Common/Utils.hs
3dde4051c307b609159a097f08a05108fdd036efJonathan von SchroederINLINEAXIOMS_deps = utils/InlineAxioms/InlineAxioms.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Common/Lib/Pretty.hs Common/Keywords.hs Common/Lib/Set.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Common/Lib/Map.hs Common/Lib/Rel.hs Common/Lib/State.hs Common/Id.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs CASL/ShowMixfix.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder CASL/Utils.hs Common/Lexer.hs Common/Token.hs Common/Anno_Parser.hs \
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maeder Common/GlobalAnnotations.hs Common/PrettyPrint.hs \
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder Common/Print_AS_Annotation.hs Common/PPUtils.hs CASL/LiteralFuns.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder CASL/Print_AS_Basic.hs Common/AnnoState.hs CASL/Formula.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder CASL/OpItem.hs CASL/SortItem.hs CASL/Inject.hs Common/Result.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder Common/ConvertLiteral.hs Common/Earley.hs CASL/MixfixParser.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder CASL/Parse_AS_Basic.hs CASL/Sign.hs CASL/Overload.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder CASL/StaticAna.hs Modal/AS_Modal.hs Modal/Parse_AS.hs \
8b767d09a78927b111f5596fdff9ca7d2c1a439fChristian Maeder Modal/ModalSign.hs Modal/Print_AS.hs Modal/StatAna.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian MaederHC = ghc
308834907a120fd8771e18292ed2ca9cd767c12dChristian MaederPERL = perl
bab2d88d650448628730ed3b65c9f99c52500e8cChristian MaederHAPPY = happy -sgca
1f9274bb2aa44ea236327814dce99946be52e348Felix Gabriel ManceDRIFT = utils/DrIFT
8cacad2a09782249243b80985f28e9387019fe40Christian MaederINLINEAXIOMS = utils/outlineAxioms
6a2dad705deefd1b7a7e09b84fd2d75f2213be47Christian MaederHADDOCK = haddock
a7c27282e71cf4505026645f96d4f5cb8a284e32Christian MaederCPPP = cpp
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder
014dc30f64ec25e4790cca987d4d1e6635430510Christian MaederHC_WARN = -Wall
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus LuettichHC_FLAGS = $(HC_WARN) -fglasgow-exts -fno-monomorphism-restriction \
6aea82c63ba1d2efc0329bc784a14e521469ec20Christian Maeder -fallow-overlapping-instances -fallow-undecidable-instances
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder# -ddump-minimal-imports
feca1d35123d8c31aee238c9ce79947b0bf65494Christian Maeder# flags also come in via ../uni/uni-package.conf
431d34c7007a787331c4e5ec997badb0f8190fc7Christian Maeder# but added it here in case of compilation without uni
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder
f5c0884429b01e74c6e658ded921fb2e16dfb478Christian MaederHC_INCLUDE = $(addprefix -i, $(INCLUDE_PATH))
db675e8302ddb0d6528088ce68f5e98a00e890e3Christian Maeder
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maederlogics = CASL HasCASL Modal CoCASL COL CspCASL Hatchet
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian MaederUNI_PACKAGE_CONF = $(wildcard ../uni/uni-package.conf)
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maederifneq ($(strip $(UNI_PACKAGE_CONF)),)
23ffcc44ca8612feccbd8fda63fa5be7ab5f9dc3Christian MaederHC_PACKAGE = -package-conf $(UNI_PACKAGE_CONF) -package uni-davinci \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder -package uni-server -DUNI_PACKAGE
c0c2380bced8159ff0297ece14eba948bd236471Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# some modules from uni for haddock
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# if uni/server is included also HaXml sources are needed
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederuni_dirs = ../uni/davinci ../uni/graphs ../uni/events \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder ../uni/reactor ../uni/util ../uni/posixutil
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maederuni_sources = $(wildcard $(addsuffix /haddock/*.hs, $(uni_dirs))) \
6a79849bed67264c396dddb3e9c184bdfc1a1bc9Christian Maeder $(wildcard ../uni/htk/haddock/*/*.hs)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederendif
a3c6d8e0670bf2aa71bc8e2a3b1f45d56dd65e4cChristian Maeder
dc679edd4ca027663212afdf00926ae2ce19b555Christian Maeder### list of directories to run checks in
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederTESTDIRS += Common CASL HasCASL Haskell/Hatchet/examples
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederPFE_TOOLDIR = $(wildcard ../programatica/tools)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maederifneq ($(strip $(PFE_TOOLDIR)),)
ca074a78b8dcccbb8c419586787882f98d0c6163Christian MaederPFE_DIRS = base/AST base/TI base/parse2 base/parse2/Lexer base/parse2/Parser \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder base/parse2/LexerGen base/parse2/LexerSpec base/tests/HbcLibraries \
4017ebc0f692820736d796af3110c3b3018c108aChristian Maeder base/pretty base/syntax base/lib base/lib/Monads base/Modules base/defs \
b568982efd0997d877286faa592d81b03c8c67b8Christian Maeder base/transforms base/transforms/Deriving property \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder property/syntax property/AST property/transforms \
0be0db405c49906bd7057255069bf6df53395ac9Klaus Luettich property/TI property/defs property/parse2 property/parse2/Parser
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederPFE_PATHS = $(addprefix $(PFE_TOOLDIR)/, $(PFE_DIRS))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maederpfe_sources = $(wildcard $(addsuffix /*hs, $(PFE_PATHS)))
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian MaederPFE_PATH = $(addprefix -i, $(PFE_PATHS))
f2f9df2e17e70674f0bf426ed1763c973ee4cde0Christian MaederPFE_FLAGS = -package data -package text $(PFE_PATH) -DPROGRAMATICA
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maederhappy_files += $(PFE_TOOLDIR)/property/parse2/Parser/PropParser.hs
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian MaederLEX_DIR = $(PFE_TOOLDIR)/base/parse2/Lexer
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian Maeder$(LEX_DIR)/HsLex.hs: $(LEX_DIR)Gen/HsLexerGen
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $< > $@
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder$(LEX_DIR)Gen/HsLexerGen: $(LEX_DIR)Gen/*.hs $(LEX_DIR)Spec/*.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder $(LEX_DIR)/HsTokens.hs
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $(HC) --make -O -package data \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder -i$(PFE_TOOLDIR)/base/tests/HbcLibraries \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -i$(PFE_TOOLDIR)/base/lib \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder -i$(LEX_DIR) -i$(LEX_DIR)Gen -i$(LEX_DIR)Spec \
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder $@.hs -o $@
ca074a78b8dcccbb8c419586787882f98d0c6163Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederlogics += Haskell
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maederderived_sources += Haskell/PreludeString.hs $(LEX_DIR)/HsLex.hs \
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder $(LEX_DIR)Gen/HsLexerGen
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder
d946c1bfdd7d58aa7c023efe864d5999eb44a61bChristian MaederAPPENDPRELUDESTRING = utils/appendHaskellPreludeString \
e6d5dbbc3308f05197868806e0b860f4f53875f1Christian Maeder Haskell/ProgramaticaPrelude.hs
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder## rule for appendHaskellPreludeString
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian MaederHaskell/PreludeString.hs: Haskell/PreludeString.append.hs \
eb74267cf39e4e95f9eeb5c765f4c8dac33971b4Christian Maeder $(APPENDPRELUDESTRING)
e4f4d096e5e6d60dd91c746d0e833d0ac7a29c50Christian Maeder $(APPENDPRELUDESTRING) < $< > $@
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederAst_Haskell_files = HsDeclStruct HsExpStruct HsFieldsStruct \
f1541d4a151dbd08002dbd14e7eb1d5dde253689Christian Maeder HsGuardsStruct HsKindStruct HsPatStruct HsTypeStruct HsAssocStruct \
8d178ae08a52d61379e6b8074f61646499bc88bbChristian Maeder HsModule HsName HsLiteral HsIdent
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
6cd33d6101fb1b93baa6d86fac158af18a115108Christian MaederOther_PFE_files = property/AST/HsPropStruct base/defs/PNT \
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder base/defs/UniqueNames base/Modules/TypedIds base/TI/TiKinds \
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder base/parse2/SourceNames base/syntax/SyntaxRec \
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder property/syntax/PropSyntaxStruct
6cd33d6101fb1b93baa6d86fac158af18a115108Christian Maeder
b2ac5a92cf36382e8deea5661c1964566caf72b3Christian MaederHaskell_files = $(addsuffix .hs, \
59138b404f12352d103eeffbeaeb3957b90e75fdChristian Maeder $(addprefix $(PFE_TOOLDIR)/base/AST/, $(Ast_Haskell_files)) \
b2ac5a92cf36382e8deea5661c1964566caf72b3Christian Maeder $(addprefix $(PFE_TOOLDIR)/, $(Other_PFE_files)))
b2ac5a92cf36382e8deea5661c1964566caf72b3Christian Maeder
7d0ee72ee91ec305408688b969c43f07b9667c80Christian Maeder## rule for ATC generation
7d0ee72ee91ec305408688b969c43f07b9667c80Christian MaederHaskell/ATC_Haskell.der.hs: $(Haskell_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(Haskell_files)
0e5b095a19790411e5352fa7cf57cb0388e70472Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederTESTDIRS += ToHaskell
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederendif
f1a913f880e409e7327b5deae95738b5448379a1Christian Maeder
f1a913f880e409e7327b5deae95738b5448379a1Christian Maederhappy_files += Haskell/Hatchet/HsParser.hs
f1a913f880e409e7327b5deae95738b5448379a1Christian Maeder
f1a913f880e409e7327b5deae95738b5448379a1Christian Maeder### Profiling (only for debugging)
14c56dc499da4bbeaeebeb558ceb755150ae341cChristian Maeder### Attention every module must be compiled with profiling or the linker
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder### cannot link the various .o files properly. So after switching on
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Profiling, do an 'gmake real_clean; gmake'
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder### and comment out HC_PACKAGE variable definition above.
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Comment in the following line for switching on profiling.
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder#HC_PROF = -prof -auto-all
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian Maeder
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian MaederHCI_OPTS = $(HC_FLAGS) $(HC_INCLUDE) $(HC_PACKAGE) $(PFE_FLAGS)
93f5b72fdb9ee734caa750b43dd79bbb590dcd73Christian MaederHC_OPTS = $(HCI_OPTS) $(HC_PROF)
328a85c807f2a95c3f147d10b05927eaf862ebebChristian MaederDRIFT_OPTS = +RTS -K10m -RTS
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder
06dd4e7c29f33f6122a910719e3bd9062256e397Andy Gimblett####################################################################
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder## sources for hets (semi - manually produced with a perl script)
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder#GHCMAKE_OUTPUT = $(wildcard hetcats-make)
5b818f10e11fc79def1fdd5c8a080d64a6438d87Christian Maeder
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers#ifneq ($(strip $(GHCMAKE_OUTPUT)),)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder#include sources_hetcats.mk
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder#else
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maedernon_sources = Common/LaTeX_maps.svmono.hs CspCASL/Main.hs Logic/Morphism.hs \
140287998aa8592c9c403bd9e308e447ba92ae11Christian Maeder Static/LogicStructured.hs Common/CaslLanguage.hs ./Test.hs
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian MaederSOURCE_PATHS = $(COMMONLIB_PATH) $(CLEAN_PATH)
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder
3554301a34639efb6c9961a8571775d0061284c9Christian Maedersources = hets.hs $(filter-out $(non_sources), \
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers $(wildcard $(addsuffix /[A-Z]*hs, $(SOURCE_PATHS))))
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
9e748851c150e1022fb952bab3315e869aaf0214Christian Maeder#endif
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maederobjects = $(sources:%.hs=%.o)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maederdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder Modal/AS_Modal.hs CoCASL/AS_CoCASL.hs COL/AS_COL.hs \
3554301a34639efb6c9961a8571775d0061284c9Christian Maeder $(gendrifted_files)
3554301a34639efb6c9961a8571775d0061284c9Christian Maeder
3554301a34639efb6c9961a8571775d0061284c9Christian Maedergenrule_header_files = $(wildcard ATC/*.header.hs)
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maederatc_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Common/AS_Annotation.der.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Static/DevGraph.hs Proofs/Proofs.hs Isabelle/IsaSign.hs
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maederatc_der_files = $(foreach file, $(atc_files), \
383aa66e5142365fe9b1f88b18c1da5b27cc8c04Christian Maeder ATC/$(basename $(basename $(notdir $(file)))).der.hs)
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian MaederCASL_files = CASL/Sublogic.hs CASL/Morphism.hs CASL/Sign.hs \
a14767aeac3e78ed100f5b75e210ba563ee10dbaChristian Maeder CASL/AS_Basic_CASL.der.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
3554301a34639efb6c9961a8571775d0061284c9Christian MaederHasCASL_files = HasCASL/As.hs HasCASL/Le.hs HasCASL/Morphism.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder HasCASL/Sublogic.hs \
54ea981a0503c396c2923a1c06421c6235baf27fChristian Maeder
54ea981a0503c396c2923a1c06421c6235baf27fChristian MaederModal_files = Modal/AS_Modal.hs Modal/ModalSign.hs
54ea981a0503c396c2923a1c06421c6235baf27fChristian MaederCoCASL_files = CoCASL/AS_CoCASL.hs CoCASL/CoCASLSign.hs
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian MaederCOL_files = COL/AS_COL.hs COL/COLSign.hs
aded505f9b42cc38975559c2a5d175ae95de436bChristian MaederCspCASL_files = CspCASL/AS_CSP_CASL.hs CspCASL/SignCSP.hs
697e63e30aa3c309a1ef1f9357745111f8dfc5a9Christian Maeder
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian MaederHatchet_files = Haskell/Hatchet/AnnotatedHsSyn.hs \
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder Haskell/Hatchet/MultiModuleBasics.hs Haskell/Hatchet/HsSyn.hs \
f9e0b18852b238ddb649d341194e05d7200d1bbeChristian Maeder Haskell/Hatchet/Representation.hs Haskell/Hatchet/Class.hs \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder Haskell/Hatchet/KindInference.hs Haskell/Hatchet/Env.hs \
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder Hatchet/HatParser.hs
819e29dba060687cf391e444e0f6ff88c1908cc3Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederatc_logic_files = $(foreach logic, $(logics), $(logic)/ATC_$(logic).der.hs)
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedergenerated_rule_files = $(atc_der_files) $(atc_logic_files)
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maedergendrifted_files = $(patsubst %.der.hs, %.hs, $(generated_rule_files))
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederinline_axiom_files = Comorphisms/CASL2PCFOL.hs Comorphisms/PCFOL2FOL.hs \
254df6f22d01eacf7c57b85729e0445747b630d9Christian Maeder Comorphisms/Modal2CASL.hs Comorphisms/CASL2TopSort.hs
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maedergen_inline_axiom_files = $(patsubst %.hs,%.inline.hs, $(inline_axiom_files))
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maeder
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maederderived_sources += $(drifted_files) Driver/Version.hs $(happy_files) \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder $(inline_axiom_files) Modal/ModalSystems.hs
ac34194a668399bb8ef238da77c3a09e93fb253bChristian Maeder
4fc9de0da898448f1d3597ebbd8c04a066464c21Christian Maeder# sources that have {-# OPTIONS -cpp #-}
aded505f9b42cc38975559c2a5d175ae95de436bChristian Maedercpp_sources = Common/DFiniteMap.hs Common/DynamicUtils.hs \
d23b0cc79c0d204e6ec758dff8d0ba71c9f693f7Christian Maeder Isabelle/Logic_Isabelle.hs \
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder Proofs/Proofs.hs hets.hs CASL/CCC/FreeTypes.hs \
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder Comorphisms/LogicList.hs Comorphisms/LogicGraph.hs $(happy_files)
c208973c890b8f993297720fd0247bc7481d4304Christian Maeder
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maedernondoc_sources = $(wildcard utils/DrIFT-src/*.hs) \
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder $(wildcard utils/DrIFT-src/*.lhs) \
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder $(wildcard utils/GenerateRules/*.hs) \
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maeder $(wildcard utils/InlineAxioms/*.hs) \
0d0278c34a374b29c2d6c58b39b8b56e283d48e8Christian Maeder $(cpp_sources) $(pfe_sources) $(gen_inline_axiom_files) \
1842453990fed8a1bd7a5ac792d7982c1d2bfcd5Christian Maeder $(genrule_header_files) $(generated_rule_files) \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder Modal/GeneratePatterns.inline.hs \
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder Haskell/PreludeString.append.hs Haskell/ProgramaticaPrelude.hs \
986d3f255182539098a97ac86da9eeee5b7a72e3Christian Maeder hxt/HXT.hs hxt/Net.hs $(patsubst %.hs, %.der.hs, $(drifted_files))
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
4561227a776bdf0ab679b19fb92f1eaaed8786f7Christian Maeder# this variable holds the modules that should be documented
01e278bdd7dce13b9303ed3d79683d83c89d09f9Liam O'Reillydoc_sources = $(filter-out $(nondoc_sources), $(sources)) \
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(patsubst %.hs, %.hspp, $(cpp_sources)) $(uni_sources)
5ad5dffe06818a13e1632b1119fbca7881085fc1Dominik Luecke
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maedertax_sources = Taxonomy/AbstractGraphView.hs Taxonomy/MMiSSOntology.hs \
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder Taxonomy/MMiSSOntologyGraph.hs Taxonomy/OntoParser.hs
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescutax_objects = $(patsubst %.hs, %.o, $(tax_sources))
31d6d9286988dc31639d105841296759aeb743e0Jonathan von Schroeder
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu####################################################################
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder### targets
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder.PHONY : all hets-opt hets-optimized clean d_clean real_clean bin_clean \
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder lib_clean distclean check capa hacapa h2h clean_genRules genRules \
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke taxonomy count doc apache_doc post_doc4apache \
05a206508bc898f87fe6ab6e069814df3c29d303Dominik Luecke derivedSources install_hets install release
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder.SECONDARY : %.hs %.d $(generated_rule_files) $(gen_inline_axiom_files)
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder#.PRECIOUS: sources_hetcats.mk
d54cd08a4cfa26256c38d8ed12c343adbfe1a0e3Christian Maeder
3b06e23643a9f65390cb8c1caabe83fa7e87a708Till Mossakowski### call run_hc with
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder# $(call run_hc,<command-that-compiles-hetc-with-ghc>)
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder# and it generates hetcats-make
8c812cd83569e973f10cf69a342424ceabc07af9Christian Maeder# iff there was no error during compilation
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maederrun_hc = ($(1) 2>&1 || $(RM) hetcats-make) | tee hetcats-make
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maeder
5afff1a0f62394414c33b06141175b3ab0b117a5Christian Maederhets: $(sources) $(derived_sources)
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder $(call run_hc, $(HC) --make -o $@ hets.hs $(HC_OPTS))
1b3a2f98d1cd01fc9e0591f69507e20526727559Dominik Luecke
f04e8f3ff56405901be968fd4c6e9769239f1a9bKlaus Luettichhets-opt:
e39a1626bee36d6ad13a2c0014a80ef179a65bcbChristian Maeder $(MAKE) distclean
f8e1a1eca871a26a535a4ee7d51902ba94b1db1eChristian Maeder $(MAKE) derivedSources
ea3bff3e547a1ac714d4db39c5efef95e02b2e7dChristian Maeder $(MAKE) real_clean
dd6f22b9dcff2695181b86372e4df03d5b96e92dKristina Sojakova $(MAKE) hets-optimized
005e0f0c6b0cc898003b03801158c208f3071fc5Kristina Sojakova
abf2487c3aece95c371ea89ac64319370dcb6483Klaus Luettichhets-optimized: $(derived_sources)
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder $(call run_hc, $(HC) --make -O -o hets hets.hs $(HC_OPTS))
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder strip hets
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maederhets-old: $(objects)
76b9b2974795a6fb31f242fd032de3ff66df6204Christian Maeder $(RM) $@
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder $(HC) -o hets $(HC_OPTS) $(objects)
878a5ecd6acf973907e25e5be6e4a792ea19a05eEwaryst Schulz
878a5ecd6acf973907e25e5be6e4a792ea19a05eEwaryst Schulzhets.cgi: $(sources) GUI/hets_cgi.hs
c2e192ace9ef7cfb0e59563f1b24477b2b65cff3Dominik Dietrich ghc --make -package-conf /home/luettich/ghc-pkg/package.conf \
6b75c206b317eb30a08d88a8f27e0295ffeb1546Christian Maeder -package WASH-CGI GUI/hets_cgi.hs -o hets.cgi $(HC_INCLUDE) \
9a4b469ca0a7f44a598e551a973c75195207db58Eugen Kuksa $(HC_FLAGS) -O
48aa0645e25883048369afc02aac3f49b14a50daChristian Maeder strip hets.cgi
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder
01645eac73dbc789392674930adc5745c935f3a0Christian Maedertaxonomy: Taxonomy/taxonomyTool.hs $(tax_sources)
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder $(HC) --make -o Taxonomy/taxonomyTool $< -ifgl $(HC_OPTS)
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder
7dc37844730a8b23973139e9720574382de109e7Alexis Tsogias###############################
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis Tsogias### TAGS files for (x)emacs
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz# load them with "M-x" "visit-tags-table" from
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz# "HetCATS/hetcats.TAGS"
a604cbad8e2202147b5c6bb9f2e06ae61162d654Felix Gabriel Mance# use "M-." to search for a tag
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder# !!Beware this is somewhat instable, because it uses an absolute path!!
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maederhetcats.TAGS: $(sources)
7834a982096d93301a4626f444dd9ea5f9fe17eaChristian Maeder /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
1f9274bb2aa44ea236327814dce99946be52e348Felix Gabriel Mance $(sources); mv TAGS $@; mv tags hetcats.tags
1f9274bb2aa44ea236327814dce99946be52e348Felix Gabriel Mance
bab2d88d650448628730ed3b65c9f99c52500e8cChristian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### count lines of code
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maedercount: $(sources)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder wc -l $(sources)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### Documentation via haddock
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederdoc: docs/index.html
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder# generate haddock documentation with links to sources
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederdocs/index.html: $(doc_sources)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HADDOCK) $(doc_sources) -o docs -h -v \
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder -i docs/base.haddock -i docs/parsec.haddock -s ../ \
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder -t 'Hets - the Heterogeneous Tool Set' \
7a3fe82695aa32657693e05712f84d7f81672f2eJonathan von Schroeder -p Hets-Haddock-Prologue.txt
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu# sources are not copied here
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescuapache_doc:
1535e1d8c82db5f7e2402261983c4c2ef39f4f39Mihai Codescu $(RM) docs/*.*
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder cvs up -d ; echo "CVS exited with: " $$?
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(MAKE) hets-opt
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(MAKE) doc
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(MAKE) post_doc4apache
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(MAKE) o_clean
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(MAKE) hets.cgi
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederpost_doc4apache:
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(PERL) utils/post_process_docs.pl docs \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder 'Common.Lib.Map.html:Common.Lib._Map.html'
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder cp docs/*.* a-docs/
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder###############################
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### release management
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederderivedSources: $(derived_sources)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederutils/DrIFT: $(DRIFT_deps)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT && \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder strip ../DrIFT)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederutils/genRules: $(GENERATERULES_deps)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder (cd utils/GenerateRules; \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HC) --make -i../DrIFT-src -i../.. $(HC_WARN) \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder GenerateRules.hs -o ../genRules && strip ../genRules)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder$(INLINEAXIOMS): $(INLINEAXIOMS_deps)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HC) --make utils/InlineAxioms/InlineAxioms.hs $(HC_WARN) $(HC_PROF) \
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder -i../.. -o $(INLINEAXIOMS)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder strip $(INLINEAXIOMS)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederrelease:
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) -r HetCATS
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository\
3e8b136f23ed57d40ee617f49bcac37830b58cabChristian Maeder co -P HetCATS
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) -r uni
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder if [ -d ../uni ] ; then ln -s ../uni uni ; fi
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) -r programatica
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder if [ -d ../programatica ] ; then \
9f85afecbd79b3df5a0bb17bd28cd0b288dc3213Kristina Sojakova mkdir programatica; \
48aa0645e25883048369afc02aac3f49b14a50daChristian Maeder ln -s ../../programatica/tools programatica/tools ; fi
9f85afecbd79b3df5a0bb17bd28cd0b288dc3213Kristina Sojakova (cd HetCATS; $(MAKE) derivedSources; \
79834070d6d3c63a098e570b12fa3405c607dc70Kristina Sojakova $(MAKE) clean; ./clean.sh; \
79834070d6d3c63a098e570b12fa3405c607dc70Kristina Sojakova find . -name CVS -o -name \*.o -o -name \*.hi | xargs $(RM) -r; \
79834070d6d3c63a098e570b12fa3405c607dc70Kristina Sojakova $(RM) clean.*; mv Makefile Makefile.orig; \
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder mv ReleaseMakefile Makefile)
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder tar cvf HetCATS.tar HetCATS
23b4e542dca35852f58d1fb3f7d9078c1de5ab06Christian Maeder
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maederinstall-hets:
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder chmod g+w hets
8a78868bae2ec6838c87366c35c57e109154c51eChristian Maeder cp -p hets $(INSTALLDIR)/versions/hets-`cat version_nr`
624e6701e0deb7ac6c03c0cba0190fbc5033cf93Ewaryst Schulz cp -p version_nr $(INSTALLDIR)
624e6701e0deb7ac6c03c0cba0190fbc5033cf93Ewaryst Schulz (cd $(INSTALLDIR); $(RM) hets; \
c2e192ace9ef7cfb0e59563f1b24477b2b65cff3Dominik Dietrich ln -s versions/hets-`cat version_nr` hets; $(RM) version_nr)
7165a916d2fa1bf87c4741ec63b253413eebbf69Karl Luc
7165a916d2fa1bf87c4741ec63b253413eebbf69Karl Lucinstall: hets-opt install-hets
7165a916d2fa1bf87c4741ec63b253413eebbf69Karl Luc
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder#############################
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder### ATC DrIFT-rule generation
01645eac73dbc789392674930adc5745c935f3a0Christian Maeder
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian MaedergenRules: $(generated_rule_files)
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder
bff4b3f816be4c1e1d8ded76f1d5af786839e1a9Christian Maeder$(atc_der_files): $(atc_files) $(genrule_header_files) utils/genRules
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis Tsogias $(foreach file, $(atc_files), $(gen_atc_files))
fc09e0a6af734edbd944dd8082bb51985c233b43Alexis Tsogias
b5da047a9a875dec3f968b6c0df96af326f90fa9Alexis TsogiasCASL/ATC_CASL.der.hs: $(CASL_files) utils/genRules
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz utils/genRules -r $(rule) -o CASL $(CASL_files)
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst Schulz
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst SchulzHasCASL/ATC_HasCASL.der.hs: $(HasCASL_files) utils/genRules
bab2d88d650448628730ed3b65c9f99c52500e8cChristian Maeder utils/genRules -r $(rule) -o HasCASL $(HasCASL_files)
18d370f8341357f5d6a4068f4bb6981173ece70fFelix Gabriel Mance
7834a982096d93301a4626f444dd9ea5f9fe17eaChristian MaederModal/ATC_Modal.der.hs: $(Modal_files) utils/genRules
ed1b8e97e72b2e3e92edaf2eb22a4b5373d705f1Felix Gabriel Mance utils/genRules -r $(rule) -o Modal $(Modal_files)
ed1b8e97e72b2e3e92edaf2eb22a4b5373d705f1Felix Gabriel Mance
0a03acf9fa28e6ff00f4d7c9c6acbae64cf09c56Ewaryst SchulzCoCASL/ATC_CoCASL.der.hs: $(CoCASL_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o CoCASL $(CoCASL_files)
c70ef4c3b3a62764f715510c9fd67dde3acfe454Christian Maeder
61fa0ac06ede811c7aad54ec4c4202346727368eChristian MaederCOL/ATC_COL.der.hs: $(COL_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o COL $(COL_files)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederCspCASL/ATC_CspCASL.der.hs: $(CspCASL_files) utils/genRules
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder utils/genRules -r $(rule) -o CspCASL $(CspCASL_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian MaederHatchet/ATC_Hatchet.der.hs: $(Hatchet_files) utils/genRules
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder utils/genRules -r $(rule) -o Hatchet -h ATC/Hatchet.header.hs \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(Hatchet_files)
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
cc07a598b995acc9436651e66fd18009509047efChristian Maederrule = ShATermConvertible
61fa0ac06ede811c7aad54ec4c4202346727368eChristian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maedergen_atc_files = \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; \
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder then utils/genRules -r $(rule) -o ATC -h \
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
e420b3848a0e15a9e074b08c413996cbeb5ab06dChristian Maeder else utils/genRules -r $(rule) -o ATC $(file); fi ;
f443a57f2a8e0ca3daa7431b0c89a18ba52c337aChristian Maeder
f5c9b1e739228c2a2edf055ac419583412569683Christian Maederclean_genRules:
857992065be4ed40a72c6296b6c0aec62ab4c5b9Christian Maeder $(RM) $(generated_rule_files) $(gendrifted_files)
37a9d042e9f85a1d6e229eb80b48f93df810f155Christian Maeder
7c99e334446bb97120e30e967baeeddfdd1278deKlaus Luettich###############
f5c9b1e739228c2a2edf055ac419583412569683Christian Maeder### clean up
f5c9b1e739228c2a2edf055ac419583412569683Christian Maeder
f5c9b1e739228c2a2edf055ac419583412569683Christian Maederclean: bin_clean o_clean
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### removes *.hi and *.o in all include directories
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maedero_clean:
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maeder for p in $(CLEAN_PATH) ; do \
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder (cd $$p ; $(RM) *.hi *.o *.hspp) ; done
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### remove binaries
0c355dd0b739631ee472f9a656e266be27fa4e64Christian Maederbin_clean:
fa21fba9ceb1ddf7b3efd54731a12ed8750191d8Christian Maeder $(RM) hets
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder $(RM) test_parser
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich $(RM) CASL/capa
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich $(RM) HasCASL/hacapa
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) Haskell/hapa
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich $(RM) Haskell/hana
c7ec85d1103173e089aa5048fd7afb2f9b505124Klaus Luettich $(RM) Haskell/wrap
810746aea00b81c1eec27dae84d73a43599ff056Christian Maeder $(RM) ToHaskell/h2h
a883cd4d01fe39d23219cf5333425f195be24d8bChristian Maeder $(RM) Syntax/hetpa
b905126bab9454b89041f92b3c50bb9efc85e427Klaus Luettich $(RM) Static/hetana
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(RM) GUI/hetdg
33d042fe6a9eb27a4c48f840b80838f3e7d98e34Christian Maeder $(RM) hetpa
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(RM) hetana
0a5571c8adeddd27548445546491725beb224dddChristian Maeder $(RM) hetdg
0a5571c8adeddd27548445546491725beb224dddChristian Maeder $(RM) atctest2
0a5571c8adeddd27548445546491725beb224dddChristian Maeder $(RM) atctest
0a5571c8adeddd27548445546491725beb224dddChristian Maeder $(RM) Common/annos
0a5571c8adeddd27548445546491725beb224dddChristian Maeder $(RM) Haskell/Hatchet/hatch
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder $(RM) ToHaskell/translateAna
e112e83352048f3db8c8f93ae104193e7338c10fChristian Maeder $(RM) Taxonomy/taxonomyTool
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder### additonally removes *.d (dependency files) in every include directory
e642ad0e782f9bb9ba310164358220402eec8cd8Christian Maeder### also delete *.d.bak (dependency file backups)
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maederd_clean: clean
f38b3687c5558128515e34fb85d8b466d22dc300Christian Maeder for p in $(CLEAN_PATH) ; do \
74d27713392cbbe39ecd72d0ddb0caad16e84555Christian Maeder (cd $$p ; $(RM) *.d *.d.bak) ; done
ef67402074be14deb95e4ff564737d5593144130Klaus Luettich
e112e83352048f3db8c8f93ae104193e7338c10fChristian Maeder### remove files also in own libraries
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maederlib_clean:
aebb0b18fe5e6ba7dd7e4c66a16a905611ef7ba9Christian Maeder for p in $(COMMONLIB_PATH) ; do \
e05fd774e0181e93963d4302303b20698603a505Christian Maeder (cd $$p ; $(RM) *.hi *.d *.o) ; done
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder### additionally removes the files that define the sources-variable
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maederreal_clean: bin_clean lib_clean clean
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maeder $(RM) hetcats-make sources_hetcats.mk
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maeder
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maeder### additionally removes files not in CVS tree
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroederdistclean: real_clean clean_genRules d_clean
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder $(RM) $(derived_sources)
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder $(RM) utils/DrIFT utils/genRules $(INLINEAXIOMS)
3dde4051c307b609159a097f08a05108fdd036efJonathan von Schroeder
aebb0b18fe5e6ba7dd7e4c66a16a905611ef7ba9Christian Maeder####################################################################
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### test targets
63f0e65a37b95621334db9ee4ba0cd9d826f5c0fChristian Maeder####################################################################
e05fd774e0181e93963d4302303b20698603a505Christian Maeder
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder### a parser to test annotation parser and Id parsers
1dfba1f850f6a43094962b459998d1ea11472461Christian Maedertest_parser: Common/test_parser
1dfba1f850f6a43094962b459998d1ea11472461Christian Maeder
1dfba1f850f6a43094962b459998d1ea11472461Christian MaederCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
fa0f3519d71f719d88577b716b1579776b4a2535Christian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### interactive
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maederghci:
fa0f3519d71f719d88577b716b1579776b4a2535Christian Maeder $(HC)i $(HCI_OPTS)
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maeder
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder### christian's target
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maeder### CASL parser
5bb7eeaca10ea76595229375f907a5a388b7c882Christian Maedercapa: CASL/capa
c59d1c38ef94b4fb1c8d9fda9573bc1e1d2801e7Christian Maeder
cd36bffee51c77cdadcb9f916b34fa512e311946Christian MaederCASL/capa: CASL/capa.hs Common/*.hs CASL/*.hs
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
ac0bbbcb2774629bb87986e69cf53d3402c5f575Christian Maeder
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder### 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
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maederh2h: ToHaskell/h2h
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder
810746aea00b81c1eec27dae84d73a43599ff056Christian MaederToHaskell/h2h: ToHaskell/h2h.hs ToHaskell/*.hs Haskell/*.hs HasCASL/*.hs
6dc9bc98d0854fe2e3dd3bfc4275096a0c28ee1cChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
8b0f493ae42bad8b94918cc0957f1af57096cda4Felix Reckers
1365c420ef71be3d52796ebd369dc2defdedc822Christian Maeder### HetCASL parser
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettichhetpa: Syntax/hetpa.hs Syntax/*.hs
82e29b77f0ef4cccd7ed734692c5e1e93dbbc645Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
a80c28bb8b7a23ccdf7e08d0fe216fc19cc97273Klaus Luettich
5f0e3e4cb7dd31033c9682cafa712d2a66b2f3bcChristian Maeder### HetCASL parser
5f0e3e4cb7dd31033c9682cafa712d2a66b2f3bcChristian Maederhetana: Static/hetana.hs Static/*.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
b9625461755578f3eed04676d42a63fd2caebd0cChristian Maeder
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder### ATC test system
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederatctest: ATC/ATCTest.hs ATC/*.hs
d0652648f9879c67a194f8b03baafe2700c68eb4Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS)
363939beade943a02b31004cea09dec34fa8a6d9Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maederatctest2: ATC/ATCTest2.hs Common/SimpPretty.hs Common/ATerm/*.hs \
b1f59a4ea7c96f4c03a4d7cfcb9c5e66871cfbbbChristian Maeder Common/Lib/*.hs
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder### ATerm.Lib test system
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maederatermlibtest: Common/ATerm/ATermLibTest.hs Common/SimpPretty.hs \
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder Common/ATerm/*.hs Common/Lib/*.hs
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder $(HC) --make -o $@ $< $(HC_OPTS) $(EXTRA_HC_OPTS)
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettichhatermdiff: Common/ATerm/ATermDiffMain.hs Common/SimpPretty.hs \
1365c420ef71be3d52796ebd369dc2defdedc822Christian Maeder Common/ATerm/*.hs Common/Lib/*.hs
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder $(HC) --make -o $@ $< $(HC_OPTS) $(EXTRA_HC_OPTS)
308834907a120fd8771e18292ed2ca9cd767c12dChristian Maeder
1365c420ef71be3d52796ebd369dc2defdedc822Christian Maeder### HetCASL with dev graph
83394c6b6e6de128e71b67c9251ed7a84485d082Christian Maederhetdg: GUI/hetdg.hs $(drifted_files) *.hs
36f63902db2b3463faa9f59912ad106e2d5aaa24Klaus Luettich $(HC) --make -o $@ $< $(HC_OPTS)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
e420b3848a0e15a9e074b08c413996cbeb5ab06dChristian Maeder### run tests in other directories
68d10d143f29fcff3c637ba24f90e983995ceae6Christian Maedercheck:
e7757995211bd395dc79d26fe017d99375f7d2a6Christian Maeder for i in $(TESTDIRS); do $(MAKE) -C $$i check; done
cc07a598b995acc9436651e66fd18009509047efChristian Maeder
cc07a598b995acc9436651e66fd18009509047efChristian Maeder####################################################################
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian Maeder## Preparing the version of HetCATS
825a1e4ca1e768de4b4883c65a6cb1dce6aa0002Christian MaederDriver/Version.hs: Driver/Version.in version_nr
3e61f574717499939bd8e0ff538ea9e7b72d4e2dKlaus Luettich $(PERL) utils/build_version.pl version_nr < Driver/Version.in > $@
4ba08bfca0cc8d9da65397b8dfd2654fdb4c0e62Christian Maeder
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
2c619a4dfdc1df27573eba98e81ed1ace906941dChristian Maederhets.hs: Driver/Version.hs
5580ab3e64410186ccd36cde8a94282d8757ac0dChristian Maeder####################################################################
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for DrIFT
e284004f10a315dbdb624c8b2522f65d485eaa48Martin Kühl.SUFFIXES:
b446bf54c1dc78690aa12e86aadc49cdd8585847Christian Maeder
e284004f10a315dbdb624c8b2522f65d485eaa48Martin Kühl%: %.hs
e284004f10a315dbdb624c8b2522f65d485eaa48Martin Kühl $(HC) --make -o $@ $<
456238178f89e5a3de2988ee6c8af924297d52d9Christian Maeder
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder%.hs: %.ly
50515239e7e190f4a34ca581dd685d002148fbddChristian Maeder $(HAPPY) $<
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maeder
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maeder%.hs: %.y
0b349288edfa50fdf38fda1a14e1562d03f92574Christian Maeder $(HAPPY) -o $@ $<
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.hs: %.der.hs utils/DrIFT
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder ($(DRIFT_ENV); export DERIVEPATH; $(DRIFT) $(DRIFT_OPTS) $< > $@)
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder## rules for inlineAxioms
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder%.hs: %.inline.hs $(INLINEAXIOMS)
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski $(INLINEAXIOMS) $< > $@
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski
8b4c68db8b465107cabef8b9cd5b6bc216e1b156Till Mossakowski## rule for cpp and haddock
bcaf979d9babe6346aa343687aa7d596e2894cccPaolo Torrini%.hspp: %.hs
df29370ae8d8b41587957f6bcdcb43a3f1927e47Christian Maeder $(HC) -E -cpp -DUNI_PACKAGE -optP -P $<
bcaf979d9babe6346aa343687aa7d596e2894cccPaolo Torrini
5ce19352a9cc47d982819cc889a71cd0a61ac171Christian Maeder## compiling rules for object and interface files
5ce19352a9cc47d982819cc889a71cd0a61ac171Christian Maeder%.o %.hi: %.hs
c9a7e6af169a2adfb92f42331cd578065ed83a2bChristian Maeder $(HC) -c $< $(HC_OPTS)
bcaf979d9babe6346aa343687aa7d596e2894cccPaolo Torrini
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder%.o %.hi: %.lhs
df29370ae8d8b41587957f6bcdcb43a3f1927e47Christian Maeder $(HC) -c $< $(HC_OPTS)
23ab8855c58adfbd03a0730584b917b24c603901Christian Maeder
e50e41135ece589f7202bd4ef8d6b97531c2a56eKlaus Luettich## compiling rules for dependencies
47b0e9f3cb008cb7997f4e3bae26e4d62dcc887aChristian Maeder%.d : %.hs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
431d34c7007a787331c4e5ec997badb0f8190fc7Christian Maeder%.d : %.lhs
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder $(HC) -M $< $(HC_OPTS) -optdep-f -optdep$@
5191fa24c532d1f67e7a642e9aece65efb8a0975Christian Maeder
99afa6000472f3d291fdf9193ea19d334a58658dChristian Maeder## rule for Modal/ModalSystems.hs needed for ModalLogic Translation
43b4c41fbb07705c9df321221ab9cb9832460407Christian MaederModal/ModalSystems.hs: Modal/GeneratePatterns.inline.hs.in \
88318aafc287e92931dceffbb943d58a9310001dChristian Maeder utils/genTransMFormFunc.pl $(INLINEAXIOMS)
d5d349836d8b1fa93ea49a59d977b106c6e9233bKlaus Luettich $(PERL) utils/genTransMFormFunc.pl $< $@
d5d349836d8b1fa93ea49a59d977b106c6e9233bKlaus Luettich
88318aafc287e92931dceffbb943d58a9310001dChristian 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
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder
43b4c41fbb07705c9df321221ab9cb9832460407Christian Maeder