diff options
author | 2013-03-12 21:47:40 +0000 | |
---|---|---|
committer | 2013-03-12 21:47:40 +0000 | |
commit | 8084b62f22f77ba868576cfa48ea040d1c6c7712 (patch) | |
tree | 2e53ffc8e9e4cc4e8582651d2425bf424f90fc59 /app-shells | |
parent | Mask USE="cg" since it is a toolkit for nvidia binary drivers. (diff) | |
download | gentoo-2-8084b62f22f77ba868576cfa48ea040d1c6c7712.tar.gz gentoo-2-8084b62f22f77ba868576cfa48ea040d1c6c7712.tar.bz2 gentoo-2-8084b62f22f77ba868576cfa48ea040d1c6c7712.zip |
Revbump to fix parameter modifier crash with :wq on empty string.
(Portage version: 2.2.0_alpha166/cvs/Linux x86_64, signed Manifest commit with key 4AB3E85B4F064CA3)
Diffstat (limited to 'app-shells')
-rw-r--r-- | app-shells/zsh/ChangeLog | 8 | ||||
-rw-r--r-- | app-shells/zsh/files/zsh-fix-parameter-modifier-crash.patch | 57 | ||||
-rw-r--r-- | app-shells/zsh/zsh-5.0.2-r1.ebuild | 180 |
3 files changed, 244 insertions, 1 deletions
diff --git a/app-shells/zsh/ChangeLog b/app-shells/zsh/ChangeLog index 956b8bce2e22..ddfcf0aa6591 100644 --- a/app-shells/zsh/ChangeLog +++ b/app-shells/zsh/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for app-shells/zsh # Copyright 1999-2013 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/app-shells/zsh/ChangeLog,v 1.203 2013/03/12 18:32:45 ago Exp $ +# $Header: /var/cvsroot/gentoo-x86/app-shells/zsh/ChangeLog,v 1.204 2013/03/12 21:47:40 radhermit Exp $ + +*zsh-5.0.2-r1 (12 Mar 2013) + + 12 Mar 2013; Tim Harder <radhermit@gentoo.org> +zsh-5.0.2-r1.ebuild, + +files/zsh-fix-parameter-modifier-crash.patch: + Revbump to fix parameter modifier crash with :wq on empty string. 12 Mar 2013; Agostino Sarubbo <ago@gentoo.org> zsh-5.0.2.ebuild: Stable for ppc, wrt bug #436348 diff --git a/app-shells/zsh/files/zsh-fix-parameter-modifier-crash.patch b/app-shells/zsh/files/zsh-fix-parameter-modifier-crash.patch new file mode 100644 index 000000000000..1e1847a60ede --- /dev/null +++ b/app-shells/zsh/files/zsh-fix-parameter-modifier-crash.patch @@ -0,0 +1,57 @@ +From 44757a653cb547ae7b556e8c92629d296d3c1f12 Mon Sep 17 00:00:00 2001 +From: Peter Stephenson <pws@users.sourceforge.net> +Date: Tue, 22 Jan 2013 16:28:58 +0000 +Subject: [PATCH] 30993: fix parameter modifier crash with :wq on empty string + +--- + ChangeLog | 8 +++++++- + Src/subst.c | 10 +++++++++- + Test/D04parameter.ztst | 7 +++++++ + 3 files changed, 23 insertions(+), 2 deletions(-) + +diff --git a/Src/subst.c b/Src/subst.c +index 974a845..a4df256 100644 +--- a/Src/subst.c ++++ b/Src/subst.c +@@ -3707,6 +3707,11 @@ paramsubst(LinkList l, LinkNode n, char **str, int qt, int pf_flags) + char *y; + + x = val; ++ if (!x) { ++ /* Shouldn't have got here with a NULL string. */ ++ DPUTS(1, "value is NULL in paramsubst"); ++ return NULL; ++ } + if (prenum || postnum) + x = dopadding(x, prenum, postnum, preone, postone, + premul, postmul +@@ -4021,7 +4026,10 @@ modify(char **str, char **ptr) + all = tmp; + t = e; + } +- *str = all; ++ if (!all) ++ *str = dupstring(""); ++ else ++ *str = all; + + } else { + switch (c) { +diff --git a/Test/D04parameter.ztst b/Test/D04parameter.ztst +index 01f8412..bea9459 100644 +--- a/Test/D04parameter.ztst ++++ b/Test/D04parameter.ztst +@@ -1544,3 +1544,10 @@ + 0:Regression test for shwordsplit with null or unset IFS and quoted array + >abc + >a b c ++ ++ foo= ++ print ${foo:wq} ++ print ${:wq} ++0:Empty parameter shouldn't cause modifiers to crash the shell ++> ++> +-- +1.8.1.5 + diff --git a/app-shells/zsh/zsh-5.0.2-r1.ebuild b/app-shells/zsh/zsh-5.0.2-r1.ebuild new file mode 100644 index 000000000000..8cdb6c5cd677 --- /dev/null +++ b/app-shells/zsh/zsh-5.0.2-r1.ebuild @@ -0,0 +1,180 @@ +# Copyright 1999-2013 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/app-shells/zsh/zsh-5.0.2-r1.ebuild,v 1.1 2013/03/12 21:47:40 radhermit Exp $ + +EAPI=5 + +# doc package for -dev version exists? +doc_available=true + +inherit eutils flag-o-matic multilib prefix + +MY_PV=${PV/_p/-dev-} +S=${WORKDIR}/${PN}-${MY_PV} + +zsh_ftp="ftp://ftp.zsh.org/pub" + +if [[ ${PV} != "${MY_PV}" ]] ; then + ZSH_URI="${zsh_ftp}/development/${PN}-${MY_PV}.tar.bz2" + if ${doc_available} ; then + ZSH_DOC_URI="${zsh_ftp}/development/${PN}-${MY_PV}-doc.tar.bz2" + else + ZSH_DOC_URI="${zsh_ftp}/${PN}-${PV%_*}-doc.tar.bz2" + fi +else + ZSH_URI="mirror://sourceforge/${PN}/${P}.tar.bz2 + ${zsh_ftp}/${P}.tar.bz2" + ZSH_DOC_URI="${zsh_ftp}/${PN}-${PV%_*}-doc.tar.bz2" +fi + +DESCRIPTION="UNIX Shell similar to the Korn shell" +HOMEPAGE="http://www.zsh.org/" +SRC_URI="${ZSH_URI} + doc? ( ${ZSH_DOC_URI} )" + +LICENSE="ZSH gdbm? ( GPL-2 )" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~amd64-fbsd ~sparc-fbsd ~x86-fbsd ~x86-interix ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris" +IUSE="caps debug doc examples gdbm maildir pcre static unicode" + +RDEPEND=" + >=sys-libs/ncurses-5.1 + static? ( >=sys-libs/ncurses-5.7-r4[static-libs] ) + caps? ( sys-libs/libcap ) + pcre? ( >=dev-libs/libpcre-3.9 + static? ( >=dev-libs/libpcre-3.9[static-libs] ) ) + gdbm? ( sys-libs/gdbm ) +" +DEPEND="sys-apps/groff + ${RDEPEND}" +PDEPEND=" + examples? ( app-doc/zsh-lovers ) +" + +src_prepare() { + # fix zshall problem with soelim + ln -s Doc man1 + mv Doc/zshall.1 Doc/zshall.1.soelim + soelim Doc/zshall.1.soelim > Doc/zshall.1 + + epatch "${FILESDIR}"/${PN}-init.d-gentoo-r1.diff + epatch "${FILESDIR}"/${PN}-fix-parameter-modifier-crash.patch + + cp "${FILESDIR}"/zprofile-1 "${T}"/zprofile || die + eprefixify "${T}"/zprofile || die + if use prefix ; then + sed -i -e 's|@ZSH_PREFIX@||' -e '/@ZSH_NOPREFIX@/d' "${T}"/zprofile || die + else + sed -i -e 's|@ZSH_NOPREFIX@||' -e '/@ZSH_PREFIX@/d' -e 's|""||' "${T}"/zprofile || die + fi +} + +src_configure() { + local myconf= + + if use static ; then + myconf+=" --disable-dynamic" + append-ldflags -static + fi + if use debug ; then + myconf+=" \ + --enable-zsh-debug \ + --enable-zsh-mem-debug \ + --enable-zsh-mem-warning \ + --enable-zsh-secure-free \ + --enable-zsh-hash-debug" + fi + + if [[ ${CHOST} == *-darwin* ]]; then + myconf+=" --enable-libs=-liconv" + append-ldflags -Wl,-x + fi + + econf \ + --bindir="${EPREFIX}"/bin \ + --libdir="${EPREFIX}"/usr/$(get_libdir) \ + --enable-etcdir="${EPREFIX}"/etc/zsh \ + --enable-fndir="${EPREFIX}"/usr/share/zsh/${PV%_*}/functions \ + --enable-site-fndir="${EPREFIX}"/usr/share/zsh/site-functions \ + --enable-function-subdirs \ + --with-term-lib="ncursesw ncurses" \ + --with-tcsetpgrp \ + $(use_enable maildir maildir-support) \ + $(use_enable pcre) \ + $(use_enable caps cap) \ + $(use_enable unicode multibyte) \ + $(use_enable gdbm ) \ + ${myconf} + + if use static ; then + # compile all modules statically, see Bug #27392 + # removed cap and curses because linking failes + sed -i \ + -e "s,link=no,link=static,g" \ + -e "/^name=zsh\/cap/s,link=static,link=no," \ + -e "/^name=zsh\/curses/s,link=static,link=no," \ + "${S}"/config.modules || die + if ! use gdbm ; then + sed -i '/^name=zsh\/db\/gdbm/s,link=static,link=no,' \ + "${S}"/config.modules || die + fi + fi +} + +src_test() { + local i + addpredict /dev/ptmx + for i in C02cond.ztst Y01completion.ztst Y02compmatch.ztst Y03arguments.ztst ; do + rm "${S}"/Test/${i} || die + done + emake check +} + +src_install() { + emake DESTDIR="${D}" install install.info + + insinto /etc/zsh + doins "${T}"/zprofile + + keepdir /usr/share/zsh/site-functions + insinto /usr/share/zsh/${PV%_*}/functions/Prompts + newins "${FILESDIR}"/prompt_gentoo_setup-1 prompt_gentoo_setup + + # install miscellaneous scripts; bug #54520 + local i + sed -i -e "s:/usr/local/bin/perl:${EPREFIX}/usr/bin/perl:g" \ + -e "s:/usr/local/bin/zsh:${EPREFIX}/bin/zsh:g" "${S}"/{Util,Misc}/* || die + for i in Util Misc ; do + insinto /usr/share/zsh/${PV%_*}/${i} + doins ${i}/* + done + + dodoc ChangeLog* META-FAQ NEWS README config.modules + + if use doc ; then + pushd "${WORKDIR}/${PN}-${PV%_*}" >/dev/null + dohtml -r Doc/* + insinto /usr/share/doc/${PF} + doins Doc/zsh.{dvi,pdf} + popd >/dev/null + fi + + docinto StartupFiles + dodoc StartupFiles/z* +} + +pkg_postinst() { + # should link to http://www.gentoo.org/doc/en/zsh.xml + elog + elog "If you want to enable Portage completions and Gentoo prompt," + elog "emerge app-shells/zsh-completion and add" + elog " autoload -U compinit promptinit" + elog " compinit" + elog " promptinit; prompt gentoo" + elog "to your ~/.zshrc" + elog + elog "Also, if you want to enable cache for the completions, add" + elog " zstyle ':completion::complete:*' use-cache 1" + elog "to your ~/.zshrc" + elog +} |