diff --git a/Recipe b/Recipe index 952373f2..3b2db901 100644 --- a/Recipe +++ b/Recipe @@ -134,13 +134,15 @@ # ------------------------------------------------------------ # Additional text added verbatim to each individual Makefile. -!cflags am version -DSOURCE_COMMIT=\"`git rev-parse HEAD 2>/dev/null`\" +!cflags am version !begin am +if AUTO_GIT_COMMIT BUILT_SOURCES = empty.h CLEANFILES = empty.h +libversion_a_CFLAGS += -DSOURCE_COMMIT=\"`git --git-dir=$(srcdir)/.git rev-parse HEAD 2>/dev/null`\" empty.h: $(allsources) echo '/* Empty file touched by automake makefile to force rebuild of version.o */' >$@ - +endif !end !begin >empty.h /* Empty file touched by automake makefile to force rebuild of version.o */ diff --git a/configure.ac b/configure.ac index e951a286..adb31915 100644 --- a/configure.ac +++ b/configure.ac @@ -42,6 +42,18 @@ AS_IF([test "x$setidtype" = "xsetgid"], AC_SUBST(SETID_CMD) AC_SUBST(SETID_MODE) +AC_ARG_ENABLE([git-commit], + [AS_HELP_STRING([--disable-git-commit], + [disable embedding current git HEAD in binaries])], + [], + [if test -d "$srcdir/.git"; then + enable_git_commit=yes; else enable_git_commit=no; fi]) + +if test "x$enable_git_commit" = "xyes" -a ! -d "$srcdir/.git"; then + AC_ERROR([Cannot --enable-git-commit when source tree is not a git checkout]) +fi +AM_CONDITIONAL(AUTO_GIT_COMMIT, [test "x$enable_git_commit" = "xyes"]) + AC_ARG_WITH([gssapi], [AS_HELP_STRING([--without-gssapi], [disable GSSAPI support])],