diff options
author | marino <marino@FreeBSD.org> | 2014-10-31 07:04:03 +0800 |
---|---|---|
committer | marino <marino@FreeBSD.org> | 2014-10-31 07:04:03 +0800 |
commit | 4246a06a4146c05c4775c9a5f5e8b03f9c899c12 (patch) | |
tree | 3078cfaf30562e7354eaf9a415ac03813715cfb6 | |
parent | eb3bf7815a8c15d19f502487de2c7a22804650d0 (diff) | |
download | freebsd-ports-gnome-4246a06a4146c05c4775c9a5f5e8b03f9c899c12.tar.gz freebsd-ports-gnome-4246a06a4146c05c4775c9a5f5e8b03f9c899c12.tar.zst freebsd-ports-gnome-4246a06a4146c05c4775c9a5f5e8b03f9c899c12.zip |
bsd.port.mk: Finish update to make makepatch
A portion of this patch to upgrade makepatch was committed almost 2
months ago; this is the rest of it. It changes the directory separator
to "_" and it will transform "_" in the filename to "__" to avoid
ambiguous file names (e.g. A/B/C.c and A_B/C.c won't have the same patch
name).
The new logic will not rename an existing patch that used previously
standard separators of "-", "+", or "__" in its name. It is desireable
to avoid commits that only change the filename of the patch, so that's
why existing filenames are re-used if previously legal.
The diff command is also pass the -p argument for additional useful
context.
Differential Revision: https://reviews.freebsd.org/D582
Approved by: portmgr (bapt)
-rw-r--r-- | Mk/bsd.port.mk | 30 |
1 files changed, 24 insertions, 6 deletions
diff --git a/Mk/bsd.port.mk b/Mk/bsd.port.mk index e85f7624001e..bcd1ef6ac109 100644 --- a/Mk/bsd.port.mk +++ b/Mk/bsd.port.mk @@ -1147,21 +1147,39 @@ STRIPBIN= ${STRIP_CMD} .else -# Look for ${PATCH_WRKSRC}/.../*.orig files, and (re-)create -# ${FILEDIR}/patch-* files from them. +# Look for files named "*.orig" under ${PATCH_WRKSRC} and (re-)generate +# ${FILESDIR}/patch-* files from them. By popular demand, we currently +# use '_' (underscore) to replace path separators in patch file names. +# +# If a file name happens to contain character which is also a separator +# replacement character, it will be doubled in the resulting patch name. +# +# To minimize gratuitous patch renames, newly generated patches will be +# written under existing file names when they use any of the previously +# common path separators ([-+_]) or legacy double underscore (__). .if !target(makepatch) +PATCH_PATH_SEPARATOR= _ makepatch: @${MKDIR} ${FILESDIR} @(cd ${PATCH_WRKSRC}; \ - for f in `${FIND} . -type f -name '*.orig'`; do \ + for f in `${FIND} -s . -type f -name '*.orig'`; do \ ORIG=$${f#./}; \ NEW=$${ORIG%.orig}; \ cmp -s $${ORIG} $${NEW} && continue; \ - PATCH=`${ECHO} $${NEW} | ${SED} -e 's|/|__|g'`; \ + ! for _lps in `${ECHO} _ - + | ${SED} -e \ + 's|${PATCH_PATH_SEPARATOR}|__|'`; do \ + PATCH=`${ECHO} $${NEW} | ${SED} -e "s|/|$${_lps}|g"`; \ + test -f "${FILESDIR}/patch-$${PATCH}" && break; \ + done || ${ECHO} $${_SEEN} | ${GREP} -q /$${PATCH} && { \ + PATCH=`${ECHO} $${NEW} | ${SED} -e \ + 's|${PATCH_PATH_SEPARATOR}|&&|g' -e \ + 's|/|${PATCH_PATH_SEPARATOR}|g'`; \ + _SEEN=$${_SEEN}/$${PATCH}; \ + }; \ OUT=${FILESDIR}/patch-$${PATCH}; \ - ${ECHO} ${DIFF} -ud $${ORIG} $${NEW} '>' $${OUT}; \ - TZ=UTC ${DIFF} -ud $${ORIG} $${NEW} | ${SED} -e \ + ${ECHO} ${DIFF} -udp $${ORIG} $${NEW} '>' $${OUT}; \ + TZ=UTC ${DIFF} -udp $${ORIG} $${NEW} | ${SED} -e \ '/^---/s|\.[0-9]* +0000$$| UTC|' -e \ '/^+++/s|\([[:blank:]][-0-9:.+]*\)*$$||' \ > $${OUT} || ${TRUE}; \ |