public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Mats Lidell" <matsl@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] repo/gentoo:master commit in: app-editors/xemacs/, app-editors/xemacs/files/
Date: Wed, 22 Jan 2025 16:01:24 +0000 (UTC)	[thread overview]
Message-ID: <1737561392.1fcbadfedce4432586e158dc810bf3a3d922d8c1.matsl@gentoo> (raw)

commit:     1fcbadfedce4432586e158dc810bf3a3d922d8c1
Author:     Mats Lidell <matsl <AT> gentoo <DOT> org>
AuthorDate: Wed Jan 22 15:20:45 2025 +0000
Commit:     Mats Lidell <matsl <AT> gentoo <DOT> org>
CommitDate: Wed Jan 22 15:56:32 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1fcbadfe

app-editors/xemacs: Fix segfault calling center-to-window-pos

Thanks to Ulrich Müller.

Closes: https://bugs.gentoo.org/948535

Signed-off-by: Mats Lidell <matsl <AT> gentoo.org>

 .../files/xemacs-21.5.35-batch-segfault.patch      | 191 +++++++++++++++
 app-editors/xemacs/xemacs-21.5.35-r7.ebuild        | 264 +++++++++++++++++++++
 2 files changed, 455 insertions(+)

diff --git a/app-editors/xemacs/files/xemacs-21.5.35-batch-segfault.patch b/app-editors/xemacs/files/xemacs-21.5.35-batch-segfault.patch
new file mode 100644
index 000000000000..5341bea1fa56
--- /dev/null
+++ b/app-editors/xemacs/files/xemacs-21.5.35-batch-segfault.patch
@@ -0,0 +1,191 @@
+Don't segfault when calling #'center-to-window-pos and friends, -batch
+Patch backported from master branch
+https://foss.heptapod.net/xemacs/xemacs/-/issues/6
+
+commit 578daa839db83c84fc7ebbc4bf809ff66fd492f5
+Author: Aidan Kehoe <kehoea@parhasard.net>
+Date:   Tue Jan 21 16:15:47 2025 +0000
+
+    Don't segfault when calling #'center-to-window-pos and friends, -batch
+
+--- xemacs-21.5.35/src/indent.c
++++ xemacs-21.5.35/src/indent.c
+@@ -642,6 +642,15 @@ Bytebpos
+ vmotion (struct window *w, Bytebpos orig, Charcount vtarget,
+          Charcount *ret_vpos)
+ {
++  if (!redisplayable_window_p (w))
++    {
++      if (ret_vpos)
++	{
++	  *ret_vpos = 0;
++	}
++      return orig;
++    }
++
+   return vmotion_1 (w, orig, vtarget, ret_vpos, NULL);
+ }
+ 
+@@ -671,6 +680,11 @@ vertical_motion_1 (Lisp_Object lines, Li
+ 
+   w = XWINDOW (window);
+ 
++  if (!redisplayable_window_p (w))
++    {
++      return Qzero;
++    }
++
+   orig = selected ? BYTE_BUF_PT (XBUFFER (w->buffer))
+                   : marker_byte_position (w->pointm[CURRENT_DISP]);
+ 
+--- xemacs-21.5.35/src/window.c
++++ xemacs-21.5.35/src/window.c
+@@ -402,6 +402,12 @@ allocate_window (void)
+   return obj;
+ }
+ #undef INIT_DISP_VARIABLE
++
++Boolint
++redisplayable_window_p (struct window *w)
++{
++  return !FRAME_STREAM_P (XFRAME (WINDOW_FRAME (w)));
++}
+ \f
+ /************************************************************************/
+ /*                        Window mirror structure                       */
+@@ -1491,11 +1497,19 @@ POS defaults to point in WINDOW's buffer
+        (pos, window, partially))
+ {
+   struct window *w = decode_window (window);
+-  Bytebpos top = marker_byte_position (w->start[CURRENT_DISP]);
+-  struct buffer *buf = XBUFFER (w->buffer);
+-  Bytebpos posint = get_buffer_pos_byte (buf, pos,
+-                                         GB_ALLOW_PAST_ACCESSIBLE |
+-                                         GB_ALLOW_NIL | GB_NO_ERROR_IF_BAD);
++  Bytebpos top, posint;
++  struct buffer *buf;
++
++  if (!redisplayable_window_p (w))
++    {
++      return Qnil;
++    }
++
++  top = marker_byte_position (w->start[CURRENT_DISP]);
++  buf = XBUFFER (w->buffer);
++  posint = get_buffer_pos_byte (buf, pos,
++				GB_ALLOW_PAST_ACCESSIBLE | GB_ALLOW_NIL
++				| GB_NO_ERROR_IF_BAD);
+ 
+   if (posint < top || posint > BYTE_BUF_ZV (buf))
+     return Qnil;
+@@ -1659,6 +1673,12 @@ is non-nil, do not include space occupie
+   line_start_cache_dynarr *cache;
+ 
+   window = wrap_window (w);
++
++  if (!redisplayable_window_p (w))
++    {
++      return Qzero;
++    }
++
+   start  = marker_byte_position (w->start[CURRENT_DISP]);
+   hlimit = WINDOW_TEXT_HEIGHT (w);
+   eobuf  = BYTE_BUF_ZV (XBUFFER (w->buffer));
+@@ -1903,11 +1923,11 @@ e.g. if the window's current buffer has
+   struct window *w = decode_window (window);
+   Bytebpos eoll;
+ 
+-  if (NILP (guarantee) || in_display)
++  if (NILP (guarantee) || !redisplayable_window_p (w) || in_display)
+     {
+       struct buffer *b = window_display_buffer (w);
+ 
+-      if (in_display || 
++      if (in_display || !redisplayable_window_p (w) ||
+           (BUFFER_LIVE_P (b) && EQ (wrap_buffer (b), window_buffer (w))))
+         {
+           return Fmarker_position (w->end_pos[CURRENT_DISP]);
+@@ -3341,7 +3361,7 @@ value is reasonable when this function i
+      window start is outside the visible portion (as might happen when
+      the display is not current, due to typeahead). */
+   if (start_pos >= BYTE_BUF_BEGV (b) && start_pos <= BYTE_BUF_ZV (b)
+-      && !MINI_WINDOW_P (w))
++      && !MINI_WINDOW_P (w) && redisplayable_window_p (w))
+     {
+       Bytebpos new_start
+         = start_with_line_at_pixpos
+@@ -4628,6 +4648,11 @@ window_scroll (Lisp_Object window, Lisp_
+   struct display_line* dl;
+   Boolint unchain_point = 0;
+   struct gcpro gcpro1;
++
++  if (!redisplayable_window_p (w))
++    {
++      return;
++    }
+   
+   if (selected)
+     point = b->point_marker;
+@@ -5127,6 +5152,11 @@ If WINDOW is nil, the selected window is
+   Bytebpos opoint = BYTE_BUF_PT (b);
+   Bytebpos startp;
+ 
++  if (!redisplayable_window_p (w))
++    {
++      return Qnil; 
++    }
++
+   if (NILP (n))
+     startp = start_with_line_at_pixpos (w, opoint, window_half_pixpos (w));
+   else
+@@ -5491,14 +5521,20 @@ get_current_pixel_pos (Lisp_Object windo
+     {
+       int first_line, i;
+       Bytebpos point;
++      struct buffer *buf;
+ 
+       if (NILP (pos))
+         {
+           pos = Fwindow_point (wrap_window (*w));
+         }
+ 
+-      point = get_buffer_pos_byte (window_display_buffer (*w), pos,
+-                                   GB_NO_ERROR_IF_BAD);
++      buf = window_display_buffer (*w);
++      if (buf == NULL)
++	{
++	  return 0;
++	}
++
++      point = get_buffer_pos_byte (buf, pos, GB_NO_ERROR_IF_BAD);
+ 
+       /* If the window has a modeline, ignore it for our purposes, POS can't
+          be over it. Start examining the display lines from 1. */
+@@ -5552,7 +5588,7 @@ a new frame, use the following instead:
+ */
+        (window, pos))
+ {
+-  struct window* w;
++  struct window *w = decode_window (window);
+   struct display_line *dl;
+   struct rune* rb;
+ 
+@@ -5575,7 +5611,7 @@ use the following instead:
+ */
+        (window, pos))
+ {
+-  struct window* w;
++  struct window *w = decode_window (window);
+   struct display_line *dl;
+   struct rune* rb;
+ 
+--- xemacs-21.5.35/src/window.h
++++ xemacs-21.5.35/src/window.h
+@@ -152,6 +152,7 @@ int buffer_window_mru (struct window *w)
+ void check_frame_size (struct frame *frame, int *cols, int *rows);
+ int frame_pixsize_valid_p (struct frame *frame, int width, int height);
+ struct window *decode_window (Lisp_Object window);
++Boolint redisplayable_window_p (struct window *w);
+ struct window *find_window_by_pixel_pos (int pix_x, int pix_y, Lisp_Object win);
+ 
+ void free_window_mirror (struct window_mirror *mir);

diff --git a/app-editors/xemacs/xemacs-21.5.35-r7.ebuild b/app-editors/xemacs/xemacs-21.5.35-r7.ebuild
new file mode 100644
index 000000000000..e0cc1c23695a
--- /dev/null
+++ b/app-editors/xemacs/xemacs-21.5.35-r7.ebuild
@@ -0,0 +1,264 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+# Note: xemacs currently does not work with position independent code
+# so the build forces the use of the -no-pie option
+
+EAPI=8
+
+inherit flag-o-matic xdg-utils desktop autotools
+
+DESCRIPTION="highly customizable open source text editor and application development system"
+HOMEPAGE="https://www.xemacs.org/"
+
+SRC_URI="http://ftp.xemacs.org/pub/xemacs/xemacs-$(ver_cut 1-2)/${P}.tar.gz
+	https://dev.gentoo.org/~matsl/${P}-ootags-boolint.patch.xz
+	https://dev.gentoo.org/~matsl/${P}-info-handle-compress.patch.xz
+	neXt? ( http://www.malfunction.de/afterstep/files/NeXT_XEmacs.tar.gz )"
+
+LICENSE="GPL-3+"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm64 ~hppa ~ppc ~ppc64 ~riscv ~sparc ~x86"
+IUSE="alsa debug gif gpm pop postgres ldap xface nas X jpeg tiff png motif xft xim athena neXt Xaw3d gdbm berkdb +bignum"
+
+X_DEPEND="x11-libs/libXt x11-libs/libXmu x11-libs/libXext x11-misc/xbitmaps"
+
+RDEPEND="
+	berkdb? ( >=sys-libs/db-4:= )
+	gdbm? ( >=sys-libs/gdbm-1.8.3:=[berkdb(+)] )
+	>=sys-libs/zlib-1.1.4
+	>=dev-libs/openssl-0.9.6:0=
+	>=media-libs/audiofile-0.2.3
+	gpm? ( >=sys-libs/gpm-1.19.6 )
+	postgres? ( dev-db/postgresql:= )
+	ldap? ( net-nds/openldap:= )
+	alsa? ( media-libs/alsa-lib )
+	nas? ( media-libs/nas )
+	X? ( $X_DEPEND !Xaw3d? ( !neXt? ( x11-libs/libXaw ) ) )
+	motif? ( >=x11-libs/motif-2.3:0[xft=] )
+	athena? ( x11-libs/libXaw )
+	Xaw3d? ( x11-libs/libXaw3d[unicode(+)] )
+	xft? ( media-libs/freetype:2 x11-libs/libXft x11-libs/libXrender >=media-libs/fontconfig-2.5.0 )
+	neXt? ( x11-libs/neXtaw )
+	xface? ( media-libs/compface )
+	tiff? ( media-libs/tiff:= )
+	png? ( >=media-libs/libpng-1.2:0 )
+	jpeg? ( media-libs/libjpeg-turbo:= )
+	>=sys-libs/ncurses-5.2:=
+	>=app-eselect/eselect-emacs-1.15
+	bignum? ( dev-libs/openssl )"
+
+DEPEND="${RDEPEND}
+	virtual/pkgconfig"
+
+BDEPEND="sys-apps/texinfo"
+
+PDEPEND="app-xemacs/xemacs-base
+	app-xemacs/mule-base"
+
+src_unpack() {
+	default_src_unpack
+}
+
+src_prepare() {
+	use neXt && cp "${WORKDIR}"/NeXT.XEmacs/xemacs-icons/* "${S}"/etc/toolbar/
+	find "${S}"/lisp -name '*.elc' -exec rm {} \; || die
+	eapply "${FILESDIR}/${P}-configure.patch"
+	eapply "${FILESDIR}/${P}-mule-tests.patch"
+	eapply "${FILESDIR}/${P}-configure-libc-version.patch"
+	eapply "${FILESDIR}/${P}-which.patch"
+	eapply "${FILESDIR}/${P}-misalignment.patch"
+	eapply "${FILESDIR}/${P}-va_args.patch"
+	eapply "${FILESDIR}/${P}-linker-flags.patch"
+	eapply "${WORKDIR}/${P}-ootags-boolint.patch"
+	eapply "${FILESDIR}/${P}-unknown-command-test.patch"
+	eapply "${WORKDIR}/${P}-info-handle-compress.patch"
+	eapply "${FILESDIR}/${P}-batch-segfault.patch"
+
+	eapply_user
+
+	eautoconf
+
+	# Some binaries and man pages are installed under suffixed names
+	# to avoid collions with their GNU Emacs counterparts (see below).
+	# Fix internal filename references.
+	sed -i -e 's/exec gnuclient/&-xemacs/' lib-src/gnudoit || die
+	sed -i -e '/^\.so/s/etags/&-xemacs/' etc/ctags.1 || die
+	sed -i -e '/^\.so/s/gnuserv/&-xemacs/' etc/gnu{client,doit,attach}.1 || die
+}
+
+src_configure() {
+	local myconf=""
+
+	# bug #639642
+	test-flags -no-pie >/dev/null && append-flags -no-pie
+	filter-flags -pie
+
+	if use X; then
+
+		myconf="${myconf} --with-widgets=athena"
+		myconf="${myconf} --with-dialogs=athena"
+		myconf="${myconf} --with-menubars=lucid"
+		myconf="${myconf} --with-scrollbars=lucid"
+		if use motif ; then
+			myconf="--with-widgets=motif"
+			myconf="${myconf} --with-dialogs=motif"
+			myconf="${myconf} --with-scrollbars=motif"
+			myconf="${myconf} --with-menubars=lucid"
+		fi
+		if use athena or use Xaw3d ; then
+			myconf="--with-scrollbars=athena"
+		fi
+
+		if use Xaw3d; then
+			myconf="${myconf} --with-athena=3d"
+		elif use neXt; then
+			myconf="${myconf} --with-athena=next"
+		else
+			myconf="${myconf} --with-athena=xaw"
+		fi
+
+		myconf="${myconf} $(use_with tiff )"
+		myconf="${myconf} $(use_with png )"
+		myconf="${myconf} $(use_with jpeg )"
+		myconf="${myconf} $(use_with xface )"
+
+		use xft && myconf="${myconf} --with-xft=emacs,tabs,menubars,gauges" ||
+			myconf="${myconf} --with-xft=no"
+
+	else
+		myconf="${myconf}
+			--without-x
+			--without-xpm
+			--without-dragndrop
+			--with-xft=no
+			--with-gif=no"
+	fi
+
+	if use xim ; then
+		if use motif ; then
+			myconf="${myconf} --with-xim=motif"
+		else
+		myconf="${myconf} --with-xim=xlib"
+		fi
+	else
+	  myconf="${myconf} --with-xim=no"
+	fi
+
+	myconf="${myconf} --without-wnn"
+
+	# This determines the type of sounds we are playing
+	local soundconf="native"
+
+	# This determines how these sounds should be played
+	use nas	&& soundconf="${soundconf},nas"
+	use alsa && soundconf="${soundconf},alsa"
+
+	myconf="${myconf} --with-sound=${soundconf}"
+
+	if use gdbm || use berkdb ; then
+		use gdbm   && mydb="gdbm"
+		use berkdb && mydb="${mydb},berkdb"
+
+		myconf="${myconf} --with-database=${mydb}"
+	else
+		myconf="${myconf} --without-database"
+	fi
+
+	if use debug ; then
+		myconf="${myconf} --with-debug"
+		# bug #924339
+		append-flags -fno-strict-aliasing
+	else
+		myconf="${myconf} --with-optimization --with-cflags-debugging="
+	fi
+
+	use bignum && myconf="${myconf} --with-bignum=openssl" ||
+		myconf="${myconf} --with-bignum=no"
+
+	econf ${myconf} \
+		$(use_with gif ) \
+		$(use_with gpm ) \
+		$(use_with postgres postgresql ) \
+		$(use_with ldap ) \
+		$(use_with pop ) \
+		--prefix=/usr \
+		--with-mule \
+		--with-unicode-internal \
+		--without-canna \
+		--with-ncurses \
+		--with-msw=no \
+		--with-mail-locking=flock \
+		--with-site-lisp=yes \
+		--with-site-modules=yes \
+		--enable-option-checking=no \
+		--with-last-packages=/usr/lib/xemacs
+}
+
+src_compile() {
+	emake EMACSLOADPATH="${S}"/lisp
+}
+
+src_install() {
+	emake prefix="${ED}"/usr \
+		mandir="${ED}"/usr/share/man/man1 \
+		infodir="${ED}"/usr/share/info \
+		libdir="${ED}"/usr/$(get_libdir) \
+		datadir="${ED}"/usr/share \
+		install
+
+	# Rename some applications installed in bin so that it is clear
+	# which application installed them and so that conflicting
+	# packages (emacs) can't clobber the actual applications.
+	# Addresses bug #62991.
+	for i in b2m ctags etags gnuclient gnudoit gnuattach; do
+		mv "${ED}"/usr/bin/${i} "${ED}"/usr/bin/${i}-xemacs || die "mv ${i} failed"
+	done
+
+	# rename man pages
+	for i in ctags etags gnuserv gnuclient gnudoit gnuattach; do
+		mv "${ED}"/usr/share/man/man1/${i}{,-xemacs}.1 || die "mv ${i}.1 failed"
+	done
+
+	# install base packages directories
+	dodir /usr/lib/xemacs/xemacs-packages/
+	dodir /usr/lib/xemacs/site-packages/
+	dodir /usr/lib/xemacs/site-modules/
+	dodir /usr/lib/xemacs/site-lisp/
+	dodir /usr/lib/xemacs/mule-packages
+
+	# remove extraneous info files
+	cd "${ED}"/usr/share/info
+	rm -f dir info.info texinfo* termcap* standards*
+
+	cd "${S}"
+	dodoc CHANGES-* ChangeLog INSTALL Installation PROBLEMS README*
+
+	newicon "${S}"/etc/${PN}-icon.xpm ${PN}.xpm
+
+	domenu "${FILESDIR}"/${PN}.desktop
+}
+
+pkg_postinst() {
+	eselect emacs update ifunset
+	eselect gnuclient update ifunset
+	xdg_desktop_database_update
+
+	einfo "If you are upgrading from XEmacs 21.4 you should note the following"
+	einfo "incompatibilities:"
+	einfo "- Mule-UCS is no longer supported due to proper UTF-8 support in XEmacs 21.5"
+	einfo "- The X resource class has changed from Emacs to XEmacs,"
+	einfo "  settings in your .Xdefaults file should be updated accordingly."
+
+	if use xft;
+	then
+	  einfo "You have enabled Xft font support. Xft requires font names to be provided"
+	  einfo "in a different way, so you may need to adjust your .Xdefaults accordingly."
+	fi
+}
+
+pkg_postrm() {
+	eselect emacs update ifunset
+	eselect gnuclient update ifunset
+	xdg_desktop_database_update
+}


             reply	other threads:[~2025-01-22 16:01 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-01-22 16:01 Mats Lidell [this message]
  -- strict thread matches above, loose matches on Subject: below --
2025-02-19 18:58 [gentoo-commits] repo/gentoo:master commit in: app-editors/xemacs/, app-editors/xemacs/files/ Mats Lidell
2024-11-01 22:48 Mats Lidell
2024-10-18 20:38 Mats Lidell
2024-09-28 20:28 Mats Lidell
2024-09-26 16:04 Mats Lidell
2024-03-09 15:27 Mats Lidell
2022-06-16 21:16 Mats Lidell
2020-08-30 18:11 Mats Lidell
2020-01-12 19:15 Mats Lidell
2020-01-11 16:50 Mats Lidell
2019-07-09  8:25 Mats Lidell
2017-03-31 20:02 Mats Lidell
2016-04-03  0:04 Mats Lidell

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1737561392.1fcbadfedce4432586e158dc810bf3a3d922d8c1.matsl@gentoo \
    --to=matsl@gentoo.org \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox