updated for version 7.2-088
diff --git a/src/os_mswin.c b/src/os_mswin.c
index 32a068f..60c5a81 100644
--- a/src/os_mswin.c
+++ b/src/os_mswin.c
@@ -1224,6 +1224,25 @@
#endif /* FEAT_MBYTE */
/*
+ * Wait for another process to Close the Clipboard.
+ * Returns TRUE for success.
+ */
+ int
+vim_open_clipboard()
+{
+ int delay = 10;
+
+ while (!OpenClipboard(NULL))
+ {
+ if (delay > 500)
+ return FALSE; /* waited too long, give up */
+ Sleep(delay);
+ delay *= 2; /* wait for 10, 20, 40, 80, etc. msec */
+ }
+ return TRUE;
+}
+
+/*
* Get the current selection and put it in the clipboard register.
*
* NOTE: Must use GlobalLock/Unlock here to ensure Win32s compatibility.
@@ -1254,7 +1273,7 @@
* Don't pass GetActiveWindow() as an argument to OpenClipboard() because
* then we can't paste back into the same window for some reason - webb.
*/
- if (!OpenClipboard(NULL))
+ if (!vim_open_clipboard())
return;
/* Check for vim's own clipboard format first. This only gets the type of
@@ -1562,7 +1581,7 @@
* because then we can't paste back into the same window for some
* reason - webb.
*/
- if (OpenClipboard(NULL))
+ if (vim_open_clipboard())
{
if (EmptyClipboard())
{
diff --git a/src/version.c b/src/version.c
index c0f593f..b04c881 100644
--- a/src/version.c
+++ b/src/version.c
@@ -677,6 +677,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 88,
+/**/
87,
/**/
86,