diff src/w32select.c @ 51777:940c7de274a2

(last_clipboard_sequence_number): New variable. (Fw32_set_clipboard_data, Fw32_get_clipboard_data): Use sequence number if possible.
author Jason Rumney <jasonr@gnu.org>
date Sun, 06 Jul 2003 21:58:40 +0000
parents 4ef507bc376e
children 695cf19ef79e
line wrap: on
line diff
--- a/src/w32select.c	Sun Jul 06 21:58:12 2003 +0000
+++ b/src/w32select.c	Sun Jul 06 21:58:40 2003 +0000
@@ -41,9 +41,14 @@
 /* Coding system for the next communicating with other Windows programs.  */
 static Lisp_Object Vnext_selection_coding_system;
 
-/* The last text we put into the clipboard.  This is used to prevent
-   passing back our own text from the clipboard, instead of using the
-   kill ring.  The former is undesirable because the clipboard data
+/* Sequence number, used where possible to detect when we are pasting
+   our own text.  */
+static DWORD last_clipboard_sequence_number;
+extern ClipboardSequence_Proc clipboard_sequence_fn;
+
+/* The last text we put into the clipboard.  This is used when the OS
+   does not support sequence numbers (NT4, 95). It is undesirable to
+   use data put on the clipboard by Emacs because the clipboard data
    could be MULEtilated by inappropriately chosen
    (next-)selection-coding-system.  For this reason, we must store the
    text *after* it was encoded/Unix-to-DOS-converted.  */
@@ -217,17 +222,23 @@
 	encode_coding (&coding, src, dst, nbytes, bufsize);
 	Vlast_coding_system_used = coding.symbol;
 
-        /* Stash away the data we are about to put into the clipboard, so we
-           could later check inside Fw32_get_clipboard_data whether
-           the clipboard still holds our data.  */
-        if (clipboard_storage_size < coding.produced)
-          {
-            clipboard_storage_size = coding.produced + 100;
-            last_clipboard_text = (char *) xrealloc (last_clipboard_text,
-                                                     clipboard_storage_size);
-          }
-        if (last_clipboard_text)
-          memcpy (last_clipboard_text, dst, coding.produced);
+	/* If clipboard sequence numbers are not supported, keep a copy for
+	   later comparison.  */
+	if (!clipboard_sequence_fn)
+	  {
+	    /* Stash away the data we are about to put into the
+	       clipboard, so we could later check inside
+	       Fw32_get_clipboard_data whether the clipboard still
+	       holds our data.  */
+	    if (clipboard_storage_size < coding.produced)
+	      {
+		clipboard_storage_size = coding.produced + 100;
+		last_clipboard_text = (char *) xrealloc (last_clipboard_text,
+							 clipboard_storage_size);
+	      }
+	    if (last_clipboard_text)
+	      memcpy (last_clipboard_text, dst, coding.produced);
+	  }
 
 	GlobalUnlock (htext);
 
@@ -243,6 +254,9 @@
 
   ok = EmptyClipboard () && SetClipboardData (CF_TEXT, htext);
 
+  if (clipboard_sequence_fn)
+    last_clipboard_sequence_number = clipboard_sequence_fn ();
+
   CloseClipboard ();
 
   if (ok) goto done;
@@ -254,6 +268,8 @@
   if (last_clipboard_text)
     *last_clipboard_text = '\0';
 
+  last_clipboard_sequence_number = 0;
+
  done:
   UNBLOCK_INPUT;
 
@@ -297,9 +313,11 @@
        data in the clipboard.  This is so we don't pass our own text
        from the clipboard (which might be troublesome if the killed
        text includes null characters).  */
-    if (last_clipboard_text
-        && clipboard_storage_size >= nbytes
-        && memcmp(last_clipboard_text, src, nbytes) == 0)
+    if ((clipboard_sequence_fn
+	 && clipboard_sequence_fn () == last_clipboard_sequence_number)
+	|| (last_clipboard_text
+	    && clipboard_storage_size >= nbytes
+	    && memcmp(last_clipboard_text, src, nbytes) == 0))
       goto closeclip;
 
     {