-SIMGRID_INSTALL_DIR := ./simgrid-3.5-install
-#SIMGRID_INSTALL_DIR := ../simgrid-git-install
+SIMGRID_INSTALL_DIR := ./simgrid-stable
+#SIMGRID_INSTALL_DIR := ./simgrid-dev
OPTIM_FLAGS += -O3
DEBUG_FLAGS += -g
CPPFLAGS += $(CHECK_FLAGS)
CFLAGS += -std=c99
-CFLAGS += -fgnu89-inline # workaround simgrid bug
+#CFLAGS += -fgnu89-inline # workaround simgrid bug
CFLAGS += $(OPTIM_FLAGS) $(DEBUG_FLAGS)
+#CXXFLAGS += -std=c++0x
CXXFLAGS += $(OPTIM_FLAGS) $(DEBUG_FLAGS)
LDFLAGS += -L $(SIMGRID_INSTALL_DIR)/lib
LINK.o = $(CXX) $(LDFLAGS) $(TARGET_ARCH)
LDLIBS := -lsimgrid
-MAKEDEPEND.FLAGS = $(CPPFLAGS) -MM -MF $@ $<
+MAKEDEPEND.FLAGS = $(CPPFLAGS) -MM -MG -MF $@ $<
MAKEDEPEND.C = $(CC) $(MAKEDEPEND.FLAGS)
MAKEDEPEND.CXX = $(CXX) $(MAKEDEPEND.FLAGS)
-LOCALVERSION := localversion
-SETLOCALVERSION := ./setlocalversion
-
SRC.loba := main.cpp \
communicator.cpp \
cost_func.cpp \
+ deployment.cpp \
+ hostdata.cpp \
+ $(wildcard loba_*.cpp) \
+ misc.cpp \
neighbor.cpp \
options.cpp \
process.cpp \
TARGETS := loba simple_async
-$(shell $(SETLOCALVERSION))
-
-.PHONY: all depend clean
+.PHONY: all clean realclean
all: $(TARGETS)
clean:
$(RM) core core.[0-9]* vgcore.[0-9]*
- $(RM) $(LOCALVERSION)
+ $(RM) misc_autogen.h
+ $(RM) localversion
$(RM) $(OBJ)
$(RM) $(DEP)
$(RM) $(TARGETS)
%.d: %.c ; $(MAKEDEPEND.C)
%.d: %.cpp ; $(MAKEDEPEND.CXX)
+misc_autogen.h: $(SIMGRID_INSTALL_DIR)/include/xbt/log.h
+ grep -C1 '# *define *CLOG' $< \
+ | sed 's/CLOG/XCLOG/;s/_XBT_LOGV\(([^)]*)\)/(*\1)/' > $@
+
version.o: $(patsubst %.cpp,%.o,$(filter-out version.cpp, $(SRC.loba)))
--include $(DEP)
+ifneq ($(MAKECMDGOALS),clean)
+ ifneq ($(MAKECMDGOALS),realclean)
+ $(shell ./setlocalversion)
+ -include $(DEP)
+ endif
+endif
.SECONDEXPANSION:
$(TARGETS): $$(patsubst %.cpp,%.o,$$(SRC.$$@))