commit:     31ea80d39218e125993ab64694fb0261871843ae
Author:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
AuthorDate: Sun Apr 21 09:10:31 2019 +0000
Commit:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
CommitDate: Sun Apr 21 09:16:26 2019 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=31ea80d3

app-shells/bash: Removed old.

Package-Manager: Portage-2.3.64, Repoman-2.3.12
Signed-off-by: Lars Wendler <polynomial-c <AT> gentoo.org>

 app-shells/bash/bash-5.0_p2-r2.ebuild              | 267 ---------------------
 app-shells/bash/bash-5.0_p3.ebuild                 | 266 --------------------
 .../bash/files/bash-5.0-globpat-backslashes.patch  | 206 ----------------
 3 files changed, 739 deletions(-)

diff --git a/app-shells/bash/bash-5.0_p2-r2.ebuild 
b/app-shells/bash/bash-5.0_p2-r2.ebuild
deleted file mode 100644
index 7383e634420..00000000000
--- a/app-shells/bash/bash-5.0_p2-r2.ebuild
+++ /dev/null
@@ -1,267 +0,0 @@
-# Copyright 1999-2019 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=6
-
-inherit flag-o-matic toolchain-funcs multilib prefix
-
-# Official patchlevel
-# See ftp://ftp.cwru.edu/pub/bash/bash-5.0-patches/
-PLEVEL=${PV##*_p}
-MY_PV=${PV/_p*}
-MY_PV=${MY_PV/_/-}
-MY_P=${PN}-${MY_PV}
-is_release() {
-       case ${PV} in
-       *_alpha*|*_beta*|*_rc*) return 1 ;;
-       *) return 0 ;;
-       esac
-}
-[[ ${PV} != *_p* ]] && PLEVEL=0
-patches() {
-       local opt=$1 plevel=${2:-${PLEVEL}} pn=${3:-${PN}} pv=${4:-${MY_PV}}
-       [[ ${plevel} -eq 0 ]] && return 1
-       eval set -- {1..${plevel}}
-       set -- $(printf "${pn}${pv/\.}-%03d " "$@")
-       if [[ ${opt} == -s ]] ; then
-               echo "${@/#/${DISTDIR}/}"
-       else
-               local u
-               for u in ftp://ftp.cwru.edu/pub/bash mirror://gnu/${pn} ; do
-                       printf "${u}/${pn}-${pv}-patches/%s " "$@"
-               done
-       fi
-}
-
-# The version of readline this bash normally ships with.
-READLINE_VER="8.0"
-
-DESCRIPTION="The standard GNU Bourne again shell"
-HOMEPAGE="http://tiswww.case.edu/php/chet/bash/bashtop.html";
-if is_release ; then
-       SRC_URI="mirror://gnu/bash/${MY_P}.tar.gz $(patches)"
-else
-       SRC_URI="ftp://ftp.cwru.edu/pub/bash/${MY_P}.tar.gz";
-fi
-
-LICENSE="GPL-3"
-SLOT="0"
-KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 
~sh ~sparc ~x86 ~ppc-aix ~x64-cygwin ~amd64-fbsd ~x86-fbsd ~amd64-linux 
~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris 
~sparc64-solaris ~x64-solaris ~x86-solaris"
-IUSE="afs bashlogger examples mem-scramble +net nls plugins +readline"
-
-DEPEND="
-       >=sys-libs/ncurses-5.2-r2:0=
-       readline? ( >=sys-libs/readline-${READLINE_VER}:0= )
-       nls? ( virtual/libintl )
-"
-RDEPEND="
-       ${DEPEND}
-       !<sys-apps/portage-2.1.6.7_p1
-"
-# we only need yacc when the .y files get patched (bash42-005)
-#DEPEND+=" virtual/yacc"
-
-S="${WORKDIR}/${MY_P}"
-
-PATCHES=(
-       # Patches from Chet sent to bashbug ml
-       "${FILESDIR}"/${PN}-5.0-history-zero-length.patch
-       "${FILESDIR}"/${PN}-5.0-history-append.patch
-       "${FILESDIR}"/${PN}-5.0-optimize-connection-fork.patch
-       "${FILESDIR}"/${PN}-5.0-syslog-history-extern.patch
-       "${FILESDIR}"/${PN}-5.0-globpat-backslashes.patch
-)
-
-pkg_setup() {
-       if is-flag -malign-double ; then #7332
-               eerror "Detected bad CFLAGS '-malign-double'.  Do not use this"
-               eerror "as it breaks LFS (struct stat64) on x86."
-               die "remove -malign-double from your CFLAGS mr ricer"
-       fi
-       if use bashlogger ; then
-               ewarn "The logging patch should ONLY be used in restricted 
(i.e. honeypot) envs."
-               ewarn "This will log ALL output you enter into the shell, you 
have been warned."
-       fi
-}
-
-src_unpack() {
-       unpack ${MY_P}.tar.gz
-}
-
-src_prepare() {
-       # Include official patches
-       [[ ${PLEVEL} -gt 0 ]] && eapply -p0 $(patches -s)
-
-       # Clean out local libs so we know we use system ones w/releases.
-       if is_release ; then
-               rm -rf lib/{readline,termcap}/*
-               touch lib/{readline,termcap}/Makefile.in # for config.status
-               sed -ri -e 's:\$[(](RL|HIST)_LIBSRC[)]/[[:alpha:]]*.h::g' 
Makefile.in || die
-       fi
-
-       # Prefixify hardcoded path names. No-op for non-prefix.
-       hprefixify pathnames.h.in
-
-       # Avoid regenerating docs after patches #407985
-       sed -i -r '/^(HS|RL)USER/s:=.*:=:' doc/Makefile.in || die
-       touch -r . doc/*
-
-       eapply -p0 "${PATCHES[@]}"
-       eapply_user
-}
-
-src_configure() {
-       local myconf=(
-               --disable-profiling
-               --docdir='$(datarootdir)'/doc/${PF}
-               --htmldir='$(docdir)/html'
-               --with-curses
-               $(use_enable mem-scramble)
-               $(use_enable net net-redirections)
-               $(use_enable readline)
-               $(use_enable readline bang-history)
-               $(use_enable readline history)
-               $(use_with afs)
-               $(use_with mem-scramble bash-malloc)
-       )
-
-       # For descriptions of these, see config-top.h
-       # bashrc/#26952 bash_logout/#90488 ssh/#24762 mktemp/#574426
-       append-cppflags \
-               
-DDEFAULT_PATH_VALUE=\'\"${EPREFIX}/usr/local/sbin:${EPREFIX}/usr/local/bin:${EPREFIX}/usr/sbin:${EPREFIX}/usr/bin:${EPREFIX}/sbin:${EPREFIX}/bin\"\'
 \
-               
-DSTANDARD_UTILS_PATH=\'\"${EPREFIX}/bin:${EPREFIX}/usr/bin:${EPREFIX}/sbin:${EPREFIX}/usr/sbin\"\'
 \
-               -DSYS_BASHRC=\'\"${EPREFIX}/etc/bash/bashrc\"\' \
-               -DSYS_BASH_LOGOUT=\'\"${EPREFIX}/etc/bash/bash_logout\"\' \
-               -DNON_INTERACTIVE_LOGIN_SHELLS \
-               -DSSH_SOURCE_BASHRC \
-               $(use bashlogger && echo -DSYSLOG_HISTORY)
-
-       # Don't even think about building this statically without
-       # reading Bug 7714 first.  If you still build it statically,
-       # don't come crying to us with bugs ;).
-       #use static && export LDFLAGS="${LDFLAGS} -static"
-       use nls || myconf+=( --disable-nls )
-
-       # Historically, we always used the builtin readline, but since
-       # our handling of SONAME upgrades has gotten much more stable
-       # in the PM (and the readline ebuild itself preserves the old
-       # libs during upgrades), linking against the system copy should
-       # be safe.
-       # Exact cached version here doesn't really matter as long as it
-       # is at least what's in the DEPEND up above.
-       export ac_cv_rl_version=${READLINE_VER%%_*}
-
-       # Force linking with system curses ... the bundled termcap lib
-       # sucks bad compared to ncurses.  For the most part, ncurses
-       # is here because readline needs it.  But bash itself calls
-       # ncurses in one or two small places :(.
-
-       if is_release ; then
-               # Use system readline only with released versions.
-               myconf+=( --with-installed-readline=. )
-       fi
-
-       if use plugins; then
-               append-ldflags -Wl,-rpath,/usr/$(get_libdir)/bash
-       else
-               # Disable the plugins logic by hand since bash doesn't
-               # provide a way of doing it.
-               export ac_cv_func_dl{close,open,sym}=no \
-                       ac_cv_lib_dl_dlopen=no ac_cv_header_dlfcn_h=no
-               sed -i \
-                       -e '/LOCAL_LDFLAGS=/s:-rdynamic::' \
-                       configure || die
-       fi
-       tc-export AR #444070
-       econf "${myconf[@]}"
-}
-
-src_compile() {
-       emake
-
-       if use plugins ; then
-               emake -C examples/loadables all others
-       fi
-}
-
-src_install() {
-       local d f
-
-       default
-
-       dodir /bin
-       mv "${ED%/}"/usr/bin/bash "${ED%/}"/bin/ || die
-       dosym bash /bin/rbash
-
-       insinto /etc/bash
-       doins "${FILESDIR}"/bash_logout
-       doins "$(prefixify_ro "${FILESDIR}"/bashrc)"
-       keepdir /etc/bash/bashrc.d
-       insinto /etc/skel
-       for f in bash{_logout,_profile,rc} ; do
-               newins "${FILESDIR}"/dot-${f} .${f}
-       done
-
-       local sed_args=(
-               -e "s:#${USERLAND}#@::"
-               -e '/#@/d'
-       )
-       if ! use readline ; then
-               sed_args+=( #432338
-                       -e '/^shopt -s histappend/s:^:#:'
-                       -e 's:use_color=true:use_color=false:'
-               )
-       fi
-       sed -i \
-               "${sed_args[@]}" \
-               "${ED%/}"/etc/skel/.bashrc \
-               "${ED%/}"/etc/bash/bashrc || die
-
-       if use plugins ; then
-               exeinto /usr/$(get_libdir)/bash
-               doexe $(echo examples/loadables/*.o | sed 's:\.o::g')
-               insinto /usr/include/bash-plugins
-               doins *.h builtins/*.h include/*.h 
lib/{glob/glob.h,tilde/tilde.h}
-       fi
-
-       if use examples ; then
-               for d in examples/{functions,misc,scripts,startup-files} ; do
-                       exeinto /usr/share/doc/${PF}/${d}
-                       insinto /usr/share/doc/${PF}/${d}
-                       for f in ${d}/* ; do
-                               if [[ ${f##*/} != PERMISSION ]] && [[ ${f##*/} 
!= *README ]] ; then
-                                       doexe ${f}
-                               else
-                                       doins ${f}
-                               fi
-                       done
-               done
-       fi
-
-       doman doc/*.1
-       newdoc CWRU/changelog ChangeLog
-       dosym bash.info /usr/share/info/bashref.info
-}
-
-pkg_preinst() {
-       if [[ -e ${EROOT}/etc/bashrc ]] && [[ ! -d ${EROOT}/etc/bash ]] ; then
-               mkdir -p "${EROOT}"/etc/bash
-               mv -f "${EROOT}"/etc/bashrc "${EROOT}"/etc/bash/
-       fi
-
-       if [[ -L ${EROOT}/bin/sh ]] ; then
-               # rewrite the symlink to ensure that its mtime changes. having 
/bin/sh
-               # missing even temporarily causes a fatal error with paludis.
-               local target=$(readlink "${EROOT}"/bin/sh)
-               local tmp=$(emktemp "${EROOT}"/bin)
-               ln -sf "${target}" "${tmp}"
-               mv -f "${tmp}" "${EROOT}"/bin/sh
-       fi
-}
-
-pkg_postinst() {
-       # If /bin/sh does not exist, provide it
-       if [[ ! -e ${EROOT}/bin/sh ]] ; then
-               ln -sf bash "${EROOT}"/bin/sh
-       fi
-}

diff --git a/app-shells/bash/bash-5.0_p3.ebuild 
b/app-shells/bash/bash-5.0_p3.ebuild
deleted file mode 100644
index 0e14a04dc16..00000000000
--- a/app-shells/bash/bash-5.0_p3.ebuild
+++ /dev/null
@@ -1,266 +0,0 @@
-# Copyright 1999-2019 Gentoo Authors
-# Distributed under the terms of the GNU General Public License v2
-
-EAPI=6
-
-inherit flag-o-matic toolchain-funcs multilib prefix
-
-# Official patchlevel
-# See ftp://ftp.cwru.edu/pub/bash/bash-5.0-patches/
-PLEVEL=${PV##*_p}
-MY_PV=${PV/_p*}
-MY_PV=${MY_PV/_/-}
-MY_P=${PN}-${MY_PV}
-is_release() {
-       case ${PV} in
-       *_alpha*|*_beta*|*_rc*) return 1 ;;
-       *) return 0 ;;
-       esac
-}
-[[ ${PV} != *_p* ]] && PLEVEL=0
-patches() {
-       local opt=$1 plevel=${2:-${PLEVEL}} pn=${3:-${PN}} pv=${4:-${MY_PV}}
-       [[ ${plevel} -eq 0 ]] && return 1
-       eval set -- {1..${plevel}}
-       set -- $(printf "${pn}${pv/\.}-%03d " "$@")
-       if [[ ${opt} == -s ]] ; then
-               echo "${@/#/${DISTDIR}/}"
-       else
-               local u
-               for u in ftp://ftp.cwru.edu/pub/bash mirror://gnu/${pn} ; do
-                       printf "${u}/${pn}-${pv}-patches/%s " "$@"
-               done
-       fi
-}
-
-# The version of readline this bash normally ships with.
-READLINE_VER="8.0"
-
-DESCRIPTION="The standard GNU Bourne again shell"
-HOMEPAGE="http://tiswww.case.edu/php/chet/bash/bashtop.html";
-if is_release ; then
-       SRC_URI="mirror://gnu/bash/${MY_P}.tar.gz $(patches)"
-else
-       SRC_URI="ftp://ftp.cwru.edu/pub/bash/${MY_P}.tar.gz";
-fi
-
-LICENSE="GPL-3"
-SLOT="0"
-KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 
~sh ~sparc ~x86 ~ppc-aix ~x64-cygwin ~amd64-fbsd ~x86-fbsd ~amd64-linux 
~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris 
~sparc64-solaris ~x64-solaris ~x86-solaris"
-IUSE="afs bashlogger examples mem-scramble +net nls plugins +readline"
-
-DEPEND="
-       >=sys-libs/ncurses-5.2-r2:0=
-       readline? ( >=sys-libs/readline-${READLINE_VER}:0= )
-       nls? ( virtual/libintl )
-"
-RDEPEND="
-       ${DEPEND}
-       !<sys-apps/portage-2.1.6.7_p1
-"
-# we only need yacc when the .y files get patched (bash42-005)
-#DEPEND+=" virtual/yacc"
-
-S="${WORKDIR}/${MY_P}"
-
-PATCHES=(
-       # Patches from Chet sent to bashbug ml
-       "${FILESDIR}"/${PN}-5.0-history-zero-length.patch
-       "${FILESDIR}"/${PN}-5.0-history-append.patch
-       "${FILESDIR}"/${PN}-5.0-optimize-connection-fork.patch
-       "${FILESDIR}"/${PN}-5.0-syslog-history-extern.patch
-)
-
-pkg_setup() {
-       if is-flag -malign-double ; then #7332
-               eerror "Detected bad CFLAGS '-malign-double'.  Do not use this"
-               eerror "as it breaks LFS (struct stat64) on x86."
-               die "remove -malign-double from your CFLAGS mr ricer"
-       fi
-       if use bashlogger ; then
-               ewarn "The logging patch should ONLY be used in restricted 
(i.e. honeypot) envs."
-               ewarn "This will log ALL output you enter into the shell, you 
have been warned."
-       fi
-}
-
-src_unpack() {
-       unpack ${MY_P}.tar.gz
-}
-
-src_prepare() {
-       # Include official patches
-       [[ ${PLEVEL} -gt 0 ]] && eapply -p0 $(patches -s)
-
-       # Clean out local libs so we know we use system ones w/releases.
-       if is_release ; then
-               rm -rf lib/{readline,termcap}/*
-               touch lib/{readline,termcap}/Makefile.in # for config.status
-               sed -ri -e 's:\$[(](RL|HIST)_LIBSRC[)]/[[:alpha:]]*.h::g' 
Makefile.in || die
-       fi
-
-       # Prefixify hardcoded path names. No-op for non-prefix.
-       hprefixify pathnames.h.in
-
-       # Avoid regenerating docs after patches #407985
-       sed -i -r '/^(HS|RL)USER/s:=.*:=:' doc/Makefile.in || die
-       touch -r . doc/*
-
-       eapply -p0 "${PATCHES[@]}"
-       eapply_user
-}
-
-src_configure() {
-       local myconf=(
-               --disable-profiling
-               --docdir='$(datarootdir)'/doc/${PF}
-               --htmldir='$(docdir)/html'
-               --with-curses
-               $(use_enable mem-scramble)
-               $(use_enable net net-redirections)
-               $(use_enable readline)
-               $(use_enable readline bang-history)
-               $(use_enable readline history)
-               $(use_with afs)
-               $(use_with mem-scramble bash-malloc)
-       )
-
-       # For descriptions of these, see config-top.h
-       # bashrc/#26952 bash_logout/#90488 ssh/#24762 mktemp/#574426
-       append-cppflags \
-               
-DDEFAULT_PATH_VALUE=\'\"${EPREFIX}/usr/local/sbin:${EPREFIX}/usr/local/bin:${EPREFIX}/usr/sbin:${EPREFIX}/usr/bin:${EPREFIX}/sbin:${EPREFIX}/bin\"\'
 \
-               
-DSTANDARD_UTILS_PATH=\'\"${EPREFIX}/bin:${EPREFIX}/usr/bin:${EPREFIX}/sbin:${EPREFIX}/usr/sbin\"\'
 \
-               -DSYS_BASHRC=\'\"${EPREFIX}/etc/bash/bashrc\"\' \
-               -DSYS_BASH_LOGOUT=\'\"${EPREFIX}/etc/bash/bash_logout\"\' \
-               -DNON_INTERACTIVE_LOGIN_SHELLS \
-               -DSSH_SOURCE_BASHRC \
-               $(use bashlogger && echo -DSYSLOG_HISTORY)
-
-       # Don't even think about building this statically without
-       # reading Bug 7714 first.  If you still build it statically,
-       # don't come crying to us with bugs ;).
-       #use static && export LDFLAGS="${LDFLAGS} -static"
-       use nls || myconf+=( --disable-nls )
-
-       # Historically, we always used the builtin readline, but since
-       # our handling of SONAME upgrades has gotten much more stable
-       # in the PM (and the readline ebuild itself preserves the old
-       # libs during upgrades), linking against the system copy should
-       # be safe.
-       # Exact cached version here doesn't really matter as long as it
-       # is at least what's in the DEPEND up above.
-       export ac_cv_rl_version=${READLINE_VER%%_*}
-
-       # Force linking with system curses ... the bundled termcap lib
-       # sucks bad compared to ncurses.  For the most part, ncurses
-       # is here because readline needs it.  But bash itself calls
-       # ncurses in one or two small places :(.
-
-       if is_release ; then
-               # Use system readline only with released versions.
-               myconf+=( --with-installed-readline=. )
-       fi
-
-       if use plugins; then
-               append-ldflags -Wl,-rpath,/usr/$(get_libdir)/bash
-       else
-               # Disable the plugins logic by hand since bash doesn't
-               # provide a way of doing it.
-               export ac_cv_func_dl{close,open,sym}=no \
-                       ac_cv_lib_dl_dlopen=no ac_cv_header_dlfcn_h=no
-               sed -i \
-                       -e '/LOCAL_LDFLAGS=/s:-rdynamic::' \
-                       configure || die
-       fi
-       tc-export AR #444070
-       econf "${myconf[@]}"
-}
-
-src_compile() {
-       emake
-
-       if use plugins ; then
-               emake -C examples/loadables all others
-       fi
-}
-
-src_install() {
-       local d f
-
-       default
-
-       dodir /bin
-       mv "${ED%/}"/usr/bin/bash "${ED%/}"/bin/ || die
-       dosym bash /bin/rbash
-
-       insinto /etc/bash
-       doins "${FILESDIR}"/bash_logout
-       doins "$(prefixify_ro "${FILESDIR}"/bashrc)"
-       keepdir /etc/bash/bashrc.d
-       insinto /etc/skel
-       for f in bash{_logout,_profile,rc} ; do
-               newins "${FILESDIR}"/dot-${f} .${f}
-       done
-
-       local sed_args=(
-               -e "s:#${USERLAND}#@::"
-               -e '/#@/d'
-       )
-       if ! use readline ; then
-               sed_args+=( #432338
-                       -e '/^shopt -s histappend/s:^:#:'
-                       -e 's:use_color=true:use_color=false:'
-               )
-       fi
-       sed -i \
-               "${sed_args[@]}" \
-               "${ED%/}"/etc/skel/.bashrc \
-               "${ED%/}"/etc/bash/bashrc || die
-
-       if use plugins ; then
-               exeinto /usr/$(get_libdir)/bash
-               doexe $(echo examples/loadables/*.o | sed 's:\.o::g')
-               insinto /usr/include/bash-plugins
-               doins *.h builtins/*.h include/*.h 
lib/{glob/glob.h,tilde/tilde.h}
-       fi
-
-       if use examples ; then
-               for d in examples/{functions,misc,scripts,startup-files} ; do
-                       exeinto /usr/share/doc/${PF}/${d}
-                       insinto /usr/share/doc/${PF}/${d}
-                       for f in ${d}/* ; do
-                               if [[ ${f##*/} != PERMISSION ]] && [[ ${f##*/} 
!= *README ]] ; then
-                                       doexe ${f}
-                               else
-                                       doins ${f}
-                               fi
-                       done
-               done
-       fi
-
-       doman doc/*.1
-       newdoc CWRU/changelog ChangeLog
-       dosym bash.info /usr/share/info/bashref.info
-}
-
-pkg_preinst() {
-       if [[ -e ${EROOT}/etc/bashrc ]] && [[ ! -d ${EROOT}/etc/bash ]] ; then
-               mkdir -p "${EROOT}"/etc/bash
-               mv -f "${EROOT}"/etc/bashrc "${EROOT}"/etc/bash/
-       fi
-
-       if [[ -L ${EROOT}/bin/sh ]] ; then
-               # rewrite the symlink to ensure that its mtime changes. having 
/bin/sh
-               # missing even temporarily causes a fatal error with paludis.
-               local target=$(readlink "${EROOT}"/bin/sh)
-               local tmp=$(emktemp "${EROOT}"/bin)
-               ln -sf "${target}" "${tmp}"
-               mv -f "${tmp}" "${EROOT}"/bin/sh
-       fi
-}
-
-pkg_postinst() {
-       # If /bin/sh does not exist, provide it
-       if [[ ! -e ${EROOT}/bin/sh ]] ; then
-               ln -sf bash "${EROOT}"/bin/sh
-       fi
-}

diff --git a/app-shells/bash/files/bash-5.0-globpat-backslashes.patch 
b/app-shells/bash/files/bash-5.0-globpat-backslashes.patch
deleted file mode 100644
index 21acaf7e7ff..00000000000
--- a/app-shells/bash/files/bash-5.0-globpat-backslashes.patch
+++ /dev/null
@@ -1,206 +0,0 @@
-*** ../bash-5.0-patched/lib/glob/glob_loop.c   2019-01-16 16:13:21.000000000 
-0500
---- lib/glob/glob_loop.c       2019-02-01 09:45:11.000000000 -0500
-***************
-*** 27,34 ****
-    register const GCHAR *p;
-    register GCHAR c;
-!   int bopen;
-  
-    p = pattern;
-!   bopen = 0;
-  
-    while ((c = *p++) != L('\0'))
---- 27,34 ----
-    register const GCHAR *p;
-    register GCHAR c;
-!   int bopen, bsquote;
-  
-    p = pattern;
-!   bopen = bsquote = 0;
-  
-    while ((c = *p++) != L('\0'))
-***************
-*** 56,66 ****
-        case L('\\'):
-       /* Don't let the pattern end in a backslash (GMATCH returns no match
-!         if the pattern ends in a backslash anyway), but otherwise return 1,
-!         since the matching engine uses backslash as an escape character
-!         and it can be removed. */
-!      return (*p != L('\0'));
-        }
-  
-!   return 0;
-  }
-  
---- 56,75 ----
-        case L('\\'):
-       /* Don't let the pattern end in a backslash (GMATCH returns no match
-!         if the pattern ends in a backslash anyway), but otherwise note that 
-!         we have seen this, since the matching engine uses backslash as an
-!         escape character and it can be removed. We return 2 later if we
-!         have seen only backslash-escaped characters, so interested callers
-!         know they can shortcut and just dequote the pathname. */
-!      if (*p != L('\0'))
-!        {
-!          p++;
-!          bsquote = 1;
-!          continue;
-!        }
-!      else    /* (*p == L('\0')) */
-!        return 0;
-        }
-  
-!   return bsquote ? 2 : 0;
-  }
-  
-*** ../bash-5.0-patched/lib/glob/glob.h        2013-10-28 14:46:12.000000000 
-0400
---- lib/glob/glob.h    2019-03-07 11:06:47.000000000 -0500
-***************
-*** 31,34 ****
---- 31,35 ----
-  #define GX_ADDCURDIR 0x200   /* internal -- add passed directory name */
-  #define GX_GLOBSTAR  0x400   /* turn on special handling of ** */
-+ #define GX_RECURSE   0x800   /* internal -- glob_filename called recursively 
*/
-  
-  extern int glob_pattern_p __P((const char *));
-*** ../bash-5.0-patched/lib/glob/glob.c        2018-09-20 10:53:23.000000000 
-0400
---- lib/glob/glob.c    2019-03-07 14:23:43.000000000 -0500
-***************
-*** 1062,1066 ****
-    unsigned int directory_len;
-    int free_dirname;                  /* flag */
-!   int dflags;
-  
-    result = (char **) malloc (sizeof (char *));
---- 1078,1082 ----
-    unsigned int directory_len;
-    int free_dirname;                  /* flag */
-!   int dflags, hasglob;
-  
-    result = (char **) malloc (sizeof (char *));
-***************
-*** 1111,1117 ****
-      }
-  
-    /* If directory_name contains globbing characters, then we
-!      have to expand the previous levels.  Just recurse. */
-!   if (directory_len > 0 && glob_pattern_p (directory_name))
-      {
-        char **directories, *d, *p;
---- 1127,1136 ----
-      }
-  
-+   hasglob = 0;
-    /* If directory_name contains globbing characters, then we
-!      have to expand the previous levels.  Just recurse.
-!      If glob_pattern_p returns != [0,1] we have a pattern that has backslash
-!      quotes but no unquoted glob pattern characters. We dequote it below. */
-!   if (directory_len > 0 && (hasglob = glob_pattern_p (directory_name)) == 1)
-      {
-        char **directories, *d, *p;
-***************
-*** 1176,1180 ****
-       d[directory_len - 1] = '\0';
-  
-!       directories = glob_filename (d, dflags);
-  
-        if (free_dirname)
---- 1195,1199 ----
-       d[directory_len - 1] = '\0';
-  
-!       directories = glob_filename (d, dflags|GX_RECURSE);
-  
-        if (free_dirname)
-***************
-*** 1333,1336 ****
---- 1352,1369 ----
-         return (NULL);
-       }
-+       /* If we have a directory name with quoted characters, and we are
-+       being called recursively to glob the directory portion of a pathname,
-+       we need to dequote the directory name before returning it so the
-+       caller can read the directory */
-+       if (directory_len > 0 && hasglob == 2 && (flags & GX_RECURSE) != 0)
-+      {
-+        dequote_pathname (directory_name);
-+        directory_len = strlen (directory_name);
-+      }
-+ 
-+       /* We could check whether or not the dequoted directory_name is a
-+       directory and return it here, returning the original directory_name
-+       if not, but we don't do that yet. I'm not sure it matters. */
-+ 
-        /* Handle GX_MARKDIRS here. */
-        result[0] = (char *) malloc (directory_len + 1);
-*** ../bash-5.0-patched/pathexp.c      2018-04-29 17:44:48.000000000 -0400
---- pathexp.c  2019-01-31 20:19:41.000000000 -0500
-***************
-*** 66,74 ****
-    register int c;
-    char *send;
-!   int open;
-  
-    DECLARE_MBSTATE;
-  
-!   open = 0;
-    send = string + strlen (string);
-  
---- 66,74 ----
-    register int c;
-    char *send;
-!   int open, bsquote;
-  
-    DECLARE_MBSTATE;
-  
-!   open = bsquote = 0;
-    send = string + strlen (string);
-  
-***************
-*** 101,105 ****
-          globbing. */
-       case '\\':
-!        return (*string != 0);
-                 
-       case CTLESC:
---- 101,112 ----
-          globbing. */
-       case '\\':
-!        if (*string != '\0' && *string != '/')
-!          {
-!            bsquote = 1;
-!            string++;
-!            continue;
-!          }
-!        else if (*string == 0)
-!          return (0);
-                 
-       case CTLESC:
-***************
-*** 118,122 ****
-  #endif
-      }
-!   return (0);
-  }
-  
---- 125,130 ----
-  #endif
-      }
-! 
-!   return (bsquote ? 2 : 0);
-  }
-  
-*** ../bash-5.0-patched/bashline.c     2019-01-16 16:13:21.000000000 -0500
---- bashline.c 2019-02-22 09:29:08.000000000 -0500
-***************
-*** 3753,3757 ****
-  
-       case '\\':
-!        if (*string == 0)
-           return (0);           
-       }
---- 3766,3770 ----
-  
-       case '\\':
-!        if (*string++ == 0)
-           return (0);           
-       }

Reply via email to