git has an interface for cloning SVN repositories into git which some users might decide to use. For those users' surprise, the repository will always fail to build on svnonly target and it will exit early.
The problem is simple enough to fix by just checking if a .git directory exists in top_builddir and, if so, call git svn info insstead of svn info. Note, however, that this only supports Linux (and possibly Mac) users, as I have no means of writing/testing an equivalent patch for the Windows Makefiles. Signed-off-by: Felipe Balbi <ba...@kernel.org> --- Due to lack of a Windows system, this has only been tested on my linux box, if someone could give this a whirl on windows and Mac OS X, I'd be really glad. cheers Makefile.in | 5 ++++- src/include/Makefile.win | 7 +++++-- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/Makefile.in b/Makefile.in index 44b0a3b4b99f..10415abd442b 100644 --- a/Makefile.in +++ b/Makefile.in @@ -9,6 +9,9 @@ top_builddir = . include $(top_builddir)/Makeconf +GIT := `if [ -d "$(top_builddir)/.git" ]; then \ + echo "git"; fi` + distdir = $(PACKAGE)-$(VERSION) INSTFILES = COPYING NON_SVN_INSTFILES = SVN-REVISION @@ -104,7 +107,7 @@ svnonly: @if test ! -f "$(srcdir)/doc/FAQ" || test -f non-tarball ; then \ (cd doc/manual && $(MAKE) front-matter html-non-svn) ; \ touch non-tarball ; \ - (cd $(srcdir); LC_ALL=C TZ=GMT svn info || $(ECHO) "Revision: -99") 2> /dev/null \ + (cd $(srcdir); LC_ALL=C TZ=GMT $(GIT) svn info || $(ECHO) "Revision: -99") 2> /dev/null \ | sed -n -e '/^Revision/p' -e '/^Last Changed Date/'p \ | cut -d' ' -f1,2,3,4 > SVN-REVISION-tmp ; \ if test "`cat SVN-REVISION-tmp`" = "Revision: -99"; then \ diff --git a/src/include/Makefile.win b/src/include/Makefile.win index 28361ef9cfa3..d81941f80f4f 100644 --- a/src/include/Makefile.win +++ b/src/include/Makefile.win @@ -2,6 +2,9 @@ include ../gnuwin32/MkRules R_HOME = ../.. +GIT := `if [ -d "$(top_builddir)/.git" ]; then \ + echo "git"; fi` + VER = $(shell sed -e 's/\([^ ]*\).*/\1/' ../../VERSION) ## keep these in step with ./Makefile.in @@ -67,14 +70,14 @@ ifdef USE_SVNVERSION @LC_ALL=C svnversion ../.. | sed -n 's/^/Revision: /p' > svn-tmp || rm -f svn-tmp @grep -v exported svn-tmp > /dev/null || rm -f svn-tmp else - @(cd ../..; LC_ALL=C svn info || echo "Revision: unknown") 2> /dev/null \ + @(cd ../..; LC_ALL=C $(GIT) svn info || echo "Revision: unknown") 2> /dev/null \ | sed -n '/^Revision/p' > svn-tmp @if grep unknown svn-tmp > /dev/null ; then \ rm svn-tmp; \ fi endif @if test -f svn-tmp ; then \ - (cd ../..; LC_ALL=C TZ=GMT svn info || echo "Last Changed Date: unknown") 2> /dev/null \ + (cd ../..; LC_ALL=C TZ=GMT $(GIT) svn info || echo "Last Changed Date: unknown") 2> /dev/null \ | sed -n '/^Last Changed Date:/p' | sed 's/[0-9][0-9]:.*//' \ >> svn-tmp ; \ else \ -- 2.3.0-rc1 ______________________________________________ R-devel@r-project.org mailing list https://stat.ethz.ch/mailman/listinfo/r-devel