Fix bug#72254
authorPo Lu <luangruo@yahoo.com>
Thu, 12 Sep 2024 00:22:25 +0000 (08:22 +0800)
committerPo Lu <luangruo@yahoo.com>
Thu, 12 Sep 2024 00:23:13 +0000 (08:23 +0800)
* src/pgtkselect.c (Fpgtk_get_selection_internal): If requesting
TARGETS with just one result, return it as a vector.
(bug#72254)

src/pgtkselect.c

index 271411b87caf7155393a730cf19882efcf32eca9..9e172c5860220c87b3c42ea9e2fd87f7b152da06 100644 (file)
@@ -1644,10 +1644,24 @@ frame's display, or the first available X display.  */)
 
   if (NILP (val) && FRAME_LIVE_P (f))
     {
-      Lisp_Object frame;
+      Lisp_Object frame, val;
       XSETFRAME (frame, f);
-      return pgtk_get_foreign_selection (selection_symbol, target_type,
-                                        time_stamp, frame);
+
+      val = pgtk_get_foreign_selection (selection_symbol, target_type,
+                                       time_stamp, frame);
+
+      /* A window property holding just one item is indistinguishable
+        from an array of one element, and is always decoded as the
+        former, producing issues with programs that expect the TARGETS
+        property always to return vectors, even when the toolkit
+        reports just one data type.  Though X sidesteps this ambiguity
+        by defining TARGETS as returning at least two properties
+        TARGETS and MULTIPLE, GTK knows no such scruples, and therefore
+        symbol values (or nil) should be enclosed in vectors when
+        TARGETS is being requested.  (bug#72254) */
+      if (EQ (target_type, QTARGETS) && (NILP (val) || SYMBOLP (val)))
+       val = make_vector (NILP (val) ? 0 : 1, val);
+      return val;
     }
 
   if (CONSP (val) && SYMBOLP (XCAR (val)))