VirtualBox

Changeset 19728 in vbox for trunk/src/VBox/Main/cbinding


Ignore:
Timestamp:
May 15, 2009 11:52:49 AM (16 years ago)
Author:
vboxsync
Message:

tstXPCOMCCall.c: event loop.

Location:
trunk/src/VBox/Main/cbinding
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Main/cbinding/Makefile.kmk

    r18998 r19728  
    101101        $(VBoxXPCOMCGlue_1_TARGET)
    102102
     103  ifeq (disabled,1)
     104   #
     105   # The callback testcase.
     106   #
     107   PROGRAMS += tstXPCOMCCall
     108   tstXPCOMCCall_TEMPLATE = VBOXR3EXE
     109   tstXPCOMCCall_INCS = \
     110        $(VBOX_PATH_SDK)/bindings/xpcom/include
     111   tstXPCOMCCall_INTERMEDIATES = \
     112        $(VBOX_PATH_SDK)/bindings/xpcom/include/VBoxCAPI_v2_5.h
     113   tstXPCOMCCall_SOURCES = \
     114        tstXPCOMCCall.c
     115   tstXPCOMCCall_LIBS = \
     116        $(VBoxXPCOMCGlue_1_TARGET)
     117  endif
    103118 endif
    104119
  • trunk/src/VBox/Main/cbinding/tstXPCOMCCall.c

    r19375 r19728  
    3030#include <stdlib.h>
    3131#include <unistd.h>
    32 
     32#include <signal.h>
     33#include <sys/poll.h>
     34
     35/*******************************************************************************
     36*   Internal Functions                                                         *
     37*******************************************************************************/
    3338static void listVMs(IVirtualBox *virtualBox, ISession *session, nsIEventQueue *queue);
    3439static void registerCallBack(IVirtualBox *virtualBox, ISession *session, PRUnichar *machineId, nsIEventQueue *queue);
    3540static void startVM(IVirtualBox *virtualBox, ISession *session, PRUnichar *id, nsIEventQueue *queue);
     41
     42/*******************************************************************************
     43*   Global Variables                                                           *
     44*******************************************************************************/
     45/** Set by signal handler. */
     46static volatile int g_fStop = 0;
    3647
    3748int volatile g_refcount = 0;
     
    212223    nsresult c;
    213224
    214     printf("AddRef\n");
    215     c = g_refcount++;
     225    c = ++g_refcount;
     226    printf("AddRef: %d\n", c);
    216227    return c;
    217228}
     
    220231{
    221232    nsresult c;
    222     printf("Release\n");
    223 
    224     c = g_refcount--;
     233
     234    c = --g_refcount;
     235    printf("Release: %d\n", c);
    225236    if (c == 0)
    226237    {
     
    236247    IConsoleCallback *that = (IConsoleCallback *)pThis;
    237248
    238     printf("QueryInterface\n");
    239249    /* match iid */
    240     g_refcount++;
     250    ++g_refcount;
     251    printf("QueryInterface: %d\n", g_refcount);
    241252    *resultp = that;
    242     return 0;
     253    return NS_OK;
     254}
     255
     256/**
     257 * Signal callback.
     258 *
     259 * @param  iSig     The signal number (ignored).
     260 */
     261static void sigIntHandler(int iSig)
     262{
     263    printf("sigIntHandler\n");
     264    (void)iSig;
     265    g_fStop = 1;
    243266}
    244267
     
    295318                 * great ideas anyone?
    296319                 */
    297                 int run = 10000000;
    298                 while (run-- > 0) {
    299                     queue->vtbl->ProcessPendingEvents(queue);
     320                PRInt32 fd;
     321
     322                printf("Entering event loop, press Ctrl-C to terminate\n");
     323                fflush(stdout);
     324                signal(SIGINT, sigIntHandler);
     325
     326                fd = queue->vtbl->GetEventQueueSelectFD(queue);
     327                if (fd >= 0) {
     328                    while (!g_fStop) {
     329                        struct pollfd   pfd;
     330                        pfd.fd = fd;
     331                        pfd.events = POLLIN | POLLERR | POLLHUP;
     332                        pfd.revents = 0;
     333                        poll(&pfd, 1, 250);
     334                        rc = queue->vtbl->ProcessPendingEvents(queue);
     335                    }
     336                } else {
     337                    while (!g_fStop) {
     338                        PLEvent *pEvent = NULL;
     339                        rc = queue->vtbl->WaitForEvent(queue, &pEvent);
     340                        /*printf("event: %p rc=%x\n", (void *)pEvent, rc);*/
     341                        if (NS_SUCCEEDED(rc))
     342                            queue->vtbl->HandleEvent(queue, pEvent);
     343                    }
    300344                }
     345                signal(SIGINT, SIG_DFL);
    301346            }
    302347            console->vtbl->UnregisterCallback(console, consoleCallback);
    303         }
    304         consoleCallback->vtbl->nsisupports.Release((nsISupports *)consoleCallback);
     348            consoleCallback->vtbl->nsisupports.Release((nsISupports *)consoleCallback);
     349        }
    305350    }
    306351    session->vtbl->Close((void *)session);
     
    593638    }
    594639    g_pVBoxFuncs->pfnGetEventQueue(&queue);
    595     printf("Got the event queue: %p\n", queue);
     640    printf("Got the event queue: %p\n", (void *)queue);
    596641
    597642    /*
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