- Timestamp:
- Apr 29, 2016 9:16:24 PM (9 years ago)
- Location:
- trunk/src/VBox
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Additions/WINNT/VBoxTray/VBoxClipboard.cpp
r58604 r60772 95 95 } 96 96 97 98 static int vboxOpenClipboard(HWND hwnd) 99 { 100 /* "OpenClipboard fails if another window has the clipboard open." 101 * So try a few times and wait up to 1 second. 102 */ 103 int rc; 104 105 uint32_t u32SleepMS = 1; 106 int i; 107 for (i = 0; i <= 9; ++i) /* u32SleepMS = [1..512] */ 108 { 109 if (OpenClipboard(hwnd)) 110 { 111 rc = 0; 112 break; 113 } 114 rc = RTErrConvertFromWin32(GetLastError()); 115 116 RTThreadSleep(u32SleepMS); 117 u32SleepMS <<= 1; 118 } 119 #ifdef LOG_ENABLED 120 if (i > 0) 121 LogFlow(("vboxOpenClipboard: %d times tried to open clipboard. \n", ++i)); 122 #endif 123 return rc; 124 } 125 126 97 127 static int vboxClipboardChanged(PVBOXCLIPBOARDCONTEXT pCtx) 98 128 { … … 100 130 101 131 /* Query list of available formats and report to host. */ 102 int rc = VINF_SUCCESS; 103 if (FALSE == OpenClipboard(pCtx->hwnd)) 104 { 105 rc = RTErrConvertFromWin32(GetLastError()); 106 } 107 else 132 int rc = vboxOpenClipboard(pCtx->hwnd); 133 if(RT_SUCCESS(rc)) 108 134 { 109 135 uint32_t u32Formats = 0; … … 147 173 CloseClipboard(); 148 174 rc = VbglR3ClipboardReportFormats(pCtx->u32ClientID, u32Formats); 175 } 176 else 177 { 178 LogFlow(("vboxClipboardChanged: error in open clipboard. hwnd: %x. err: %Rrc\n", pCtx->hwnd, rc)); 149 179 } 150 180 return rc; … … 472 502 * windows is to be destroyed and therefore the guest side becomes inactive. 473 503 */ 474 if (OpenClipboard(hwnd)) 504 int res = vboxOpenClipboard(hwnd); 505 if (RT_SUCCESS(res)) 475 506 { 476 507 EmptyClipboard(); 477 508 CloseClipboard(); 478 509 } 510 else 511 { 512 LogFlowFunc(("WM_RENDERALLFORMATS: Failed to open clipboard! rc: %Rrc\n", res)); 513 } 479 514 } break; 480 515 … … 483 518 /* Announce available formats. Do not insert data, they will be inserted in WM_RENDER*. */ 484 519 uint32_t u32Formats = (uint32_t)lParam; 485 486 if (FALSE == OpenClipboard(hwnd)) 487 { 488 LogFlowFunc(("WM_USER: Failed to open clipboard! Last error = %ld\n", GetLastError())); 489 } 490 else 520 521 int res = vboxOpenClipboard(hwnd); 522 if(RT_SUCCESS(res)) 491 523 { 492 524 EmptyClipboard(); … … 519 551 LogFlowFunc(("WM_USER: hClip = %p, err = %ld\n", hClip, GetLastError ())); 520 552 } 553 else 554 { 555 LogFlowFunc(("WM_USER: Failed to open clipboard! error = %Rrc\n", res)); 556 } 521 557 } break; 522 558 … … 527 563 HANDLE hClip = NULL; 528 564 529 if (FALSE == OpenClipboard(hwnd)) 530 { 531 LogFlowFunc(("WM_USER: Failed to open clipboard! Last error = %ld\n", GetLastError())); 532 } 533 else 565 int res = vboxOpenClipboard(hwnd); 566 if (RT_SUCCESS(res)) 534 567 { 535 568 int vboxrc; … … 602 635 CloseClipboard(); 603 636 } 637 else 638 { 639 LogFlowFunc(("WM_USER: Failed to open clipboard! rc: %Rrc\n", res)); 640 } 604 641 605 642 if (hClip == NULL) -
trunk/src/VBox/HostServices/SharedClipboard/VBoxClipboard-win.cpp
r58604 r60772 111 111 #endif /* LOG_ENABLED */ 112 112 113 113 114 static void vboxClipboardInitNewAPI(VBOXCLIPBOARDCONTEXT *pCtx) 114 115 { … … 143 144 } 144 145 146 147 static int vboxOpenClipboard(HWND hwnd) 148 { 149 /* "OpenClipboard fails if another window has the clipboard open." 150 * So try a few times and wait up to 1 second. 151 */ 152 int rc; 153 154 uint32_t u32SleepMS = 1; 155 int i; 156 for (i = 0; i <= 9; ++i) /* u32SleepMS = [1..512] */ 157 { 158 if (OpenClipboard(hwnd)) 159 { 160 rc = 0; 161 break; 162 } 163 rc = RTErrConvertFromWin32(GetLastError()); 164 165 RTThreadSleep(u32SleepMS); 166 u32SleepMS <<= 1; 167 } 168 #ifdef LOG_ENABLED 169 if (i > 0) 170 LogFlow(("vboxOpenClipboard: %d times tried to open clipboard. \n", ++i)); 171 #endif 172 return rc; 173 } 174 175 145 176 static void vboxClipboardGetData (uint32_t u32Format, const void *pvSrc, uint32_t cbSrc, 146 177 void *pvDst, uint32_t cbDst, uint32_t *pcbActualDst) … … 194 225 195 226 /* Query list of available formats and report to host. */ 196 if (OpenClipboard (pCtx->hwnd)) 227 int rc = vboxOpenClipboard(pCtx->hwnd); 228 if (RT_SUCCESS(rc)) 197 229 { 198 230 uint32_t u32Formats = 0; … … 240 272 vboxSvcClipboardReportMsg (pCtx->pClient, VBOX_SHARED_CLIPBOARD_HOST_MSG_FORMATS, u32Formats); 241 273 } 274 else 275 { 276 LogFlow(("vboxClipboardChanged: error in open clipboard. hwnd: %x. err: %Rrc\n", pCtx->hwnd, rc)); 277 } 242 278 } 243 279 … … 491 527 * windows is to be destroyed and therefore the guest side becomes inactive. 492 528 */ 493 if (OpenClipboard (hwnd)) 529 int res = vboxOpenClipboard(hwnd); 530 if (RT_SUCCESS(res)) 494 531 { 495 532 EmptyClipboard(); 496 533 497 534 CloseClipboard(); 535 } 536 else 537 { 538 LogFlow(("vboxClipboardWndProc: WM_RENDERALLFORMATS: error in open clipboard. hwnd: %x, rc: %Rrc\n", hwnd, res)); 498 539 } 499 540 } break; … … 515 556 Log(("WM_USER u32Formats = %02X\n", u32Formats)); 516 557 517 if (OpenClipboard (hwnd)) 558 int res = vboxOpenClipboard(hwnd); 559 if (RT_SUCCESS(res)) 518 560 { 519 561 EmptyClipboard(); … … 553 595 else 554 596 { 555 dprintf(("window proc WM_USER: failed to open clipboard \n"));597 dprintf(("window proc WM_USER: failed to open clipboard. rc: %Rrc \n", res)); 556 598 } 557 599 } break; … … 748 790 * The guest wants to read data in the given format. 749 791 */ 750 if (OpenClipboard (pClient->pCtx->hwnd)) 792 int rc = vboxOpenClipboard(pClient->pCtx->hwnd); 793 if (RT_SUCCESS(rc)) 751 794 { 752 795 dprintf(("Clipboard opened.\n")); … … 831 874 else 832 875 { 833 dprintf((" failed to open clipboard\n"));876 dprintf(("vboxClipboardReadData: failed to open clipboard, rc: %Rrc \n", rc)); 834 877 } 835 878
Note:
See TracChangeset
for help on using the changeset viewer.