#############################################################################"
#
# This one Makefile serves all of converse and charm.  It includes
# rules for building:
#
#     * The CONVERSE libraries
#     * Charm++ runtime
#     * ITC++ Translator
#     * Languages
#     * Documentation
# 
# This Makefile is common to all machines.  This works because the charmc
# is smart enough to "conceal" the differences between machines.  charmc
# gets its smarts by reading the conv-mach.sh configuration file.
#
# If you wish to compile with debugging, optimization, or some other charm
# option, you can do so by setting OPTS.  For example, if you need a lot
# of debugging information, you could type:
#
#     make charm++ OPTS="-g -save -verbose"
#
###############################################################################

SHELL=/bin/sh
L=../lib

all: charm++ bluegene LIBS AMPI f90charm TSM SM PVM doc

charm++: converse libck.a loadbalancers charmxi

bluegene: charm++ libconv-bluegene.a

for-namd: charm++ pvm AMPIC

TSM: converse libtsm.a

SM: converse libsm.a

PVM: converse libpvmc.a

AMR: charm++ LIBS
	cd libs/ck-libs/amr; make all OPTS='$(OPTS)'

FEM: charm++ CONVLIBS FEMC LIBS FEMF

FEMC: charm++ LIBS

FEMF: FEMC libconv-utilf.a

MBLOCK: AMPI MBLOCKC MBLOCKF

MBLOCKC: charm++ LIBS

MBLOCKF: MBLOCKC libconv-utilf.a

AMPI: charm++ CONVLIBS AMPIC AMPIF

AMPIC: charm++ LIBS

AMPIF: AMPIC libconv-utilf.a

f90charm: charm++ libf90charm.a

multicast:
	cd libs/ck-libs/multicast && make

translators: charmxi conv-cpm

LIBS: CONVLIBS CHARMLIBS
	cd libs; make otherlibs OPTS='$(OPTS)'

test-all: all
	cd ../pgms ; make test-all  OPTS='$(OPTS)'

test-converse: converse
	cd ../pgms ; make test-converse  OPTS='$(OPTS)'

test-charm: charm++
	cd ../pgms ; make test-charm  OPTS='$(OPTS)'

test-AMPI: AMPI
	cd ../pgms ; make test-AMPI  OPTS='$(OPTS)'

test-fem: FEM
	cd ../pgms ; make test-fem  OPTS='$(OPTS)'

ps-doc: basics
	cd doc ; make ps

pdf-doc: basics
	cd doc ; make pdf

html-doc: basics
	cd doc ; make html

doc: basics
	cd doc ; make doc

CHARMC=../bin/charmc $(CHARMOPTS) $(OPTS)

SEQCHARMC=../bin/charmc -seq $(CHARMOPTS)


###############################################################################
#
# The basics (bin, lib, include, headers, charmc, conv-mach.sh)
#
###############################################################################

CVHEADERS=cpthreads.h converse.h conv-trace.h trace.h charm-api.h\
      conv-ccs.h ccs-client.c ccs-client.h ccs-auth.c ccs-auth.h CcsServer.java \
      debug-conv.h debug-charm.h conv-autoconfig.h \
      conv-common.h conv-mach.h conv-mach-opt.h conv-mach.sh conv-mach-opt.sh \
      CkMarshall.decl.h CkArray.decl.h CkLocation.decl.h CkReduction.decl.h \
      CkFutures.decl.h LBDatabase.decl.h CentralLB.decl.h NullLB.decl.h \
      RandCentLB.decl.h RecBisectBfLB.decl.h BaseLB.decl.h \
      MetisLB.decl.h RefineLB.decl.h \
      HeapCentLB.decl.h NborBaseLB.decl.h NeighborLB.decl.h \
      WSLB.decl.h GreedyRefLB.decl.h RandRefLB.decl.h \
      tempo.decl.h waitqd.decl.h \
	  CommLB.decl.h Comm1LB.decl.h  \
	  BlueGene.decl.h blue.h

# The .c files are there to be #included by clients whole
# This is a bit unusual, but makes client linking simpler.
UTILHEADERS=pup.h pup_c.h ckhashtable.h cklists.h conv-lists.h \
	sockRoutines.h sockRoutines.c

CKHEADERS=ck.h ckstream.h envelope.h init.h qd.h charm.h charm++.h \
	  ckfutures.h ckcallback.h ckarray.h cklocation.h ckreduction.h readonly.h \
	  $(UTILHEADERS) \
	  tempo.h waitqd.h LBDatabase.h lbdb.h \
	  LBDBManager.h LBComm.h LBOM.h LBObj.h LBMachineUtil.h \
	  Refiner.h ObjGraph.h heap.h elements.h CommLBHeap.h \
	  BaseLB.h CentralLB.h RandCentLB.h RecBisectBfLB.h \
	  RefineLB.h HeapCentLB.h CommLB.h Comm1LB.h manager.h \
	  MetisLB.h NborBaseLB.h \
	  NeighborLB.h WSLB.h GreedyRefLB.h RandRefLB.h \
	  BlueGene.h middle.h middle-blue.h \
	  $(CVHEADERS)

ALLHEADERS=$(CKHEADERS) \
    simplemsg.h sm.h pvmc.h pvm3.h sdag.h \
	graph.h bitvecset.h Set.h

basics: headers
	touch basics

# Headers is used only for the dependencies
headers: dirs+sources headerlinks $(ALLHEADERS)

conv-autoconfig.h:
	./charmconfig

headerlinks: dirs+sources Makefile $(ALLHEADERS)
	@echo "Soft-linking headers..."
	-@for hdr in $(ALLHEADERS) ; do test ! -f "../include/$$hdr" && ./system_ln "../tmp/$$hdr" ../include ; done
	touch headerlinks	

dirs+sources:
	rm -f .gdir
#	(cd .. ; basename `pwd`) 			> .vdir
	(cd .. ; basename `pwd` | sed -e 's@-.*@@') 	> .gdir
	find . -type l -exec rm {} \;
	rm -rf QuickThreads
	rm -rf libs
	rm -rf ../bin ; mkdir ../bin
	rm -rf ../lib ; mkdir ../lib
	rm -rf ../pgms
	rm -rf ../doc ; ln -s ../doc ../doc
	../../src/Common/scripts/gatherflat ../../src/Common/scripts .
	./gatherflat ../../src/Common/conv-core        .
	./gatherflat ../../src/Common/conv-ldb         .
	./gatherflat ../../src/Common/conv-ccs         .
	./gatherflat ../../src/Common/ck-core          .
	./gatherflat ../../src/Common/util             .
	./gatherflat ../../src/Common/ck-perf          .
	./gatherflat ../../src/Common/ck-ldb           .
	./gatherflat ../../src/Common/langs/simplemsg  .
	./gatherflat ../../src/Common/langs/pvmc       .
	./gatherflat ../../src/Common/langs/bluegene   .
	./gatherflat ../../src/Common/langs/f90charm   .
	./gatherflat ../../src/Common/xlat-i           .
	./gatherflat ../../src/Common/xlatcpm          .
	./gathertree ../../src/QuickThreads QuickThreads
	./gathertree ../../src/Common/libs libs
	./gathertree ../../src/Common/langs langs
	./gathertree ../../src/Common.`cat .gdir`      .
	./gatherflat ../../src/`cat .vdir`             .
	./gathertree ../../pgms ../pgms
	rm -f ../bin/charmc ; cp charmc ../bin/
	chmod +x ../bin/charmc
	rm -f .gdir
	rm -rf ../include ; mkdir ../include
	./system_ln  ../tmp/conv-mach.sh ../include
	./system_ln  ../tmp/conv-mach-opt.sh ../include
	./system_ln  ../tmp/conv-mach-pre.sh ../include
	if [ ! -f conv-common.h ] ; then ( touch conv-common.h ) ; fi
	touch dirs+sources


###############################################################################
#
# Converse Libraries
#
###############################################################################
CLBLIBS=$(L)/libldb-rand.o $(L)/libldb-spray.o $(L)/libldb-graph.o $(L)/libldb-test.o $(L)/libldb-bluegene.o
TRACELIBS=$(L)/libtrace-projections.a $(L)/libtrace-summary.a
MEMLIBS=$(L)/libmemory-default.o $(L)/libmemory-os.o $(L)/libmemory-gnu.o \
   $(L)/libmemory-verbose.o $(L)/libmemory-paranoid.o

CVLIBS=libconv-core.a \
	libconv-cplus-n.a libconv-cplus-y.a libconv-util.a \
	$(CLBLIBS) $(TRACELIBS) $(MEMLIBS) \
	libccs-client.a

LIBCONV_CORE=threads.o convcore.o conv-conds.o queueing.o msgmgr.o \
	cpm.o cpthreads.o futures.o cldb.o random.o trace-common.o \
	debug-conv.o generate.o edgelist.o conv-ccs.o ccs-builtins.o \
	quiescence.o isomalloc.o

LIBCONV_UTIL=pup_util.o pup_xlater.o pup_c.o ckhashtable.o sockRoutines.o conv-lists.o

LIBCONV_UTILF=pup_f.o

converse: basics QuickThreads/libqt.a $(CVLIBS) fmain-ok charmrun-target conv-cpm

charmrun-target: daemon-target sockRoutines.c sockRoutines.h ccs-server.c ccs-server.h
	if [ -d charmrun ] ; then ( cd charmrun ; make OPTS='$(OPTS)' ) ; fi
	if [ -f charmrun ] ; then ( cp charmrun ../bin ) ; fi

daemon-target: sockRoutines-seq.o
	if test -f daemon.c ; then $(CHARMC) -seq daemon.c \
		sockRoutines-seq.o -o ../bin/charmd; fi 
	if test -f daemon.c ; then $(CHARMC) -DFACELESS -seq daemon.c \
		sockRoutines-seq.o -o ../bin/charmd_faceless; fi 
	touch daemon-target

fmain-ok: fmain.f90
	-@$(CHARMC) -c fmain.f90
	-@cp fmain.o ../lib
	-@touch fmain-ok

QuickThreads/libqt.a:
	. ./conv-mach.sh;. ./conv-mach-opt.sh; cd QuickThreads;./configure $$CMK_QT
	rm -f QuickThreads/libqt.a
	cd QuickThreads ; make qt  OPTS='$(OPTS)'
	cp QuickThreads/libqt.a ../lib/libckqt.a

CONVLIBS: converse
	cd libs; make convlibs OPTS='$(OPTS)'

libconv-core.a: $(LIBCONV_CORE)
	$(CHARMC) -cp ../lib/ -o $@ $(LIBCONV_CORE)

libconv-cplus-y.a: machine.c $(CVHEADERS)	
	$(CHARMC) -cp ../lib/ -o $@ -DFOR_CPLUS=1 machine.c

libconv-cplus-n.a: machine.c $(CVHEADERS)
	$(CHARMC) -cp ../lib/ -o $@ -DFOR_CPLUS=0 machine.c

libconv-util.a: $(LIBCONV_UTIL)
	$(CHARMC) -cp ../lib/ -o $@ $(LIBCONV_UTIL)

libconv-utilf.a: $(LIBCONV_UTILF)
	-@$(CHARMC) -cp ../lib/ -o $@ $(LIBCONV_UTILF)

libccs-client.a: ccs-client.o
	$(CHARMC) -cp ../lib/ -o $@ ccs-client.o

cpm.o: cpm.c $(CVHEADERS)
	$(CHARMC) cpm.c

isomalloc.o: isomalloc.c $(CVHEADERS)
	$(CHARMC) isomalloc.c

threads.o: threads.c $(CVHEADERS)
	$(CHARMC) -IQuickThreads threads.c

convcore.o: convcore.c $(CVHEADERS)
	$(CHARMC) convcore.c

conv-ccs.o: conv-ccs.c $(CVHEADERS)
	$(CHARMC) conv-ccs.c

ccs-builtins.o: ccs-builtins.C $(CVHEADERS)
	$(CHARMC) ccs-builtins.C

ccs-client.o: ccs-client.c
	$(CHARMC) ccs-client.c

sockRoutines.o: sockRoutines.c $(CVHEADERS) $(UTILHEADERS)
	$(CHARMC) sockRoutines.c

sockRoutines-seq.o: sockRoutines.c $(CVHEADERS) $(UTILHEADERS)
	$(CHARMC) -seq -o sockRoutines-seq.o sockRoutines.c

random.o: random.c $(CVHEADERS)
	$(CHARMC) random.c

queueing.o: queueing.c $(CVHEADERS)
	$(CHARMC) queueing.c

conv-conds.o: conv-conds.c $(CVHEADERS)
	$(CHARMC) conv-conds.c

futures.o: futures.c $(CVHEADERS)
	$(CHARMC) futures.c

msgmgr.o: msgmgr.c $(CVHEADERS)
	$(CHARMC) msgmgr.c

cpthreads.o: cpthreads.c $(CVHEADERS)
	$(CHARMC) cpthreads.c

debug-conv.o: debug-conv.c $(CVHEADERS)
	$(CHARMC) debug-conv.c

edgelist.o : edgelist.c ../../src/Common/conv-ldb/typedefs.h $(CVHEADERS)
	$(CHARMC) -I../../src/Common/conv-ldb/ edgelist.c

generate.o : generate.c ../../src/Common/conv-ldb/typedefs.h $(CVHEADERS)
	$(CHARMC) -I../../src/Common/conv-ldb/ generate.c

cldb.o: cldb.c ../../src/Common/conv-ldb/cldb.h $(CVHEADERS)
	$(CHARMC) -I../../src/Common/conv-ldb/ cldb.c

quiescence.o: quiescence.c $(CVHEADERS)
	$(CHARMC) quiescence.c

pup_util.o: pup_util.C $(UTILHEADERS)
	$(CHARMC) -o pup_util.o pup_util.C

pup_xlater.o: pup_xlater.C $(UTILHEADERS)
	$(CHARMC) -o pup_xlater.o pup_xlater.C

pup_c.o: pup_c.C $(UTILHEADERS)
	$(CHARMC) -o pup_c.o pup_c.C

pup_f.o: pup_f.f90
	-@$(CHARMC) -c pup_f.f90
	-@$(CHARMC) -cpmod ../include pupmod.M

ckhashtable.o: ckhashtable.C ckhashtable.h
	$(CHARMC) -o ckhashtable.o ckhashtable.C

conv-lists.o: conv-lists.C $(UTILHEADERS)
	$(CHARMC) -o conv-lists.o conv-lists.C

## Converse load balancers (seed balancers, -balance)
$(L)/libldb-rand.o: cldb.rand.c ../../src/Common/conv-ldb/cldb.h $(CVHEADERS)
	$(CHARMC) -I../../src/Common/conv-ldb/ -o $@ cldb.rand.c

$(L)/libldb-graph.o: cldb.graph.c ../../src/Common/conv-ldb/cldb.graph.h $(CVHEADERS)
	$(CHARMC) -I../../src/Common/conv-ldb/ -o $@ cldb.graph.c 

$(L)/libldb-spray.o: cldb.spray.c $(CVHEADERS)
	$(CHARMC) -o $@ cldb.spray.c

$(L)/libldb-test.o: cldb.test.c $(CVHEADERS)
	$(CHARMC) -o $@ cldb.test.c

$(L)/libldb-bluegene.o: cldb.bluegene.c $(CVHEADERS)
	$(CHARMC) -o $@ cldb.bluegene.c

## Memory allocation libraries (-memory)
MEM_DEPS=memory.c memory-gnu.c converse.h conv-mach.h
$(L)/libmemory-default.o: $(MEM_DEPS)
	$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_DEFAULT memory.c

$(L)/libmemory-os.o: $(MEM_DEPS)
	$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_OS memory.c

# If the system doesn't have sbrk, these compilations may fail.
#  This is OK, but then we can't use "-memory gnu" or friends.
$(L)/libmemory-gnu.o: $(MEM_DEPS)
	-$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_GNU memory.c

$(L)/libmemory-verbose.o: memory-verbose.c $(MEM_DEPS)
	-$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_VERBOSE memory.c

$(L)/libmemory-paranoid.o: memory-paranoid.c $(MEM_DEPS)
	-$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_PARANOID memory.c

$(L)/libmemory-cache.o: memory-cache.c $(MEM_DEPS)
	-$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_CACHE memory.c

###############################################################################
#
# Charm Libraries
#
###############################################################################

CK_LIBS_CORE=libck.a

LIBCK_CORE=init.o register.o qd.o ck.o main.o msgalloc.o ckfutures.o \
           debug-message.o ckcallback.o cklocation.o ckarray.o ckreduction.o \
           tempo.o waitqd.o LBDatabase.o lbdb.o \
           LBDBManager.o LBComm.o LBObj.o LBMachineUtil.o \
	   BaseLB.o CentralLB.o NborBaseLB.o WSLB.o ObjGraph.o graph.o  \
           Refiner.o bitvecset.o Set.o heap.o CommLBHeap.o NullLB.o \
	   compat_regmm.o

CHARMLIBS: charm++
	cd libs; make charmlibs OPTS='$(OPTS)'

libck.a: $(LIBCK_CORE)
	$(CHARMC) -cp ../lib/ -o $@ $(LIBCK_CORE)

CkFutures.decl.h CkFutures.def.h : ckfutures.ci charmxi
	$(CHARMC) ckfutures.ci

tempo.decl.h tempo.def.h : tempo.ci charmxi
	$(CHARMC) tempo.ci

waitqd.decl.h waitqd.def.h : waitqd.ci charmxi
	$(CHARMC) waitqd.ci

LBDatabase.decl.h LBDatabase.def.h : LBDatabase.ci charmxi
	$(CHARMC) LBDatabase.ci

NullLB.decl.h NullLB.def.h : NullLB.ci charmxi
	$(CHARMC) NullLB.ci

BaseLB.decl.h BaseLB.def.h : BaseLB.ci charmxi
	$(CHARMC) BaseLB.ci

init.o: init.C $(CKHEADERS)
	$(CHARMC) -o init.o init.C

msgalloc.o: msgalloc.C $(CKHEADERS)
	$(CHARMC) -o msgalloc.o msgalloc.C

register.o: register.C $(CKHEADERS)
	$(CHARMC) -o register.o register.C

ckfutures.o: ckfutures.C $(CKHEADERS)
	$(CHARMC) -o ckfutures.o ckfutures.C

tempo.o: tempo.C $(CKHEADERS)
	$(CHARMC) -o tempo.o tempo.C

qd.o: qd.C $(CKHEADERS)
	$(CHARMC) -o qd.o qd.C

main.o: main.C $(CKHEADERS)
	$(CHARMC) -o main.o main.C

debug-message.o: debug-message.C $(CKHEADERS)
	$(CHARMC) -I. debug-message.C

ck.o: ck.C $(CKHEADERS)
	$(CHARMC) -o ck.o ck.C

waitqd.o: waitqd.C $(CKHEADERS)
	$(CHARMC) -o waitqd.o waitqd.C

CkReduction.decl.h CkReduction.def.h: ckreduction.ci charmxi
	$(CHARMC) ckreduction.ci

ckreduction.o: ckreduction.C $(CKHEADERS)
	$(CHARMC) -o ckreduction.o ckreduction.C

CkMarshall.decl.h CkMarshall.def.h : ckmarshall.ci charmxi
	$(CHARMC) ckmarshall.ci

CkArray.decl.h CkArray.def.h : ckarray.ci charmxi
	$(CHARMC) ckarray.ci

ckarray.o: ckarray.C $(CKHEADERS)
	$(CHARMC) -o ckarray.o ckarray.C

CkLocation.decl.h: cklocation.ci charmxi
	$(CHARMC) cklocation.ci

cklocation.o: cklocation.C $(CKHEADERS)
	$(CHARMC) -c cklocation.C

ckcallback.o: ckcallback.C $(CKHEADERS) CkCallback.decl.h
	$(CHARMC) -c ckcallback.C

CkCallback.decl.h: ckcallback.ci $(CHARMXI)
	$(CHARMC) ckcallback.ci

## Charm++ Load balancer (Dynamic load balancer)

BaseLB.o: BaseLB.C $(CKHEADERS)
	$(CHARMC) -c BaseLB.C

lbdb.o: lbdb.C $(CKHEADERS)
	$(CHARMC) -o lbdb.o lbdb.C

LBDBManager.o:	LBDBManager.C $(CKHEADERS)
	$(CHARMC) -o LBDBManager.o LBDBManager.C

LBComm.o:	LBComm.C $(CKHEADERS)
	$(CHARMC) -o LBComm.o LBComm.C

LBObj.o: LBObj.C $(CKHEADERS)
	$(CHARMC) -o LBObj.o LBObj.C

LBMachineUtil.o: LBMachineUtil.C $(CKHEADERS)
	$(CHARMC) -o LBMachineUtil.o LBMachineUtil.C

LBDatabase.o: LBDatabase.C $(CKHEADERS)
	$(CHARMC) -o LBDatabase.o LBDatabase.C

NullLB.o: NullLB.C $(CKHEADERS)
	$(CHARMC) -c NullLB.C

Refiner.o: Refiner.C $(CKHEADERS)
	$(CHARMC) -o Refiner.o Refiner.C

ObjGraph.o: ObjGraph.C $(CKHEADERS)
	$(CHARMC) -o ObjGraph.o ObjGraph.C

graph.o: graph.c 
	$(CHARMC) -o graph.o graph.c

bitvecset.o: bitvecset.c bitvecset.h
	$(CHARMC) -o bitvecset.o bitvecset.c

Set.o: Set.C $(CKHEADERS) Set.h elements.h 
	$(CHARMC) -o Set.o Set.C

heap.o: heap.C $(CKHEADERS) elements.h heap.h
	$(CHARMC) -o heap.o heap.C

CentralLB.decl.h: CentralLB.ci charmxi
	$(CHARMC) CentralLB.ci

CentralLB.o: CentralLB.C CentralLB.decl.h $(CKHEADERS)
	$(CHARMC) -c CentralLB.C

NborBaseLB.decl.h: NborBaseLB.ci charmxi
	$(CHARMC) NborBaseLB.ci

NborBaseLB.o: NborBaseLB.C NborBaseLB.decl.h $(CKHEADERS)
	$(CHARMC) -c NborBaseLB.C

WSLB.decl.h: WSLB.ci charmxi
	$(CHARMC) WSLB.ci

WSLB.o: WSLB.C WSLB.decl.h $(CKHEADERS)
	$(CHARMC) -c WSLB.C

CommLBHeap.o: CommLBHeap.C $(CKHEADERS)
	$(CHARMC) -c CommLBHeap.C

compat_regmm.o: compat_regmm.c
	$(CHARMC) -c compat_regmm.c

## Tracing libraries (profiling, -tracemode)
LIBTRACE_NONE=trace-none.o trace-common.o
$(L)/libtrace-none.a: $(LIBTRACE_NONE)
	$(CHARMC) -o $@ $(LIBTRACE_NONE)

LIBTRACE_PROJ=trace-projections.o trace-common.o
$(L)/libtrace-projections.a: $(LIBTRACE_PROJ)
	$(CHARMC) -o $@ $(LIBTRACE_PROJ)

LIBTRACE_SUMM=trace-summary.o trace-common.o
$(L)/libtrace-summary.a: $(LIBTRACE_SUMM)
	$(CHARMC) -o $@ $(LIBTRACE_SUMM)

trace-common.o: trace-common.C $(CKHEADERS)
	$(CHARMC) trace-common.C

trace-none.o : trace-none.C trace.h $(CKHEADERS)
	$(CHARMC) -o trace-none.o trace-none.C

trace-projections.o:trace-projections.C trace-projections.h trace.h $(CKHEADERS)
	$(CHARMC) -o trace-projections.o trace-projections.C

trace-summary.o:trace-summary.C trace-summary.h trace.h $(CKHEADERS)
	$(CHARMC) -o trace-summary.o trace-summary.C


###############################################################################
#
# Dynamic Load Balancers
#
###############################################################################

# This portion of the makefile automatically generated with Makefile_lb.sh
LOADBALANCERS=\
   $(L)/libmoduleRandCentLB.a \
   $(L)/libmoduleRecBisectBfLB.a \
   $(L)/libmoduleMetisLB.a \
   $(L)/libmoduleRefineLB.a \
   $(L)/libmoduleCommLB.a \
   $(L)/libmoduleComm1LB.a \
   $(L)/libmoduleHeapCentLB.a \
   $(L)/libmoduleNeighborLB.a \
   $(L)/libmoduleGreedyRefLB.a \
   $(L)/libmoduleRandRefLB.a 

RandCentLB.decl.h: RandCentLB.ci charmxi
	$(CHARMC) RandCentLB.ci

RandCentLB.o: RandCentLB.C RandCentLB.decl.h $(CKHEADERS)
	$(CHARMC) -c RandCentLB.C

$(L)/libmoduleRandCentLB.a: RandCentLB.o
	$(CHARMC) -o $(L)/libmoduleRandCentLB.a RandCentLB.o

RecBisectBfLB.decl.h: RecBisectBfLB.ci charmxi
	$(CHARMC) RecBisectBfLB.ci

RecBisectBfLB.o: RecBisectBfLB.C RecBisectBfLB.decl.h $(CKHEADERS)
	$(CHARMC) -c RecBisectBfLB.C

$(L)/libmoduleRecBisectBfLB.a: RecBisectBfLB.o
	$(CHARMC) -o $(L)/libmoduleRecBisectBfLB.a RecBisectBfLB.o

MetisLB.decl.h: MetisLB.ci charmxi
	$(CHARMC) MetisLB.ci

MetisLB.o: MetisLB.C MetisLB.decl.h $(CKHEADERS)
	$(CHARMC) -c MetisLB.C

$(L)/libmoduleMetisLB.a: MetisLB.o
	$(CHARMC) -o $(L)/libmoduleMetisLB.a MetisLB.o

RefineLB.decl.h: RefineLB.ci charmxi
	$(CHARMC) RefineLB.ci

RefineLB.o: RefineLB.C RefineLB.decl.h $(CKHEADERS)
	$(CHARMC) -c RefineLB.C

$(L)/libmoduleRefineLB.a: RefineLB.o
	$(CHARMC) -o $(L)/libmoduleRefineLB.a RefineLB.o

CommLB.decl.h: CommLB.ci charmxi
	$(CHARMC) CommLB.ci

CommLB.o: CommLB.C CommLB.decl.h manager.h $(CKHEADERS)
	$(CHARMC) -c CommLB.C 

manager.o: manager.C manager.h 
	$(CHARMC) -c manager.C

$(L)/libmoduleCommLB.a: CommLB.o manager.o
	$(CHARMC) -o $(L)/libmoduleCommLB.a CommLB.o manager.o

Comm1LB.decl.h: Comm1LB.ci charmxi
	$(CHARMC) Comm1LB.ci

Comm1LB.o: Comm1LB.C Comm1LB.decl.h $(CKHEADERS)
	$(CHARMC) -c Comm1LB.C

$(L)/libmoduleComm1LB.a: Comm1LB.o
	$(CHARMC) -o $(L)/libmoduleComm1LB.a Comm1LB.o

HeapCentLB.decl.h: HeapCentLB.ci charmxi
	$(CHARMC) HeapCentLB.ci

HeapCentLB.o: HeapCentLB.C HeapCentLB.decl.h $(CKHEADERS)
	$(CHARMC) -c HeapCentLB.C

$(L)/libmoduleHeapCentLB.a: HeapCentLB.o
	$(CHARMC) -o $(L)/libmoduleHeapCentLB.a HeapCentLB.o

NeighborLB.decl.h: NeighborLB.ci charmxi
	$(CHARMC) NeighborLB.ci

NeighborLB.o: NeighborLB.C NeighborLB.decl.h $(CKHEADERS)
	$(CHARMC) -c NeighborLB.C

$(L)/libmoduleNeighborLB.a: NeighborLB.o
	$(CHARMC) -o $(L)/libmoduleNeighborLB.a NeighborLB.o

GreedyRefLB.decl.h: GreedyRefLB.ci charmxi
	$(CHARMC) GreedyRefLB.ci

GreedyRefLB.o: GreedyRefLB.C GreedyRefLB.decl.h $(CKHEADERS)
	$(CHARMC) -c GreedyRefLB.C

$(L)/libmoduleGreedyRefLB.a: GreedyRefLB.o
	$(CHARMC) -o $(L)/libmoduleGreedyRefLB.a GreedyRefLB.o

RandRefLB.decl.h: RandRefLB.ci charmxi
	$(CHARMC) RandRefLB.ci

RandRefLB.o: RandRefLB.C RandRefLB.decl.h $(CKHEADERS)
	$(CHARMC) -c RandRefLB.C

$(L)/libmoduleRandRefLB.a: RandRefLB.o
	$(CHARMC) -o $(L)/libmoduleRandRefLB.a RandRefLB.o

LB_OBJ=EveryLB.o \
    RandCentLB.o \
    RecBisectBfLB.o \
    MetisLB.o \
    RefineLB.o \
    CommLB.o \
    manager.o \
    Comm1LB.o \
    HeapCentLB.o \
    NeighborLB.o \
    GreedyRefLB.o \
    RandRefLB.o 

EveryLB.o: EveryLB.C EveryLB.decl.h
	$(CHARMC) -c EveryLB.C

EveryLB.decl.h: EveryLB.ci
	$(CHARMC) EveryLB.ci

$(L)/libmoduleEveryLB.a: $(LB_OBJ)
	$(CHARMC) -o $(L)/libmoduleEveryLB.a $(LB_OBJ)

loadbalancers: $(LOADBALANCERS) $(L)/libmoduleEveryLB.a

###############################################################################
#
# BlueGene Emulator
#
###############################################################################

BlueGene.decl.h BlueGene.def.h : BlueGene.ci charmxi
	$(CHARMC) BlueGene.ci

libbluegene.a: BlueGene.C BlueGene.h BlueGene.decl.h BlueGene.def.h
	$(CHARMC) -c BlueGene.C
	$(CHARMC) -cp ../lib -o libbluegene.a BlueGene.o

blue.o:  blue.h blue_impl.h blue.C
	$(CHARMC) -c blue.C

libconv-bluegene.a:   blue.o
	$(CHARMC) -cp ../lib -o libconv-bluegene.a blue.o

###############################################################################
#
# The CPM scanner
#
###############################################################################

conv-cpm: conv-cpm.o
	$(SEQCHARMC) -o conv-cpm -cp ../bin/ conv-cpm.o

conv-cpm.o: conv-cpm.c
	$(SEQCHARMC) conv-cpm.c

###############################################################################
#
# The interface translator
#
###############################################################################

XIHEADERS=xi-symbol.h xi-util.h xi-grammar.tab.h
CHARMXI=xi-main.o xi-symbol.o xi-grammar.tab.o xi-scan.o xi-util.o
SDAGOBJ=sdag-main.o sdag-trans.o CLexer.o CParser.o CParsedFile.o CParseNode.o \
	sdag-globals.o CParseNodeProcess.o CEntry.o
SDAGHEADERS=CLexer.h CToken.h EToken.h CParser.h CParsedFile.h CParseNode.h \
	sdag-globals.h CEntry.h

charmxi: $(CHARMXI) $(SDAGOBJ)
	$(SEQCHARMC) -language c++ -cp ../bin/ -o charmxi $(CHARMXI) $(SDAGOBJ)

xi-main.o: xi-main.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) xi-main.C

xi-symbol.o: xi-symbol.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) xi-symbol.C

xi-util.o: xi-util.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) xi-util.C

xi-grammar.tab.o: xi-grammar.tab.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) xi-grammar.tab.C

xi-scan.o: xi-scan.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -I. -DYY_NEVER_INTERACTIVE xi-scan.C

sdag-main.o: sdag-main.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c sdag-main.C

sdag-trans.o: sdag-trans.c $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -I. -c sdag-trans.c

CLexer.o: CLexer.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c CLexer.C

CParser.o: CParser.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c CParser.C

CParsedFile.o: CParsedFile.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c CParsedFile.C

CParseNode.o: CParseNode.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c CParseNode.C

sdag-globals.o: sdag-globals.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c sdag-globals.C

CParseNodeProcess.o: CParseNodeProcess.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c CParseNodeProcess.C

CEntry.o: CEntry.C $(XIHEADERS) $(SDAGHEADERS)
	$(SEQCHARMC) -c CEntry.C

###############################################################################
#
# Simple Messaging
#
###############################################################################

libtsm.a: converse simplemsg.c simplemsg.h
	$(CHARMC) -cp ../lib/ -o $@ simplemsg.c

libsm.a: converse sm.c sm.h
	$(CHARMC) -cp ../lib/ -o $@ sm.c

###############################################################################
#
# PVM
#
###############################################################################

PVMC=pvmc_buf.o pvmc_comm.o pvmc_conv.o pvmc_main.o pvmc_pack.o pvmc_groups.o

libpvmc.a: $(PVMC)
	$(CHARMC) -cp ../lib -o libpvmc.a $(PVMC)

pvmc_buf.o: pvmc_buf.c pvmc.h pvm3.h
	$(CHARMC) -o $@ pvmc_buf.c

pvmc_conv.o: pvmc_conv.c pvmc.h pvm3.h
	$(CHARMC) -o $@ pvmc_conv.c

pvmc_pack.o: pvmc_pack.c pvmc.h pvm3.h
	$(CHARMC) -o $@ pvmc_pack.c

pvmc_comm.o: pvmc_comm.c pvmc.h pvm3.h
	$(CHARMC) -o $@ pvmc_comm.c

pvmc_groups.o: pvmc_groups.c pvmc.h pvm3.h
	$(CHARMC) -o $@ pvmc_groups.c

pvmc_main.o: pvmc_main.c pvmc.h pvm3.h
	$(CHARMC) -o $@ pvmc_main.c

libf90charm.a: f90main.ci f90main.h f90main.C charmf.h charmf.C futil.f90
	$(CHARMC) f90main.ci
	$(CHARMC) -c -DAMPI_FORTRAN=1 f90main.C
	$(CHARMC) -c -DAMPI_FORTRAN=1 charmf.C
	-$(CHARMC) -c futil.f90
	-$(CHARMC) -cp ../lib -o libf90charm.a f90main.o charmf.o futil.o

###############################################################################
#
# Make clean
#
###############################################################################

clean:
	rm -f conv-autoconfig.h config.cache
	rm -f QuickThreads/libqt.a
	rm -f charmxi conv-cpm
	rm -f TAGS basics cmk_extras core
	rm -f core *.a
	rm -f core *.o
	rm -f core #*#
	rm -f core *~
	if [ -d charmrun ] ; then ( cd charmrun; make clean ) ; fi
	-( cd doc && make clean )
	( cd libs; make clean )
	( cd ../pgms; make clean )

veryclean:
	rm -rf ../bin
	rm -rf ../lib
	rm -rf ../src
	rm -rf ../pgms
	rm -rf ../include
	rm -rf ../doc
	mv Makefile .Makefile
	rm -rf [a-z]* [A-Z]*
	mv .Makefile Makefile
	rm -rf .[a-z]* .[A-Z]*


charmconfig: configure.in
	autoconf && autoheader && /bin/mv -f configure charmconfig
