VirtualBox

Changeset 60772 in vbox for trunk/src


Ignore:
Timestamp:
Apr 29, 2016 9:16:24 PM (9 years ago)
Author:
vboxsync
Message:

Additions/SharedClipboard: fix for bugref:6466: fixed OpenClipboard() issue when multiple VM started.

Location:
trunk/src/VBox
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Additions/WINNT/VBoxTray/VBoxClipboard.cpp

    r58604 r60772  
    9595}
    9696
     97
     98static 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
    97127static int vboxClipboardChanged(PVBOXCLIPBOARDCONTEXT pCtx)
    98128{
     
    100130
    101131    /* 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))
    108134    {
    109135        uint32_t u32Formats = 0;
     
    147173        CloseClipboard();
    148174        rc = VbglR3ClipboardReportFormats(pCtx->u32ClientID, u32Formats);
     175    }
     176    else
     177    {
     178        LogFlow(("vboxClipboardChanged: error in open clipboard. hwnd: %x. err: %Rrc\n", pCtx->hwnd, rc));
    149179    }
    150180    return rc;
     
    472502             * windows is to be destroyed and therefore the guest side becomes inactive.
    473503             */
    474             if (OpenClipboard(hwnd))
     504            int res = vboxOpenClipboard(hwnd);
     505            if (RT_SUCCESS(res))
    475506            {
    476507                EmptyClipboard();
    477508                CloseClipboard();
    478509            }
     510            else
     511            {
     512                LogFlowFunc(("WM_RENDERALLFORMATS: Failed to open clipboard! rc: %Rrc\n", res));
     513            }
    479514        } break;
    480515
     
    483518            /* Announce available formats. Do not insert data, they will be inserted in WM_RENDER*. */
    484519            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))
    491523            {
    492524                EmptyClipboard();
     
    519551                LogFlowFunc(("WM_USER: hClip = %p, err = %ld\n", hClip, GetLastError ()));
    520552            }
     553            else
     554            {
     555                LogFlowFunc(("WM_USER: Failed to open clipboard! error = %Rrc\n", res));
     556            }
    521557        } break;
    522558
     
    527563            HANDLE hClip = NULL;
    528564
    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))
    534567            {
    535568                int vboxrc;
     
    602635                CloseClipboard();
    603636            }
     637            else
     638            {
     639                LogFlowFunc(("WM_USER: Failed to open clipboard! rc: %Rrc\n", res));
     640            }
    604641
    605642            if (hClip == NULL)
  • trunk/src/VBox/HostServices/SharedClipboard/VBoxClipboard-win.cpp

    r58604 r60772  
    111111#endif /* LOG_ENABLED */
    112112
     113
    113114static void vboxClipboardInitNewAPI(VBOXCLIPBOARDCONTEXT *pCtx)
    114115{
     
    143144}
    144145
     146
     147static 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
    145176static void vboxClipboardGetData (uint32_t u32Format, const void *pvSrc, uint32_t cbSrc,
    146177                                  void *pvDst, uint32_t cbDst, uint32_t *pcbActualDst)
     
    194225
    195226    /* 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))
    197229    {
    198230        uint32_t u32Formats = 0;
     
    240272        vboxSvcClipboardReportMsg (pCtx->pClient, VBOX_SHARED_CLIPBOARD_HOST_MSG_FORMATS, u32Formats);
    241273    }
     274    else
     275    {
     276        LogFlow(("vboxClipboardChanged: error in open clipboard. hwnd: %x. err: %Rrc\n", pCtx->hwnd, rc));
     277    }
    242278}
    243279
     
    491527             * windows is to be destroyed and therefore the guest side becomes inactive.
    492528             */
    493             if (OpenClipboard (hwnd))
     529            int res = vboxOpenClipboard(hwnd);
     530            if (RT_SUCCESS(res))
    494531            {
    495532                EmptyClipboard();
    496533
    497534                CloseClipboard();
     535            }
     536            else
     537            {
     538                LogFlow(("vboxClipboardWndProc: WM_RENDERALLFORMATS: error in open clipboard. hwnd: %x, rc: %Rrc\n", hwnd, res));
    498539            }
    499540        } break;
     
    515556            Log(("WM_USER u32Formats = %02X\n", u32Formats));
    516557
    517             if (OpenClipboard (hwnd))
     558            int res = vboxOpenClipboard(hwnd);
     559            if (RT_SUCCESS(res))
    518560            {
    519561                EmptyClipboard();
     
    553595            else
    554596            {
    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));
    556598            }
    557599        } break;
     
    748790     * The guest wants to read data in the given format.
    749791     */
    750     if (OpenClipboard (pClient->pCtx->hwnd))
     792    int rc = vboxOpenClipboard(pClient->pCtx->hwnd);
     793    if (RT_SUCCESS(rc))
    751794    {
    752795        dprintf(("Clipboard opened.\n"));
     
    831874    else
    832875    {
    833         dprintf(("failed to open clipboard\n"));
     876        dprintf(("vboxClipboardReadData: failed to open clipboard, rc: %Rrc \n", rc));
    834877    }
    835878
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette