git: a4c3b6f622b8 - main - Remove two tools that are no longer useful with Git.
Rene Ladan
rene at FreeBSD.org
Tue Apr 6 10:40:04 UTC 2021
The branch main has been updated by rene:
URL: https://cgit.FreeBSD.org/ports/commit/?id=a4c3b6f622b81ac9a0848c782b4645e0e9dcfcd0
commit a4c3b6f622b81ac9a0848c782b4645e0e9dcfcd0
Author: Rene Ladan <rene at FreeBSD.org>
AuthorDate: 2021-04-06 10:28:35 +0000
Commit: Rene Ladan <rene at FreeBSD.org>
CommitDate: 2021-04-06 10:39:46 +0000
Remove two tools that are no longer useful with Git.
- mfh: this is replaced by 'git cherry-pick -x HASH'
- psvn: unlike svn, git has no per-file properties
Adjust README accordingly.
Differential Revision: https://reviews.freebsd.org/D29451
With hat: portmgr
---
Tools/scripts/README | 1 -
Tools/scripts/mfh | 195 ---------------------------------------------------
Tools/scripts/psvn | 191 -------------------------------------------------
3 files changed, 387 deletions(-)
diff --git a/Tools/scripts/README b/Tools/scripts/README
index af5771794569..079a78a29b58 100644
--- a/Tools/scripts/README
+++ b/Tools/scripts/README
@@ -32,7 +32,6 @@ getpatch.sh - downloads patch attachments from a Bug Tracking Systems (plain she
gnomedepends - Analyse pkg/PLIST and give an advice as to which GNOME ports
should be listes in {RUN,LIB}_DEPENDS for this port
mark_safe.pl - utility to set subsets of ports to MAKE_JOBS_(UN)SAFE=yes
-mfh - Merge from head to a given branch
neededlibs.sh - Extract direct library dependencies from binaries.
portsearch - A utility for searching the ports tree. It allows more detailed
search criteria than ``make search key=<string>'' and accepts
diff --git a/Tools/scripts/mfh b/Tools/scripts/mfh
deleted file mode 100755
index 85427a48fe7e..000000000000
--- a/Tools/scripts/mfh
+++ /dev/null
@@ -1,195 +0,0 @@
-#!/bin/sh
-#
-# mfh - Merge from head to a given branch
-#
-# Usage: mfh [<branch>] <revnumber> [<revnumber>]
-# <branch> is optional and defaults to latest branch
-# If supplying multiple revnumbers, put them in chronological order
-# (111111 111112 111113)
-#
-# Copyright 2013 Baptiste Daroussin
-# All rights reserved.
-#
-# Redistribution and use in source and binary forms, with or without
-# modification, are permitted provided that the following conditions
-# are met:
-# 1. Redistributions of source code must retain the above copyright
-# notice, this list of conditions and the following disclaimer.
-# 2. Redistributions in binary form must reproduce the above copyright
-# notice, this list of conditions and the following disclaimer in the
-# documentation and/or other materials provided with the distribution.
-#
-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
-# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
-# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-# SUCH DAMAGE.
-#
-# MAINTAINER= portmgr at FreeBSD.org
-
-set -eu
-
-LF=$(printf '\nX')
-LF=${LF%X}
-IFS="${LF}"
-
-# defaults from here ---------------------------
-
-: ${svnserver:="svn+ssh://repo.FreeBSD.org"}
-: ${EDITOR:=vi}
-
-# implementation from here ---------------------
-
-err() {
- echo "$@" >&2
- exit 1
-}
-
-ask() {
- question=${1}
-
- answer=x
- while [ "${answer}" != "y" -a "${answer}" != "n" ] ; do
- printf "%s [y/n] " "${question}"
- read -r answer
- done
-
- [ "${answer}" = "y" ] && return 0
- return 1
-}
-
-# -- find svn and diff coloring command --
-
-if [ -n "$(command -v svn 2>/dev/null)" ]; then
- svn=svn
-elif [ -n "$(command -v svnlite 2>/dev/null)" ]; then
- svn=svnlite
-else
- err "Neither svn(1) nor svnlite(1) found. Please install devel/subversion."
-fi
-
-latest_branch=$("${svn}" ls ${svnserver}/ports/branches/|sed -ne '/^2.*Q./s|/$||p'|tail -1)
-
-[ $# -lt 1 ] && err "$(basename "$0") requires at least 1 arguments: [<branch>] <revnumber> [<revnumber>...]"
-branch=$1
-
-if [ -n "$(command -v ydiff)" ] ; then cdiffcmd=ydiff
-elif [ -n "$(command -v colordiff)" ] ; then cdiffcmd=colordiff
-else cdiffcmd=cat
-fi
-
-# I sure hope by 2030 we'll be doing something else. Yes, famous last words.
-if expr -- "${branch}" : '20[12][0-9]Q[1-4]' > /dev/null; then
- shift
- if [ "${latest_branch}" != "${branch}" ]; then
- ask "/!\\ The latest branch is ${latest_branch}, do you really want to commit to ${branch}?" || exit 1
- fi
-else
- branch=${latest_branch}
-fi
-
-## -- parse revisions --
-
-for rev in "$@"
-do
- rev=${rev##r} # remove a leading "r"
- case ${rev} in
- ''|*[!-0-9]*) err "revision \"${rev}\" should be a number" ;;
- esac
-done
-
-## -- set up tmpdir and auto-clean --
-
-dir=$(mktemp -d /tmp/mfh.XXXXXX)
-trap "rc=\$? ; echo '+ rm -rf \"${dir}\"' ; rm -rf \"\${dir}\" ; trap - EXIT ; exit \$rc" EXIT INT QUIT TERM
-cd "${dir}"
-
-## -- check out, merge, generate commit log --
-
-printf "MFH:" > commit.txt
-for rev in "$@"
-do
- rev=${rev##r}
- printf " r%s" "${rev}" >> commit.txt
-done
-echo >> commit.txt
-
-# iterate over revisions to assemble dirlist (for checkout)
-# and accumulate log messages
-dirlist=""
-for rev in "$@"
-do
- rev=${rev##r}
- for f in $("${svn}" diff --summarize -c "r${rev}" "${svnserver}/ports/head"); do
- # ignore top-level filenames without slash
- case ${f} in
- */*) ;;
- *) continue ;;
- esac
- f=${f#*/ports/head/}
- # strip down f to the first two components (CATEGORY/PORTNAME),
- # so that if the MFH only addresses files/, we still get the
- # full port to review, and, for instance, bump PORTREVISION
- # separately if the patch was broken out from a larger lump.
- while :; do
- case ${f} in
- */*/*) f=${f%/*} ;;
- *) break ;;
- esac
- done
- dirlist="${dirlist}${f}${LF}"
- done
- "${svn}" log "-r${rev##-}" ${svnserver}/ports/head | sed '1,2d;$d;/^MFH:/d' \
- | sed '$d' >> commit.txt
-done
-dirlist=$(printf '%s' "${dirlist}" | sort -u | sed "s}^}${branch}/}")
-
-"${svn}" co --quiet --depth=empty ${svnserver}/ports/branches/"${branch}"
-"${svn}" up --parents --set-depth=infinity $dirlist
-"${svn}" up --quiet "${branch}"
-for rev in "$@"
-do
- rev=${rev##r}
- "${svn}" merge -c "r${rev}" ^/head/ "${branch}"
-done
-"${svn}" up --quiet "${branch}"
-
-## -- present final result to user --
-svnstat=$("${svn}" status "${branch}")
-if [ -z "${svnstat}" ] ; then
- err "The MFH came up empty - already merged? Wrong revision given?"
-fi
-
-echo
-printf '%s\n' "${svnstat}"
-"${svn}" diff "${branch}" | $cdiffcmd
-printf '\nSee the status/diff above: all the merge work was done on %s.\n' "${dir}/${branch}"
-ask "Do you want to commit? (no = start a shell)" || (
- echo "Dropping you to a shell so you can investigate. Exit the shell to resume this script."
- cd "${branch}"
- pwd
- su -m $(id -un) || :
- ask "Do you want to commit now? (no = clean up and abort)" || err "User-requested abort."
-)
-echo >> commit.txt
-
-## -- edit pre-assembled log message and commit --
-${EDITOR} commit.txt
-while ! "${svn}" ci -F commit.txt "${branch}"; do
- if ! ask "Commit failed. Re-edit message and try again?"; then
- save_log="$(mktemp -t mfh)"
- cp -f commit.txt "${save_log}"
- echo "Saving commit log to ${save_log}"
- break
- fi
- ${EDITOR} commit.txt
-done
-
-# the trap will clean up for us
-exit 0
diff --git a/Tools/scripts/psvn b/Tools/scripts/psvn
deleted file mode 100755
index 74368cdbd452..000000000000
--- a/Tools/scripts/psvn
+++ /dev/null
@@ -1,191 +0,0 @@
-#!/bin/sh -eu
-#
-# psvn - Wrapper to set Subversion properties automatically
-#
-# Copyright (c) 2012 Beat Gaetzi <beat at FreeBSD.org>
-# Copyright (c) 2012,2014 Matthias Andree <mandree at FreeBSD.org>
-# All rights reserved.
-#
-# Redistribution and use in source and binary forms, with or without
-# modification, are permitted provided that the following conditions
-# are met:
-# 1. Redistributions of source code must retain the above copyright
-# notice, this list of conditions and the following disclaimer
-# 2. Redistributions in binary form must reproduce the above copyright
-# notice, this list of conditions and the following disclaimer in the
-# documentation and/or other materials provided with the distribution.
-#
-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
-# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
-# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-#
-# $FreeBSD$
-#
-# MAINTAINER= mandree at FreeBSD.org
-# beat@ has implicit approval to change this script.
-#
-
-#
-# The psvn wrapper checkes from replaced, conflicting, missing or
-# untracked files. When committing it adds the needed Subversion
-# properties and removes unneeded ones.
-# There is also adds a check subcommand which just executes the
-# checks.
-#
-
-PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:${PATH}
-export PATH
-
-SVN="$(which svn)"
-LF="$(printf '\nX')"
-LF="${LF%X}"
-
-VERSION=$("${SVN}" --version --quiet | sed -e 's,^\(.*\)\.\(.*\)\..*,\1\2,')
-if [ ${VERSION} -lt 17 ] ;
-then
- echo "===> Please consider upgrading to Subversion 1.7 (or newer)"
-fi
-
-checkstatus () {
- local IFS _error _file _status _statusline -
- _error=0
- eval "set -- $@"
- IFS="$LF"
- set -- $("${SVN}" status -- "$@")
-
- for _statusline
- do
- _status="$(printf '%.7s' "${_statusline}")"
- _file="${_statusline##????????}"
-
- case "${_status}" in
- R*)
- printf >&2 '===> Do not replace files as this may lose history: "%s"\n' "${_file}"
- _error=1
- ;;
- C*|?C*)
- printf >&2 '===> Conflict detected: \"%s\"\n' "${_file}"
- _error=1
- ;;
- \~*)
- printf >&2 '===> Versioned item \"%s\" obstructed.\n' "${_file}"
- _error=1
- ;;
- \?*)
- printf >&2 '===> Untracked new file "%s". Consider svn adding or deleting it.\n' "${_file}"
- _error=1
- ;;
- \!*)
- printf >&2 '===> Missing file "%s". Consider re-adding or svn deleting it.\n' "${_file}"
- _error=1
- ;;
- esac
- done
-
- if [ ${_error} -ne 0 ] ;
- then
- exit 1
- fi
-}
-
-setprop () {
- local _file -
- eval "set -- $1"
-
- for _file
- do
- if [ -d "${_file}" -o ! -e "${_file}" ] ;
- then
- continue
- fi
- printf >&2 '=> Adding svn keywords to "%s"\n' "${_file}"
- case $(egrep -- '\$FreeBSD\$|\$[BDFSer]+:' "${_file}" >/dev/null || echo $?) in
- "") # matched pattern
- "${SVN}" -q -- propset svn:keywords "FreeBSD=%H" "${_file}"
- "${SVN}" -q -- propdel fbsd:nokeywords "${_file}"
- ;;
- 1) # no match
- "${SVN}" -q -- propset fbsd:nokeywords yes "${_file}"
- "${SVN}" -q -- propdel svn:keywords "${_file}"
- ;;
- *) # egrep failed
- exit 1
- ;;
- esac
- if [ "${_file##/*}" != "bsd.port.mk" ] ; then
- "${SVN}" -q -- propset svn:eol-style native "${_file}"
- fi
- "${SVN}" -q -- propset svn:mime-type text/plain "${_file}"
- "${SVN}" -q -- propdel cvs2svn:cvs-rev "${_file}"
- done
-}
-
-# taken from "Rich's sh (POSIX shell) tricks",
-# a "Programming Guide[...]" at http://www.etalabs.net/sh_tricks.html
-savearray() {
- for i do
- printf %s\\n "$i" | sed -e "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/"
- done
- echo " "
-}
-
-getfilequotedarray() {
- local varname IFS
- varname="$1"
- shift
- IFS="$LF"
- set -- $("${SVN}" status -- "$@" | grep -v '^ ' | sed 's/^....... //')
- eval "$varname=\$(savearray "\$@")"
-}
-
-for opt ; do
- case "${opt}" in
- -*) continue ;;
- esac
- case "${opt}" in
- check)
- shift
- if [ $# -gt 0 ] ; then
- echo >&2 "===> Unsupported option before, or garbage after command"
- exit 1
- fi
- getfilequotedarray "files" "$@"
- checkstatus "${files}"
- exit 0
- ;;
- ci|commit)
- savedargs=$(savearray "$@")
- shift
- while getopts :qm:F: opt
- do
- case "$opt" in
- q) ;;
- m) ;;
- F) ;;
- \?) echo >&2 "===> Unsupported option -$OPTARG encountered. Abort."
- exit 1 ;;
- :) echo >&2 "===> Missing argument to option -$OPTARG. Abort."
- exit 1 ;;
- esac
- done
- shift $(($OPTIND - 1))
-
- getfilequotedarray "files" "$@"
- checkstatus "${files}"
- setprop "${files}"
-
- eval "set -- $savedargs"
- exec "${SVN}" "$@"
- ;;
- *)
- exec "${SVN}" "$@"
- ;;
- esac
-done
More information about the dev-commits-ports-all
mailing list