templates / Makefileon commit Merge commit 'v1.7.0' into jc/checkout-reflog-fix (71ee7fd)
   1# make and install sample templates
   2
   3ifndef V
   4        QUIET = @
   5endif
   6
   7INSTALL ?= install
   8TAR ?= tar
   9RM ?= rm -f
  10prefix ?= $(HOME)
  11template_instdir ?= $(prefix)/share/git-core/templates
  12# DESTDIR=
  13
  14# Shell quote (do not use $(call) to accommodate ancient setups);
  15DESTDIR_SQ = $(subst ','\'',$(DESTDIR))
  16template_instdir_SQ = $(subst ','\'',$(template_instdir))
  17
  18all: boilerplates.made custom
  19
  20# Put templates that can be copied straight from the source
  21# in a file direc--tory--file in the source.  They will be
  22# just copied to the destination.
  23
  24bpsrc = $(filter-out %~,$(wildcard *--*))
  25boilerplates.made : $(bpsrc)
  26        $(QUIET)umask 022 && ls *--* 2>/dev/null | \
  27        while read boilerplate; \
  28        do \
  29                case "$$boilerplate" in *~) continue ;; esac && \
  30                dst=`echo "$$boilerplate" | sed -e 's|^this|.|;s|--|/|g'` && \
  31                dir=`expr "$$dst" : '\(.*\)/'` && \
  32                mkdir -p blt/$$dir && \
  33                case "$$boilerplate" in \
  34                *--) continue;; \
  35                esac && \
  36                cp $$boilerplate blt/$$dst && \
  37                if test -x "blt/$$dst"; then rx=rx; else rx=r; fi && \
  38                chmod a+$$rx "blt/$$dst" || exit; \
  39        done && \
  40        date >$@
  41
  42# If you need build-tailored templates, build them into blt/
  43# directory yourself here.
  44custom:
  45        $(QUIET): no custom templates yet
  46
  47clean:
  48        $(RM) -r blt boilerplates.made
  49
  50install: all
  51        $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(template_instdir_SQ)'
  52        (cd blt && $(TAR) cf - .) | \
  53        (cd '$(DESTDIR_SQ)$(template_instdir_SQ)' && umask 022 && $(TAR) xof -)