rules revision 4e7050bcbcf0f372a5bad32ecd0282bccabf0983
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# Author: (c) Klaus L�ttich, Christian Maeder, Uni Bremen 2002-2004
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# Year: 2004
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# This Makefile will compile the new hetcats system and provides also
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# targets for test programs during implementation phases.
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# !!! Note: This makefile is written for GNU make !!!
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# (gmake on solaris ; make on linux)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync####################################################################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync## Some varibles, which control the compilation
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncINCLUDE_PATH = ghc:hetcats
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncCOMMONLIB_PATH = Common/Lib:Common/Lib/Parsec:Common/ATerm
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncCLEAN_PATH = Common:Logic:CASL:Syntax:Static:GUI:HasCASL:Haskell:Modal:CspCASL:ATC:ToHaskell:Proofs:Comorphisms:Isabelle:$(INCLUDE_PATH):Haskell/Hatchet
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync## set ghc imports properly for your system
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncDRIFT_ENV = DERIVEPATH='.:ghc:hetcats:/home/linux-bkb/ghc/ghc-latest/lib/ghc-6.2/imports:${GHC_IMPORTS}'
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHAPPY = happy
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncDRIFT = $(DRIFT_ENV) utils/DrIFT
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHADDOCK = haddock
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHC_FLAGS = -fglasgow-exts -Wall
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHC_INCLUDE = -i$(INCLUDE_PATH)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHC_PACKAGE = -package-conf ../uni/uni-package.conf -package uni-davinci \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync -package uni-server
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### Profiling and Warnings (only for debugging)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### Attention every module must be compiled with profiling or the linker
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### cannot link the various .o files properly. So after switching on
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### Profiling, do an 'gmake clean; gmake'
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### If you need Profiling comment out the following line
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#HC_PROF = -prof -auto-all
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHCI_OPTS = $(HC_FLAGS) $(HC_PACKAGE) $(HC_INCLUDE)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHC_OPTS = $(HCI_OPTS) $(HC_PROF)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncDRIFT_OPTS = +RTS -K10m -RTS
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### list of directories to run checks in
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncTESTDIRS = Common CASL HasCASL
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync####################################################################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync## sources for hetcats (semi - manually produced with a perl script)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),clean)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),bin_clean)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),d_clean)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),real_clean)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),distclean)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),genRules)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),utils/genRules)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),hets-opt)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),hets-optimized)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),derivedSources)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),release)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),check)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),apache_doc)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),clean_genRules)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncifneq ($(MAKECMDGOALS),atctest2)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncobjects = $(patsubst %.lhs,%.o,$(sources:%.hs=%.o))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncdrifted_files = Syntax/AS_Architecture.hs Syntax/AS_Library.hs\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync Common/AS_Annotation.hs CASL/AS_Basic_CASL.hs Syntax/AS_Structured.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(gendrifted_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncgenrule_header_files = $(wildcard ATC/*.header.hs)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncgenrule_files = Common/Lib/Graph.hs Common/Id.hs Common/Result.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync Syntax/AS_Structured.der.hs Syntax/AS_Architecture.der.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync Common/GlobalAnnotations.hs Syntax/AS_Library.der.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync CASL/Morphism.hs CASL/Sign.hs CASL/AS_Basic_CASL.der.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync Haskell/Hatchet/Class.hs Haskell/Hatchet/KindInference.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncgendrifted_files = ATC/Graph.hs ATC/Id.hs ATC/Result.hs ATC/AS_Annotation.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncgenerated_rule_files = $(patsubst %.hs,%.der.hs,$(gendrifted_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# this variable holds the modules that should be documented
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# the imported parsec library is not included!
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncdoc_sources = $(filter-out Nothing/Nothing% ,$(sources))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync####################################################################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync.PHONY : clean d_clean real_clean bin_clean check hetana hetpa hetdg \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync clean_genRules genRules
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync.SECONDARY : %.hs %.d $(generated_rule_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynchets: $(sources)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make -o $@ hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) distclean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) derivedSources
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) hets-optimized
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynchets-optimized:
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make -O -o hets hets.hs $(HC_OPTS) 2>&1 | tee hetcats-make
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynchets-old: $(objects)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) -o hets $(HC_OPTS) $(objects)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynchetcats-make: hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) hetcats-make sources_hetcats.mk
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make -o hets $< $(HC_OPTS) 2>&1 | tee hetcats-make
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync###############################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### TAGS files for (x)emacs
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# load them with "M-x" "visit-tags-table" from
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# use "M-." to search for a tag
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# !!Beware this is somewhat instable, because it uses an absolute path!!
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync /home/ger/linux/ghc-5.04.2/bin/i386-unknown-linux/hasktags \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(sources); mv TAGS $@; mv tags hetcats.tags
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync###############################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### Documentation via haddock
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# index for prelude is missing
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncdocs/index.html: $(doc_sources)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HADDOCK) $(doc_sources) -o docs -h \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync -t 'hets -- a heterogenous Specification (CASL) tool set'
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) distclean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) hetcats-make
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) docs/*.html
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (cd docs; cvs up -d)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) doc
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) post_doc4apache
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncpost_doc4apache:
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync cp docs/*.* a-docs/
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync###############################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### release management
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncderivedSources: $(drifted_files) $(happy_files) hetcats/Version.hs
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (cd utils/DrIFT-src; $(HC) --make DrIFT.hs -o ../DrIFT; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync strip ../DrIFT)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make '-i../..:../DrIFT-src' -package text GenerateRules.hs -o ../genRules;\
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync strip ../genRules)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) -r HetCATS
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync cvs -d :pserver:cvsread@cvs-agbkb.informatik.uni-bremen.de:/repository co HetCATS
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) -r uni
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync ln -s ../uni uni
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (cd HetCATS; $(MAKE) derivedSources; ./clean.sh; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync find . -name CVS -o -name \*.o -o -name \*.hi | xargs -r $(RM) -r; \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) clean.*; $(RM) Makefile; mv ReleaseMakefile Makefile)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync tar zcvf HetCATS.tgz HetCATS
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync#############################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### ATC DrIFT-rule generation
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncgenRules: $(generated_rule_files) utils/genRules
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync$(generated_rule_files): $(genrule_files) utils/genRules #$(genrule_header_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(MAKE) clean_genRules
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(foreach file,$(atc_files),$(gen_atc_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync utils/genRules -r $(rule) -o CASL -h ATC/CASL.header.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(casl_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync utils/genRules -r $(rule) -o HasCASL -h ATC/HasCASL.header.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(hascasl_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync utils/genRules -r $(rule) -o CspCASL -h ATC/CspCASL.header.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(cspcasl_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync utils/genRules -r $(rule) -o Haskell -h ATC/Haskell.header.hs \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(haskell_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncrule = ShATermConvertible
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncgen_atc_files = if [ -f ATC/$(basename $(basename $(notdir $(file)))).header.hs ]; then \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync utils/genRules -r $(rule) -o ATC -h ATC/$(basename $(basename $(notdir $(file)))).header.hs $(file); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync utils/genRules -r $(rule) -o ATC $(file); \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncatc_files := $(filter-out CASL/% HasCASL/% CspCASL/% Haskell/% ,$(genrule_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynccasl_files := $(filter CASL/% ,$(genrule_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynchascasl_files := $(filter HasCASL/% ,$(genrule_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynccspcasl_files := $(filter CspCASL/% ,$(genrule_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynchaskell_files := $(filter Haskell/%,$(genrule_files))
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncclean_genRules:
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) $(generated_rule_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync###############
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### clean up
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### removes *.hi and *.o in all include directories
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncclean: bin_clean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (cd $$p ; $(RM) *.hi *.o) ; done
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### remove binaries
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) test_parser
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) hetpa
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) hetana
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) hetdg
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### additonally removes *.d (dependency files) in every include directory
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### also delete *.d.bak (dependency file backups)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncd_clean: clean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync for p in $(subst :, ,$(CLEAN_PATH)) . ; do \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (cd $$p ; $(RM) *.d *.d.bak) ; done
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### remove files also in own libraries
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsynclib_clean: clean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync for p in $(subst :, ,$(COMMONLIB_PATH)) . ; do \
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync (cd $$p ; $(RM) *.hi *.d *.o) ; done
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### additionally removes the files that define the sources-variable
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncreal_clean: bin_clean lib_clean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) hetcats-make sources_hetcats.mk
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### additionally removes files not in CVS tree
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncdistclean: real_clean clean_genRules d_clean
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(RM) $(drifted_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync# $(RM) $(happy_files)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync####################################################################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### test targets
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync####################################################################
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### a parser to test annotation parser and Id parsers
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncCommon/test_parser: Common/test_parser.hs Common/AS_Annotation.der.hs
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make -o $@ $< $(HC_OPTS)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### interactive
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC)i $(HCI_OPTS)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### christian's target
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### CASL parser
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make -o $@ $< $(HC_OPTS)
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync### HasCASL parser
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsyncHasCASL/hacapa: HasCASL/hacapa.hs CASL/capa HasCASL/*.hs
b8e299dddd091ae24e0c08c45d91b8f937bd14d2vboxsync $(HC) --make -o $@ $< $(HC_OPTS)
hapa: Haskell/hapa
hetpa: Syntax/hetpa.hs Syntax/*.hs
hetana: Static/hetana.hs Static/*.hs
atctest: ATC/ATCTest.hs ATC/*.hs
### ATerm.Lib test system
hetdg: GUI/hetdg.hs $(drifted_files) *.hs
$(HC) --make -o $@ $< $(HC_OPTS) -package-conf ../uni/uni-package.conf -package uni-davinci -package uni-server
## two hardcoded dependencies for a correct generation of Version.hs
ifneq ($(MAKECMDGOALS),utils/genRules)
sources_hetcats.mk: hetcats-make hetcats/Version.hs hets.hs utils/create_sources.pl $(drifted_files) $(happy_files)