Subject: pkg/25750: aterm's cut'n'paste doesn't work between 64bit and 32bit platforms
To: None <gnats-bugs@gnats.NetBSD.org>
From: Joachim Kuebart <kuebart@mathematik.uni-ulm.de>
List: pkgsrc-bugs
Date: 05/30/2004 13:45:15
>Number: 25750
>Category: pkg
>Synopsis: aterm's cut'n'paste doesn't work between 64bit and 32bit platforms
>Confidential: no
>Severity: non-critical
>Priority: low
>Responsible: pkg-manager
>State: open
>Class: sw-bug
>Submitter-Id: net
>Arrival-Date: Sun May 30 11:46:00 UTC 2004
>Closed-Date:
>Last-Modified:
>Originator: Joachim Kuebart
>Release: NetBSD 2.0B, sources from around April 2, 2004.
>Organization:
>Environment:
System: NetBSD jaja 2.0B NetBSD 2.0B (ALPHA-$Revision: 1.191 $) #10: Thu Apr 22 17:37:18 CEST 2004 joki@jaja:/home/joki/NetBSD/compile/JAJA alpha
Architecture: alpha
Machine: alpha
aterm-0.4.2nb4
>Description:
Pasting a selection from an aterm running on a 64bit platform into
an application running on a 32bit platform doesn't always work.
>How-To-Repeat:
Run aterm on a 64bit platform (here: alpha) and make a selection.
Try to paste this into a client running on a 32bit platfrom (here:
opera on i386). Opera complains about an unknown Atom and no text
is pasted.
>Fix:
This is due to a wrong format specification in a call to XSetProperty()
from selection_send() for sending X Atoms. Fixing the arguments to
XSetProperty() solves the problem. The comment which was removed
indicates some experimentation has gone on here in the past, but
it was apparently unsuccessful.
Index: distinfo
===================================================================
RCS file: /cvsroot/pkgsrc/x11/aterm/distinfo,v
retrieving revision 1.6
diff -u -r1.6 distinfo
--- distinfo 25 Aug 2002 21:52:30 -0000 1.6
+++ distinfo 30 May 2004 11:39:32 -0000
@@ -6,4 +6,5 @@
SHA1 (patch-ab) = 9b4e6785912de338db958e9ad48c4cafcb344270
SHA1 (patch-ac) = 28c79343079680251a013ec3fe364b01f5a5ccac
SHA1 (patch-ad) = 0c87ee69672e98189afa2cfdcdd9691a1571f354
-SHA1 (patch-ae) = b4bbe033f29a8ee24cfff511fb59739d3582341d
+SHA1 (patch-ae) = cc35107d24362f8bf31badb7aa9e4aec069171b2
+SHA1 (patch-af) = e8e41fbc9837e87bc6bc495b4b698617bd1ea2ea
-------------------- New file: patches/patch-af:
$NetBSD$
--- src/screen.c.orig 2001-09-06 18:38:07.000000000 +0200
+++ src/screen.c 2004-05-30 12:43:05.000000000 +0200
@@ -3313,14 +3313,6 @@
/* ------------------------------------------------------------------------- */
/*
- * On some systems, the Atom typedef is 64 bits wide. We need to have a type
- * that is exactly 32 bits wide, because a format of 64 is not allowed by
- * the X11 protocol.
- */
-typedef CARD32 Atom32;
-
-/* ------------------------------------------------------------------------- */
-/*
* Respond to a request for our current selection
* EXT: SelectionRequest
*/
@@ -3329,7 +3321,7 @@
selection_send(XSelectionRequestEvent * rq)
{
XEvent ev;
- Atom32 target_list[2];
+ Atom target_list[2];
static Atom xa_targets = None;
if (xa_targets == None)
@@ -3344,10 +3336,10 @@
ev.xselection.time = rq->time;
if (rq->target == xa_targets) {
- target_list[0] = (Atom32) xa_targets;
- target_list[1] = (Atom32) XA_STRING;
- XChangeProperty(Xdisplay, rq->requestor, rq->property, rq->target,
- (8 * sizeof(target_list[0])), PropModeReplace,
+ target_list[0] = xa_targets;
+ target_list[1] = XA_STRING;
+ XChangeProperty(Xdisplay, rq->requestor, rq->property, XA_ATOM,
+ 32, PropModeReplace,
(unsigned char *)target_list,
(sizeof(target_list) / sizeof(target_list[0])));
ev.xselection.property = rq->property;
-------------------- End of new file: patches/patch-af:
While we're at it, the patch below also changes aterm's function
key codes F1..F4 from the old-fashioned \E[11... to the \E[OP...
used in modern xterms. This makes aterm work with NetBSD's xterm
termcap entry (aterm sets $TERM to xterm by default). Please note
that this patch is orthogonal to the above.
cvs server: Diffing patches
Index: patches/patch-ae
===================================================================
RCS file: /cvsroot/pkgsrc/x11/aterm/patches/patch-ae,v
retrieving revision 1.2
diff -u -r1.2 patch-ae
--- patches/patch-ae 25 Aug 2002 21:52:31 -0000 1.2
+++ patches/patch-ae 30 May 2004 11:39:32 -0000
@@ -1,7 +1,7 @@
-$NetBSD: patch-ae,v 1.2 2002/08/25 21:52:31 jlam Exp $
+$NetBSD$
---- src/command.c.orig Thu Sep 6 18:38:07 2001
-+++ src/command.c
+--- src/command.c.orig 2004-05-20 12:10:08.000000000 +0200
++++ src/command.c 2004-05-20 12:09:37.000000000 +0200
@@ -1146,6 +1146,11 @@
num_fds = getdtablesize();
#endif
@@ -14,7 +14,34 @@
#ifdef META8_OPTION
meta_char = (Options & Opt_meta8 ? 0x80 : 033);
if (rs_modifier
-@@ -2024,7 +2029,7 @@
+@@ -1763,16 +1768,21 @@
+ }
+ break;
+
++ case XK_F1: /* "\033OP" */
++ case XK_F2: /* "\033OQ" */
++ case XK_F3: /* "\033OR" */
++ case XK_F4: /* "\033OS" */
++ len = 3;
++ STRCPY(kbuf, "\033OP");
++ kbuf[2] += (keysym - XK_F1);
++ break;
++
+ #define FKEY(n, fkey) \
+ len = 5; \
+ sprintf((char *) kbuf,"\033[%02d~", (int)((n) + (keysym - fkey)))
+
+- case XK_F1: /* "\033[11~" */
+- case XK_F2: /* "\033[12~" */
+- case XK_F3: /* "\033[13~" */
+- case XK_F4: /* "\033[14~" */
+ case XK_F5: /* "\033[15~" */
+- FKEY(11, XK_F1);
++ FKEY(15, XK_F5);
+ break;
+
+ case XK_F6: /* "\033[17~" */
+@@ -2024,7 +2034,7 @@
#endif
/* See if we can read from the application */
>Release-Note:
>Audit-Trail:
>Unformatted: