# Mark Huang <mlhuang@cs.princeton.edu>
# Copyright (C) 2003-2006 The Trustees of Princeton University
#
-# $Id: Rules.mk,v 1.28 2007/02/09 01:16:19 thierry Exp $
+# $Id: Rules.mk,v 1.37 2007/09/10 22:24:20 mef Exp $
#
# Base rpmbuild in the current directory
#
SPECFILE := SPECS/$(notdir $(SPEC))
+MULTI_MODULE := $(word 2,$(MODULE))
+# is there a single module ? to mimick cvs export -d behaviour
+ifeq "$(MULTI_MODULE)" ""
+ _MAINMODULE := $(MODULE)
+else
+ _MAINMODULE := $(firstword $(MODULE))
+endif
$(SPECFILE):
mkdir -p SPECS
# Define cvstag for tagged builds
echo "%define cvstag $(TAG)" >> $@
endif
- $(if $($(package)-SVNPATH),\
- svn cat $($(package)-SVNPATH)/$(SPEC) >> $@,\
- cvs -d $(CVSROOT) checkout -r $(TAG) -p $(SPEC) >> $@)
-
+ $(if $($(package)-CVSROOT), cvs -d $($(package)-CVSROOT) checkout -r $(TAG) -p $(_MAINMODULE)/$(SPEC) >> $@; ,\
+ $(if $($(package)-SVNPATH), svn cat $($(package)-SVNPATH)/$(_MAINMODULE)/$(TAG)/$(SPEC) >> $@; ,\
+ $(if $(CVSROOT), cvs -d $(CVSROOT) checkout -r $(TAG) -p $(_MAINMODULE)/$(SPEC) >> $@; ,\
+ $(if $(SVNPATH), svn cat $(SVNPATH)/$(_MAINMODULE)/$(TAG)/$(SPEC) >> $@; ) \
+ )\
+ )\
+ )
#
# Parse spec file into Makefile fragment
MK := tmp/$(package).mk
-parseSpec: CFLAGS := -g -Wall
+parseSpec: CFLAGS := -g -Wall -D_GNU_SOURCE
parseSpec: LDFLAGS := -lrpm -lrpmbuild
# and/or to be extracted from their SVNPATH
#
# is there a single module ? to mimick cvs export -d behaviour
-MULTI_MODULE := $(word 2,$(MODULE))
ifeq "$(MULTI_MODULE)" ""
# single module: do as before
SOURCES/$(package):
- mkdir -p SOURCES
- $(if $($(package)-SVNPATH),\
- cd SOURCES && svn export $($(package)-SVNPATH) $(package),\
- cd SOURCES && cvs -d $(CVSROOT) export -r $(TAG) -d $(package) $(MODULE))
+ mkdir -p SOURCES && cd SOURCES && \
+ (\
+ $(if $($(package)-CVSROOT), cvs -d $($(package)-CVSROOT) export -r $(TAG) -d $(package) $(MODULE); ,\
+ $(if $($(package)-SVNPATH), svn export $($(package)-SVNPATH)/$(MODULE)/$(TAG) $(package) ; ,\
+ $(if $(CVSROOT), cvs -d $(CVSROOT) export -r $(TAG) -d $(package) $(MODULE); ,\
+ $(if $(SVNPATH), svn export $(SVNPATH)/$(MODULE)/$(TAG) $(package) ;) \
+ )\
+ )\
+ )\
+ )
else
# multiple modules : iterate
SOURCES/$(package):
- mkdir -p SOURCES/$(package) && cd SOURCES/$(package) && (\
- $(foreach module,$(MODULE),\
- $(if $($(module)-SVNPATH), \
- svn export $($(module)-SVNPATH) $(module), \
- cvs -d $(if $($(module)-CVSROOT),$($(module)-CVSROOT),$(CVSROOT)) export -r $(TAG) $(module);\
- )))
+ mkdir -p SOURCES/$(package) && cd SOURCES/$(package) && \
+ $(foreach module,$(MODULE),\
+ $(if $($(module)-CVSROOT), cvs -d $($(module)-CVSROOT) export -r $(TAG) -d $(module) $(module); ,\
+ $(if $($(module)-SVNPATH), svn export $($(module)-SVNPATH)/$(module)/$(TAG) $(module) ; ,\
+ $(if $(CVSROOT), cvs -d $(CVSROOT) export -r $(TAG) -d $(module) $(module); ,\
+ $(if $(SVNPATH), svn export $(SVNPATH)/$(module)/$(TAG) $(module) ;) \
+ )\
+ )\
+ )\
+ )
endif
# Make a hard-linked copy of the exported directory for each Source
# Build SRPM
$(SRPM): $(SPECFILE) $(SOURCES)
mkdir -p SRPMS
- rpmbuild $(RPMFLAGS) -bs $<
+ $(RPMBUILD) $(RPMFLAGS) -bs $<
# Base rpmbuild in the current directory
.rpmmacros: