summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2005-12-20 01:26:22 +0000
committerMike Frysinger <vapier@gentoo.org>2005-12-20 01:26:22 +0000
commit0caf9a4c4e4e0c86a3f4d06ba0f49c5c1860b01d (patch)
tree672067198821d3943bfc73491852b6af9aabef56 /sys-libs/readline
parentold (diff)
downloadgentoo-2-0caf9a4c4e4e0c86a3f4d06ba0f49c5c1860b01d.tar.gz
gentoo-2-0caf9a4c4e4e0c86a3f4d06ba0f49c5c1860b01d.tar.bz2
gentoo-2-0caf9a4c4e4e0c86a3f4d06ba0f49c5c1860b01d.zip
Grab patch from SuSe for segfault #115326 by Seemant Kulleen.
(Portage version: 2.0.53)
Diffstat (limited to 'sys-libs/readline')
-rw-r--r--sys-libs/readline/ChangeLog9
-rw-r--r--sys-libs/readline/files/digest-readline-5.1-r11
-rw-r--r--sys-libs/readline/files/readline-5.1-callback-segv.patch87
-rw-r--r--sys-libs/readline/files/readline-5.1-cleanups.patch137
-rw-r--r--sys-libs/readline/readline-5.1-r1.ebuild83
5 files changed, 316 insertions, 1 deletions
diff --git a/sys-libs/readline/ChangeLog b/sys-libs/readline/ChangeLog
index 8ed7452a85d6..f9abece6ca6d 100644
--- a/sys-libs/readline/ChangeLog
+++ b/sys-libs/readline/ChangeLog
@@ -1,6 +1,13 @@
# ChangeLog for sys-libs/readline
# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/sys-libs/readline/ChangeLog,v 1.51 2005/12/10 21:56:44 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-libs/readline/ChangeLog,v 1.52 2005/12/20 01:26:22 vapier Exp $
+
+*readline-5.1-r1 (20 Dec 2005)
+
+ 20 Dec 2005; Mike Frysinger <vapier@gentoo.org>
+ +files/readline-5.1-callback-segv.patch,
+ +files/readline-5.1-cleanups.patch, +readline-5.1-r1.ebuild:
+ Grab patch from SuSe for segfault #115326 by Seemant Kulleen.
*readline-5.1 (10 Dec 2005)
diff --git a/sys-libs/readline/files/digest-readline-5.1-r1 b/sys-libs/readline/files/digest-readline-5.1-r1
new file mode 100644
index 000000000000..69fda4e3389b
--- /dev/null
+++ b/sys-libs/readline/files/digest-readline-5.1-r1
@@ -0,0 +1 @@
+MD5 7ee5a692db88b30ca48927a13fd60e46 readline-5.1.tar.gz 2030276
diff --git a/sys-libs/readline/files/readline-5.1-callback-segv.patch b/sys-libs/readline/files/readline-5.1-callback-segv.patch
new file mode 100644
index 000000000000..94e3bfdccf7a
--- /dev/null
+++ b/sys-libs/readline/files/readline-5.1-callback-segv.patch
@@ -0,0 +1,87 @@
+http://lists.gnu.org/archive/html/bug-bash/2005-12/msg00033.html
+
+Configuration Information [Automatically generated, do not change]:
+Machine: ia64
+OS: linux
+Compiler: gcc -I/usr/src/packages/BUILD/bash-3.1 -L/usr/src/packages/BUILD/bash-3.1/../readline-5.1
+Compilation CFLAGS: -DPROGRAM='bash' -DCONF_HOSTTYPE='ia64' -DCONF_OSTYPE='linux' -DCONF_MACHTYPE='ia64-suse-linux' -DCONF_VENDOR='suse' -DLOCALEDIR='/usr/share/locale' -DPACKAGE='bash' -DSHELL -DHAVE_CONFIG_H -I. -I. -I./include -I./lib -O2 -fmessage-length=0 -Wall -D_FORTIFY_SOURCE=2 -g -D_GNU_SOURCE -DRECYCLES_PIDS -Wall -pipe -g -fbranch-probabilities
+uname output: Linux sykes 2.6.13-15-default #1 SMP Tue Sep 13 14:56:15 UTC 2005 ia64 ia64 ia64 GNU/Linux
+Machine Type: ia64-suse-linux
+
+Bash Version: 3.1
+Patch Level: 0
+Release Status: release
+
+Description:
+When using the readline callback interface (rl_callback_read_char) you'll
+get a segfault when using the delete-char function via a multi-character
+key. The problem is (1) that rl_delete_char returns non-zero even if
+successful and (2) that _rl_dispatch_subseq reports the return value of
+any readline function as if it were the result of the keymap dispatch.
+The result is that _rl_dispatch_callback doesn't clear the
+RL_STATE_MULTIKEY flag, and the next input crashes because _rl_kscxt is
+NULL when _rl_dispatch_callback is called the next time. This is only a
+problem with the callback interface, because otherwise RL_STATE_MULTIKEY
+is never set.
+
+Repeat-By:
+Build gdb with readline 5.1.
+
+Fix:
+ lib/readline/readline.c | 2 +-
+ lib/readline/text.c | 8 +++-----
+ 2 files changed, 4 insertions(+), 6 deletions(-)
+
+Index: bash-3.1/lib/readline/text.c
+===================================================================
+--- bash-3.1.orig/lib/readline/text.c 2005-12-13 14:07:38.000000000 +0100
++++ bash-3.1/lib/readline/text.c 2005-12-13 14:09:53.000000000 +0100
+@@ -1071,8 +1071,6 @@ int
+ rl_delete (count, key)
+ int count, key;
+ {
+- int r;
+-
+ if (count < 0)
+ return (_rl_rubout_char (-count, key));
+
+@@ -1090,17 +1088,17 @@ rl_delete (count, key)
+ else
+ rl_forward_byte (count, key);
+
+- r = rl_kill_text (orig_point, rl_point);
++ rl_kill_text (orig_point, rl_point);
+ rl_point = orig_point;
+- return r;
+ }
+ else
+ {
+ int new_point;
+
+ new_point = MB_NEXTCHAR (rl_line_buffer, rl_point, 1, MB_FIND_NONZERO);
+- return (rl_delete_text (rl_point, new_point));
++ rl_delete_text (rl_point, new_point);
+ }
++ return 0;
+ }
+
+ /* Delete the character under the cursor, unless the insertion
+Index: bash-3.1/lib/readline/readline.c
+===================================================================
+--- bash-3.1.orig/lib/readline/readline.c 2005-12-13 14:07:24.000000000 +0100
++++ bash-3.1/lib/readline/readline.c 2005-12-13 14:38:01.000000000 +0100
+@@ -721,7 +721,7 @@ _rl_dispatch_subseq (key, map, got_subse
+
+ rl_dispatching = 1;
+ RL_SETSTATE(RL_STATE_DISPATCHING);
+- r = (*map[key].function)(rl_numeric_arg * rl_arg_sign, key);
++ (*map[key].function)(rl_numeric_arg * rl_arg_sign, key);
+ RL_UNSETSTATE(RL_STATE_DISPATCHING);
+ rl_dispatching = 0;
+
+
+
+_______________________________________________
+Bug-bash mailing list
+Bug-bash@gnu.org
+http://lists.gnu.org/mailman/listinfo/bug-bash
diff --git a/sys-libs/readline/files/readline-5.1-cleanups.patch b/sys-libs/readline/files/readline-5.1-cleanups.patch
new file mode 100644
index 000000000000..c1f7db670a67
--- /dev/null
+++ b/sys-libs/readline/files/readline-5.1-cleanups.patch
@@ -0,0 +1,137 @@
+Cleanup misc warnings
+
+http://lists.gnu.org/archive/html/bug-bash/2005-12/msg00034.html
+
+--- readline-5.1/bind.c
++++ readline-5.1/bind.c
+@@ -1506,8 +1506,6 @@ rl_variable_value (name)
+ const char *name;
+ {
+ register int i;
+- int v;
+- char *ret;
+
+ /* Check for simple variables first. */
+ i = find_boolean_var (name);
+@@ -2170,7 +2168,6 @@ _rl_get_string_variable_value (name)
+ {
+ static char numbuf[32];
+ char *ret;
+- int n;
+
+ if (_rl_stricmp (name, "bell-style") == 0)
+ {
+--- readline-5.1/callback.c
++++ readline-5.1/callback.c
+@@ -43,6 +43,7 @@
+ #include "rldefs.h"
+ #include "readline.h"
+ #include "rlprivate.h"
++#include "xmalloc.h"
+
+ /* Private data for callback registration functions. See comments in
+ rl_callback_read_char for more details. */
+--- readline-5.1/display.c
++++ readline-5.1/display.c
+@@ -1164,7 +1166,7 @@ update_line (old, new, current_line, oma
+ int col_lendiff, col_temp;
+ #if defined (HANDLE_MULTIBYTE)
+ mbstate_t ps_new, ps_old;
+- int new_offset, old_offset, tmp;
++ int new_offset, old_offset;
+ #endif
+
+ /* If we're at the right edge of a terminal that supports xn, we're
+--- readline-5.1/isearch.c
++++ readline-5.1/isearch.c
+@@ -67,10 +67,6 @@ static _rl_search_cxt *_rl_isearch_init
+ static void _rl_isearch_fini PARAMS((_rl_search_cxt *));
+ static int _rl_isearch_cleanup PARAMS((_rl_search_cxt *, int));
+
+-/* Last line found by the current incremental search, so we don't `find'
+- identical lines many times in a row. */
+-static char *prev_line_found;
+-
+ /* Last search string and its length. */
+ static char *last_isearch_string;
+ static int last_isearch_string_len;
+--- readline-5.1/misc.c
++++ readline-5.1/misc.c
+@@ -212,6 +212,8 @@ rl_digit_loop ()
+ if (r <= 0 || (RL_ISSTATE (RL_STATE_NUMERICARG) == 0))
+ break;
+ }
++
++ return 0;
+ }
+
+ /* Create a default argument. */
+--- readline-5.1/readline.c
++++ readline-5.1/readline.c
+@@ -85,7 +85,7 @@ static void bind_arrow_keys_internal PAR
+ static void bind_arrow_keys PARAMS((void));
+
+ static void readline_default_bindings PARAMS((void));
+-static void reset_default_bindings PARAMS((void));
++/* static void reset_default_bindings PARAMS((void)); */
+
+ static int _rl_subseq_result PARAMS((int, Keymap, int, int));
+ static int _rl_subseq_getchar PARAMS((int));
+@@ -1054,6 +1054,7 @@ readline_default_bindings ()
+
+ /* Reset the default bindings for the terminal special characters we're
+ interested in back to rl_insert and read the new ones. */
++/* Unused function
+ static void
+ reset_default_bindings ()
+ {
+@@ -1063,6 +1064,7 @@ reset_default_bindings ()
+ rl_tty_set_default_bindings (_rl_keymap);
+ }
+ }
++*/
+
+ /* Bind some common arrow key sequences in MAP. */
+ static void
+--- readline-5.1/rltty.c
++++ readline-5.1/rltty.c
+@@ -933,7 +933,6 @@ rltty_set_default_bindings (kmap)
+ #if !defined (NO_TTY_DRIVER)
+ TIOTYPE ttybuff;
+ int tty;
+- static int called = 0;
+
+ tty = fileno (rl_instream);
+
+--- readline-5.1/search.c
++++ readline-5.1/search.c
+@@ -70,7 +70,6 @@ static int rl_history_search_pos;
+ static char *history_search_string;
+ static int history_string_size;
+
+-static UNDO_LIST *noninc_saved_undo_list;
+ static void make_history_line_current PARAMS((HIST_ENTRY *));
+ static int noninc_search_from_pos PARAMS((char *, int, int));
+ static int noninc_dosearch PARAMS((char *, int));
+--- readline-5.1/text.c
++++ readline-5.1/text.c
+@@ -1239,7 +1239,7 @@ rl_change_case (count, op)
+ #if defined (HANDLE_MULTIBYTE)
+ wchar_t wc, nwc;
+ char mb[MB_LEN_MAX+1];
+- int mblen, p;
++ int mblen;
+ mbstate_t ps;
+ #endif
+
+--- readline-5.1/vi_mode.c
++++ readline-5.1/vi_mode.c
+@@ -1111,7 +1111,7 @@ int
+ rl_vi_rubout (count, key)
+ int count, key;
+ {
+- int p, opoint;
++ int opoint;
+
+ if (count < 0)
+ return (rl_vi_delete (-count, key));
diff --git a/sys-libs/readline/readline-5.1-r1.ebuild b/sys-libs/readline/readline-5.1-r1.ebuild
new file mode 100644
index 000000000000..613500d883b6
--- /dev/null
+++ b/sys-libs/readline/readline-5.1-r1.ebuild
@@ -0,0 +1,83 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-libs/readline/readline-5.1-r1.ebuild,v 1.1 2005/12/20 01:26:22 vapier Exp $
+
+inherit eutils multilib
+
+# Official patches
+PLEVEL=""
+
+DESCRIPTION="Another cute console display library"
+HOMEPAGE="http://cnswww.cns.cwru.edu/php/chet/readline/rltop.html"
+SRC_URI="mirror://gnu/readline/${P}.tar.gz
+ ${PLEVEL//x/mirror://gnu/${PN}/${PN}-${PV}-patches/${PN}${PV/\.}-}"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc-macos ~ppc64 ~s390 ~sh ~sparc ~x86"
+IUSE=""
+
+# We must be certain that we have a bash that is linked
+# to its internal readline, else we may get problems.
+RDEPEND=">=sys-libs/ncurses-5.2-r2"
+DEPEND="${RDEPEND}
+ >=app-shells/bash-2.05b-r2"
+
+src_unpack() {
+ unpack ${P}.tar.gz
+
+ cd "${S}"
+ for x in ${PLEVEL//x} ; do
+ epatch "${DISTDIR}"/${PN}${PV/\.}-${x}
+ done
+ epatch "${FILESDIR}"/bash-3.0-etc-inputrc.patch
+ epatch "${FILESDIR}"/${PN}-5.0-no_rpath.patch
+ epatch "${FILESDIR}"/${P}-cleanups.patch
+ epatch "${FILESDIR}"/${P}-callback-segv.patch #115326
+
+ # force ncurses linking #71420
+ sed -i -e 's:^SHLIB_LIBS=:SHLIB_LIBS=-lncurses:' support/shobj-conf || die "sed"
+}
+
+src_compile() {
+ # the --libdir= is needed because if lib64 is a directory, it will default
+ # to using that... even if CONF_LIBDIR isnt set or we're using a version
+ # of portage without CONF_LIBDIR support.
+ econf --with-curses --libdir=/usr/$(get_libdir) || die
+ emake || die
+}
+
+src_install() {
+ make DESTDIR="${D}" install || die
+ dodir /$(get_libdir)
+
+ if ! use userland_Darwin ; then
+ mv "${D}"/usr/$(get_libdir)/*.so* "${D}"/$(get_libdir)
+ chmod a+rx "${D}"/$(get_libdir)/*.so*
+
+ # Bug #4411
+ gen_usr_ldscript libreadline.so
+ gen_usr_ldscript libhistory.so
+ fi
+
+ dodoc CHANGELOG CHANGES README USAGE NEWS
+ docinto ps
+ dodoc doc/*.ps
+ dohtml -r doc
+}
+
+pkg_preinst() {
+ # Backwards compatibility #29865
+ if [[ -e ${ROOT}/$(get_libdir)/libreadline.so.4 ]] ; then
+ cp -pPR "${ROOT}"/$(get_libdir)/libreadline.so.4* "${D}"/$(get_libdir)/
+ touch "${D}"/$(get_libdir)/libreadline.so.4*
+ fi
+}
+
+pkg_postinst() {
+ if [[ -e ${ROOT}/$(get_libdir)/libreadline.so.4 ]] ; then
+ ewarn "Your old readline libraries have been copied over."
+ ewarn "You should run 'revdep-rebuild --soname libreadline.so.4' asap."
+ ewarn "Once you have, you can safely delete /$(get_libdir)/libreadline.so.4*"
+ fi
+}