VirtualBox

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


Ignore:
Timestamp:
Sep 2, 2013 11:14:11 AM (11 years ago)
Author:
vboxsync
Message:

testcase/*: move the installation path for the remaining API/XPCOM testcases to the tescase subdirectory
Main/cbinding: repair event listener testcase, various cleanups

Location:
trunk/src/VBox/Main/cbinding
Files:
1 added
3 edited
1 moved

Legend:

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

    r41477 r48225  
    55
    66#
    7 # Copyright (C) 2009-2012 Oracle Corporation
     7# Copyright (C) 2009-2013 Oracle Corporation
    88#
    99# This file is part of VirtualBox Open Source Edition (OSE), as
     
    3030XpComCSamples_SOURCES = \
    3131        tstXPCOMCGlue.c \
    32         tstXPCOMCCall.c \
     32        tstXPCOMCEvent.c \
    3333        makefile.tstXPCOMCGlue=>Makefile
    3434
     
    5151        VBoxCAPI_v4_0.h \
    5252        VBoxCAPI_v4_1.h \
     53        VBoxCAPI_v4_2.h \
    5354        $(XpComCHeaders_0_OUTDIR)/VBoxCAPI.h=>VBoxCAPI_v$(VBOX_API_VERSION).h
    5455
     
    107108  #
    108109  PROGRAMS += tstXPCOMCGlue
    109   tstXPCOMCGlue_TEMPLATE = VBOXR3EXE
     110  tstXPCOMCGlue_TEMPLATE = VBOXR3TSTEXE
    110111  tstXPCOMCGlue_INCS = \
    111112        $(VBOX_PATH_SDK)/bindings/xpcom/include \
    112113        $(VBOX_PATH_SDK)/bindings/xpcom/cbinding
    113114  tstXPCOMCGlue_INTERMEDIATES = \
    114         $(VBOX_PATH_SDK)/bindings/xpcom/cbinding/VBoxXPCOMCGlue.h \
     115        $(VBOX_PATH_SDK)/bindings/xpcom/cbinding/VBoxXPCOMCGlue.h \
    115116        $(VBOX_PATH_SDK)/bindings/xpcom/include/VBoxCAPI_v$(VBOX_API_VERSION).h
    116117  tstXPCOMCGlue_SOURCES = \
     
    119120        $(VBoxXPCOMCGlue_1_TARGET)
    120121
    121   ifeq (disabled,1)
    122    #
    123    # The callback testcase.
    124    #
    125    PROGRAMS += tstXPCOMCCall
    126    tstXPCOMCCall_TEMPLATE = VBOXR3EXE
    127    tstXPCOMCCall_INCS = \
    128         $(VBOX_PATH_SDK)/bindings/xpcom/include
    129    tstXPCOMCCall_INTERMEDIATES = \
    130         $(VBOX_PATH_SDK)/bindings/xpcom/include/VBoxCAPI_v$(VBOX_API_VERSION).h
    131    tstXPCOMCCall_SOURCES = \
    132         tstXPCOMCCall.c
    133    tstXPCOMCCall_LIBS = \
    134         $(VBoxXPCOMCGlue_1_TARGET)
    135   endif
     122  #
     123  # The event listener testcase.
     124  #
     125  PROGRAMS += tstXPCOMCEvent
     126  tstXPCOMCEvent_TEMPLATE = VBOXR3TSTEXE
     127  tstXPCOMCEvent_INCS = \
     128        $(VBOX_PATH_SDK)/bindings/xpcom/include \
     129        $(VBOX_PATH_SDK)/bindings/xpcom/cbinding
     130  tstXPCOMCEvent_INTERMEDIATES = \
     131        $(VBOX_PATH_SDK)/bindings/xpcom/cbinding/VBoxXPCOMCGlue.h \
     132        $(VBOX_PATH_SDK)/bindings/xpcom/include/VBoxCAPI_v$(VBOX_API_VERSION).h
     133  tstXPCOMCEvent_SOURCES = \
     134        tstXPCOMCEvent.c
     135  tstXPCOMCEvent_LIBS = \
     136        $(VBoxXPCOMCGlue_1_TARGET)
    136137 endif
    137138
  • trunk/src/VBox/Main/cbinding/makefile.tstXPCOMCGlue

    r44529 r48225  
    55
    66#
    7 # Copyright (C) 2009-2010 Oracle Corporation
     7# Copyright (C) 2009-2013 Oracle Corporation
    88#
    99# This file is part of VirtualBox Open Source Edition (OSE), as
     
    2424
    2525.PHONY: all
    26 all: tstXPCOMCGlue tstXPCOMCCall
     26all: tstXPCOMCGlue tstXPCOMCEvent
    2727
    2828.PHONY: clean
    2929clean:
    30         rm -f tstXPCOMCGlue.o tstXPCOMCGlue VBoxXPCOMCGlue.o tstXPCOMCCall.o tstXPCOMCCall
     30        rm -f tstXPCOMCGlue.o tstXPCOMCGlue VBoxXPCOMCGlue.o tstXPCOMCEvent.o tstXPCOMCEvent
    3131
    3232tstXPCOMCGlue: tstXPCOMCGlue.o VBoxXPCOMCGlue.o
     
    3636        $(CC) $(CFLAGS) $(INCS_XPCOM) $(GLUE_INC) -o $@ -c $<
    3737
    38 tstXPCOMCCall: tstXPCOMCCall.o VBoxXPCOMCGlue.o
     38tstXPCOMCEvent: tstXPCOMCEvent.o VBoxXPCOMCGlue.o
    3939        $(CC) -o $@ $^ -ldl -lpthread
    4040
    41 tstXPCOMCCall.o: tstXPCOMCCall.c
     41tstXPCOMCEvent.o: tstXPCOMCEvent.c
    4242        $(CC) $(CFLAGS) $(INCS_XPCOM) $(GLUE_INC) -o $@ -c $<
    4343
  • trunk/src/VBox/Main/cbinding/tstXPCOMCEvent.c

    r48192 r48225  
    11/* $Revision$ */
    2 /** @file tstXPCOMCGlue.c
    3  * Demonstrator program to illustrate use of C bindings of Main API.
     2/** @file tstXPCOMCEvent.c
     3 * Demonstrator program to illustrate use of C bindings of Main API,
     4 * and in particular how to handle active event listeners (event delivery
     5 * through callbacks). The code is derived from tstXPCOMCGlue.c, so keep
     6 * the diffs to the original code as small as possible.
    47 *
    58 * Linux only at the moment due to shared library magic in the Makefile.
     
    710
    811/*
    9  * Copyright (C) 2009-2010 Oracle Corporation
     12 * Copyright (C) 2009-2013 Oracle Corporation
    1013 *
    1114 * This file is part of VirtualBox Open Source Edition (OSE), as
     
    2831#include <signal.h>
    2932#include <sys/poll.h>
    30 
    31 /*******************************************************************************
    32 *   Internal Functions                                                         *
    33 *******************************************************************************/
    34 static void listVMs(IVirtualBox *virtualBox, ISession *session, nsIEventQueue *queue);
    35 static void registerCallBack(IVirtualBox *virtualBox, ISession *session, PRUnichar *machineId, nsIEventQueue *queue);
    36 static void startVM(IVirtualBox *virtualBox, ISession *session, PRUnichar *id, nsIEventQueue *queue);
    3733
    3834/*******************************************************************************
     
    6258}\
    6359
    64 /**
    65  * Callback functions
    66  */
    6760static const char *GetStateName(PRUint32 machineState)
    6861{
     
    7568        case MachineState_Aborted:             return "Aborted";
    7669        case MachineState_Running:             return "Running";
     70        case MachineState_Paused:              return "Paused";
     71        case MachineState_Stuck:               return "Stuck";
    7772        case MachineState_Teleporting:         return "Teleporting";
    7873        case MachineState_LiveSnapshotting:    return "LiveSnapshotting";
    79         case MachineState_Paused:              return "Paused";
    80         case MachineState_Stuck:               return "Stuck";
    8174        case MachineState_Starting:            return "Starting";
    8275        case MachineState_Stopping:            return "Stopping";
     
    8578        case MachineState_TeleportingPausedVM: return "TeleportingPausedVM";
    8679        case MachineState_TeleportingIn:       return "TeleportingIn";
    87         case MachineState_Discarding:          return "Discarding";
     80        case MachineState_FaultTolerantSyncing: return "FaultTolerantSyncing";
     81        case MachineState_DeletingSnapshotOnline: return "DeletingSnapshotOnline";
     82        case MachineState_DeletingSnapshotPaused: return "DeletingSnapshotPaused";
     83        case MachineState_RestoringSnapshot:   return "RestoringSnapshot";
     84        case MachineState_DeletingSnapshot:    return "DeletingSnapshot";
    8885        case MachineState_SettingUp:           return "SettingUp";
    8986        default:                               return "no idea";
     
    9188}
    9289
    93 static nsresult OnMousePointerShapeChange(
    94     IConsoleCallback *pThis,
    95     PRBool visible,
    96     PRBool alpha,
    97     PRUint32 xHot,
    98     PRUint32 yHot,
    99     PRUint32 width,
    100     PRUint32 height,
    101     PRUint8 * shape
    102 ) {
    103     printf("OnMousePointerShapeChange\n");
     90/**
     91 * Event handler function
     92 */
     93static nsresult HandleEvent(IEventListener *pThis, IEvent *event)
     94{
     95    enum VBoxEventType evType;
     96    nsresult rc;
     97
     98    if (!event)
     99    {
     100        printf("event null\n");
     101        return 0;
     102    }
     103
     104    evType = VBoxEventType_Invalid;
     105    rc = event->vtbl->GetType(event, &evType);
     106    if (NS_FAILED(rc))
     107    {
     108        printf("cannot get event type, rc=%#x\n", rc);
     109        return 0;
     110    }
     111
     112    switch (evType)
     113    {
     114        case VBoxEventType_OnMousePointerShapeChanged:
     115            printf("OnMousePointerShapeChanged\n");
     116            break;
     117
     118        case VBoxEventType_OnMouseCapabilityChanged:
     119            printf("OnMouseCapabilityChanged\n");
     120            break;
     121
     122        case VBoxEventType_OnKeyboardLedsChanged:
     123            printf("OnMouseCapabilityChanged\n");
     124            break;
     125
     126        case VBoxEventType_OnStateChanged:
     127        {
     128            static const nsID istateChangedEventUUID = ISTATECHANGEDEVENT_IID;
     129            IStateChangedEvent *ev = NULL;
     130            enum MachineState state;
     131            rc = event->vtbl->nsisupports.QueryInterface((nsISupports *)event, &istateChangedEventUUID, (void **)&ev);
     132            if (NS_FAILED(rc))
     133            {
     134                printf("cannot get StateChangedEvent interface, rc=%#x\n", rc);
     135                return 0;
     136            }
     137            if (!ev)
     138            {
     139                printf("StateChangedEvent reference null\n");
     140                return 0;
     141            }
     142            rc = ev->vtbl->GetState(ev, &state);
     143            if (NS_FAILED(rc))
     144                printf("warning: cannot get state, rc=%#x\n", rc);
     145            ev->vtbl->ievent.nsisupports.Release((nsISupports *)ev);
     146            printf("OnStateChanged: %s\n", GetStateName(state));
     147
     148            fflush(stdout);
     149            if (   state == MachineState_PoweredOff
     150                || state == MachineState_Saved
     151                || state == MachineState_Teleported
     152                || state == MachineState_Aborted
     153               )
     154                g_fStop = 1;
     155            break;
     156        }
     157
     158        case VBoxEventType_OnAdditionsStateChanged:
     159            printf("OnAdditionsStateChanged\n");
     160            break;
     161
     162        case VBoxEventType_OnNetworkAdapterChanged:
     163            printf("OnNetworkAdapterChanged\n");
     164            break;
     165
     166        case VBoxEventType_OnSerialPortChanged:
     167            printf("OnSerialPortChanged\n");
     168            break;
     169
     170        case VBoxEventType_OnParallelPortChanged:
     171            printf("OnParallelPortChanged\n");
     172            break;
     173
     174        case VBoxEventType_OnStorageControllerChanged:
     175            printf("OnStorageControllerChanged\n");
     176            break;
     177
     178        case VBoxEventType_OnMediumChanged:
     179            printf("OnMediumChanged\n");
     180            break;
     181
     182        case VBoxEventType_OnVRDEServerChanged:
     183            printf("OnVRDEServerChanged\n");
     184            break;
     185
     186        case VBoxEventType_OnUSBControllerChanged:
     187            printf("OnUSBControllerChanged\n");
     188            break;
     189
     190        case VBoxEventType_OnUSBDeviceStateChanged:
     191            printf("OnUSBDeviceStateChanged\n");
     192            break;
     193
     194        case VBoxEventType_OnSharedFolderChanged:
     195            printf("OnSharedFolderChanged\n");
     196            break;
     197
     198        case VBoxEventType_OnRuntimeError:
     199            printf("OnRuntimeError\n");
     200            break;
     201
     202        case VBoxEventType_OnCanShowWindow:
     203            printf("OnCanShowWindow\n");
     204            break;
     205
     206        case VBoxEventType_OnShowWindow:
     207            printf("OnShowWindow\n");
     208            break;
     209
     210        default:
     211            printf("unknown event: %d\n", evType);
     212    }
     213
    104214    return 0;
    105215}
    106 
    107 static nsresult OnMouseCapabilityChange(
    108     IConsoleCallback *pThis,
    109     PRBool supportsAbsolute,
    110     PRBool needsHostCursor
    111 ) {
    112     printf("OnMouseCapabilityChange\n");
    113     return 0;
    114 }
    115 
    116 static nsresult OnKeyboardLedsChange(
    117     IConsoleCallback *pThis,
    118     PRBool numLock,
    119     PRBool capsLock,
    120     PRBool scrollLock
    121 ) {
    122     printf("OnMouseCapabilityChange\n");
    123     return 0;
    124 }
    125 
    126 static nsresult OnStateChange(
    127     IConsoleCallback *pThis,
    128     PRUint32 state
    129 ) {
    130     printf("OnStateChange: %s\n", GetStateName(state));
    131     fflush(stdout);
    132     if (   state == MachineState_PoweredOff
    133         || state == MachineState_Saved
    134         || state == MachineState_Teleported
    135         || state == MachineState_Aborted
    136        )
    137         g_fStop = 1;
    138     return 0;
    139 }
    140 
    141 static nsresult OnAdditionsStateChange(IConsoleCallback *pThis )
    142 {
    143     printf("OnAdditionsStateChange\n");
    144     return 0;
    145 }
    146 
    147 static nsresult OnNetworkAdapterChange(
    148     IConsoleCallback *pThis,
    149     INetworkAdapter * networkAdapter
    150 ) {
    151     printf("OnNetworkAdapterChange\n");
    152     return 0;
    153 }
    154 
    155 static nsresult OnSerialPortChange(
    156     IConsoleCallback *pThis,
    157     ISerialPort * serialPort
    158 ) {
    159     printf("OnSerialPortChange\n");
    160     return 0;
    161 }
    162 
    163 static nsresult OnParallelPortChange(
    164     IConsoleCallback *pThis,
    165     IParallelPort * parallelPort
    166 ) {
    167     printf("OnParallelPortChange\n");
    168     return 0;
    169 }
    170 
    171 static nsresult OnStorageControllerChange(IConsoleCallback *pThis)
    172 {
    173     printf("OnStorageControllerChange\n");
    174     return 0;
    175 }
    176 
    177 static nsresult OnMediumChange(IConsoleCallback *pThis,
    178                                IMediumAttachment *mediumAttachment)
    179 {
    180     printf("OnMediumChange\n");
    181     return 0;
    182 }
    183 
    184 static nsresult OnVRDPServerChange(IConsoleCallback *pThis )
    185 {
    186     printf("OnVRDPServerChange\n");
    187     return 0;
    188 }
    189 
    190 static nsresult OnUSBControllerChange(IConsoleCallback *pThis )
    191 {
    192     printf("OnUSBControllerChange\n");
    193     return 0;
    194 }
    195 
    196 static nsresult OnUSBDeviceStateChange(
    197     IConsoleCallback *pThis,
    198     IUSBDevice * device,
    199     PRBool attached,
    200     IVirtualBoxErrorInfo * error
    201 ) {
    202     printf("OnUSBDeviceStateChange\n");
    203     return 0;
    204 }
    205 
    206 static nsresult OnSharedFolderChange(
    207     IConsoleCallback *pThis,
    208     PRUint32 scope
    209 ) {
    210     printf("OnSharedFolderChange\n");
    211     return 0;
    212 }
    213 
    214 static nsresult OnRuntimeError(
    215     IConsoleCallback *pThis,
    216     PRBool fatal,
    217     PRUnichar * id,
    218     PRUnichar * message
    219 ) {
    220     printf("OnRuntimeError\n");
    221     return 0;
    222 }
    223 
    224 static nsresult OnCanShowWindow(
    225     IConsoleCallback *pThis,
    226     PRBool * canShow
    227 ) {
    228     printf("OnCanShowWindow\n");
    229     return 0;
    230 }
    231 
    232 static nsresult OnShowWindow(
    233     IConsoleCallback *pThis,
    234     PRUint64 * winId
    235 ) {
    236     printf("OnShowWindow\n");
    237     return 0;
    238 }
    239 
    240216
    241217static nsresult AddRef(nsISupports *pThis)
     
    265241static nsresult QueryInterface(nsISupports *pThis, const nsID *iid, void **resultp)
    266242{
    267     static const nsID ivirtualboxCallbackUUID = IVIRTUALBOXCALLBACK_IID;
     243    static const nsID ieventListenerUUID = IEVENTLISTENER_IID;
    268244    static const nsID isupportIID = NS_ISUPPORTS_IID;
    269245
    270246    /* match iid */
    271     if (    memcmp(iid, &ivirtualboxCallbackUUID, sizeof(nsID)) == 0
     247    if (    memcmp(iid, &ieventListenerUUID, sizeof(nsID)) == 0
    272248        ||  memcmp(iid, &isupportIID, sizeof(nsID)) == 0)
    273249    {
     
    278254    }
    279255
    280     /* printf("vboxCallback QueryInterface didn't find a matching interface\n"); */
     256    /* printf("event listener QueryInterface didn't find a matching interface\n"); */
    281257    printUUID(iid);
    282     printUUID(&ivirtualboxCallbackUUID);
     258    printUUID(&ieventListenerUUID);
    283259    return NS_NOINTERFACE;
    284260}
    285261
    286262/**
    287  * Signal callback.
     263 * Signal handler, terminate event listener.
    288264 *
    289265 * @param  iSig     The signal number (ignored).
     
    297273
    298274/**
    299  * Register callback functions for the selected VM.
     275 * Register event listener for the selected VM.
    300276 *
    301277 * @param   virtualBox ptr to IVirtualBox object
     
    304280 * @param   queue      handle to the event queue
    305281 */
    306 static void registerCallBack(IVirtualBox *virtualBox, ISession *session, PRUnichar *machineId, nsIEventQueue *queue)
     282static void registerEventListener(IVirtualBox *virtualBox, ISession *session, PRUnichar *machineId, nsIEventQueue *queue)
    307283{
    308284    IConsole *console = NULL;
     
    312288    if ((NS_SUCCEEDED(rc)) && console)
    313289    {
    314         IConsoleCallback *consoleCallback = NULL;
    315 
    316         consoleCallback = calloc(1, sizeof(IConsoleCallback));
    317         consoleCallback->vtbl = calloc(1, sizeof(struct IConsoleCallback_vtbl));
    318 
    319         if (consoleCallback && consoleCallback->vtbl)
    320         {
    321             consoleCallback->vtbl->nsisupports.AddRef = &AddRef;
    322             consoleCallback->vtbl->nsisupports.Release = &Release;
    323             consoleCallback->vtbl->nsisupports.QueryInterface = &QueryInterface;
    324             consoleCallback->vtbl->OnMousePointerShapeChange = &OnMousePointerShapeChange;
    325             consoleCallback->vtbl->OnMouseCapabilityChange = &OnMouseCapabilityChange;
    326             consoleCallback->vtbl->OnKeyboardLedsChange =&OnKeyboardLedsChange;
    327             consoleCallback->vtbl->OnStateChange = &OnStateChange;
    328             consoleCallback->vtbl->OnAdditionsStateChange = &OnAdditionsStateChange;
    329             consoleCallback->vtbl->OnNetworkAdapterChange = &OnNetworkAdapterChange;
    330             consoleCallback->vtbl->OnSerialPortChange = &OnSerialPortChange;
    331             consoleCallback->vtbl->OnParallelPortChange = &OnParallelPortChange;
    332             consoleCallback->vtbl->OnStorageControllerChange = &OnStorageControllerChange;
    333             consoleCallback->vtbl->OnMediumChange = &OnMediumChange;
    334             consoleCallback->vtbl->OnVRDPServerChange = &OnVRDPServerChange;
    335             consoleCallback->vtbl->OnUSBControllerChange = &OnUSBControllerChange;
    336             consoleCallback->vtbl->OnUSBDeviceStateChange = &OnUSBDeviceStateChange;
    337             consoleCallback->vtbl->OnSharedFolderChange = &OnSharedFolderChange;
    338             consoleCallback->vtbl->OnRuntimeError = &OnRuntimeError;
    339             consoleCallback->vtbl->OnCanShowWindow = &OnCanShowWindow;
    340             consoleCallback->vtbl->OnShowWindow = &OnShowWindow;
    341             g_refcount = 1;
    342 
    343             rc = console->vtbl->RegisterCallback(console, consoleCallback);
    344             if (NS_SUCCEEDED(rc))
     290        IEventSource *es = NULL;
     291        rc = console->vtbl->GetEventSource(console, &es);
     292        if (NS_SUCCEEDED(rc) && es)
     293        {
     294            PRUint32 interestingEvents[] =
     295                {
     296                    VBoxEventType_OnMousePointerShapeChanged,
     297                    VBoxEventType_OnMouseCapabilityChanged,
     298                    VBoxEventType_OnKeyboardLedsChanged,
     299                    VBoxEventType_OnStateChanged,
     300                    VBoxEventType_OnAdditionsStateChanged,
     301                    VBoxEventType_OnNetworkAdapterChanged,
     302                    VBoxEventType_OnSerialPortChanged,
     303                    VBoxEventType_OnParallelPortChanged,
     304                    VBoxEventType_OnStorageControllerChanged,
     305                    VBoxEventType_OnMediumChanged,
     306                    VBoxEventType_OnVRDEServerChanged,
     307                    VBoxEventType_OnUSBControllerChanged,
     308                    VBoxEventType_OnUSBDeviceStateChanged,
     309                    VBoxEventType_OnSharedFolderChanged,
     310                    VBoxEventType_OnRuntimeError,
     311                    VBoxEventType_OnCanShowWindow,
     312                    VBoxEventType_OnShowWindow
     313                };
     314            IEventListener *consoleListener = NULL;
     315            consoleListener = calloc(1, sizeof(IEventListener));
     316            consoleListener->vtbl = calloc(1, sizeof(struct IEventListener_vtbl));
     317
     318            if (consoleListener && consoleListener->vtbl)
    345319            {
    346                 /* crude way to show how it works, but any
    347                  * great ideas anyone?
    348                  */
    349                 PRInt32 fd;
    350                 int ret;
    351 
    352                 printf("Entering event loop, PowerOff the machine to exit or press Ctrl-C to terminate\n");
    353                 fflush(stdout);
    354                 signal(SIGINT, sigIntHandler);
    355 
    356                 fd = queue->vtbl->GetEventQueueSelectFD(queue);
    357                 if (fd >= 0)
     320                consoleListener->vtbl->nsisupports.AddRef = &AddRef;
     321                consoleListener->vtbl->nsisupports.Release = &Release;
     322                consoleListener->vtbl->nsisupports.QueryInterface = &QueryInterface;
     323                consoleListener->vtbl->HandleEvent = &HandleEvent;
     324                g_refcount = 1;
     325
     326                rc = es->vtbl->RegisterListener(es, consoleListener,
     327                                                sizeof(interestingEvents) / sizeof(interestingEvents[0]),
     328                                                interestingEvents, 1 /* active */);
     329                if (NS_SUCCEEDED(rc))
    358330                {
    359                     while (!g_fStop)
     331                    /* crude way to show how it works, but any
     332                     * great ideas anyone?
     333                     */
     334                    PRInt32 fd;
     335                    int ret;
     336
     337                    printf("Entering event loop, PowerOff the machine to exit or press Ctrl-C to terminate\n");
     338                    fflush(stdout);
     339                    signal(SIGINT, sigIntHandler);
     340
     341                    fd = queue->vtbl->GetEventQueueSelectFD(queue);
     342                    if (fd >= 0)
    360343                    {
    361                         struct pollfd pfd;
    362 
    363                         pfd.fd = fd;
    364                         pfd.events = POLLIN | POLLERR | POLLHUP;
    365                         pfd.revents = 0;
    366 
    367                         ret = poll(&pfd, 1, 250);
    368 
    369                         if (ret <= 0)
    370                             continue;
    371 
    372                         if (pfd.revents & POLLHUP)
    373                             g_fStop = 1;
    374 
    375                         queue->vtbl->ProcessPendingEvents(queue);
     344                        while (!g_fStop)
     345                        {
     346                            struct pollfd pfd;
     347
     348                            pfd.fd = fd;
     349                            pfd.events = POLLIN | POLLERR | POLLHUP;
     350                            pfd.revents = 0;
     351
     352                            ret = poll(&pfd, 1, 250);
     353
     354                            if (ret <= 0)
     355                                continue;
     356
     357                            if (pfd.revents & POLLHUP)
     358                                g_fStop = 1;
     359
     360                            queue->vtbl->ProcessPendingEvents(queue);
     361                        }
    376362                    }
     363                    else
     364                    {
     365                        while (!g_fStop)
     366                        {
     367                            PLEvent *pEvent = NULL;
     368                            rc = queue->vtbl->WaitForEvent(queue, &pEvent);
     369                            /*printf("event: %p rc=%x\n", (void *)pEvent, rc);*/
     370                            if (NS_SUCCEEDED(rc))
     371                                queue->vtbl->HandleEvent(queue, pEvent);
     372                        }
     373                    }
     374                    signal(SIGINT, SIG_DFL);
    377375                }
    378                 else
    379                 {
    380                     while (!g_fStop)
    381                     {
    382                         PLEvent *pEvent = NULL;
    383                         rc = queue->vtbl->WaitForEvent(queue, &pEvent);
    384                         /*printf("event: %p rc=%x\n", (void *)pEvent, rc);*/
    385                         if (NS_SUCCEEDED(rc))
    386                             queue->vtbl->HandleEvent(queue, pEvent);
    387                     }
    388                 }
    389                 signal(SIGINT, SIG_DFL);
     376                es->vtbl->UnregisterListener(es, consoleListener);
     377                consoleListener->vtbl->nsisupports.Release((nsISupports *)consoleListener);
    390378            }
    391             console->vtbl->UnregisterCallback(console, consoleCallback);
    392             consoleCallback->vtbl->nsisupports.Release((nsISupports *)consoleCallback);
     379            else
     380            {
     381                printf("Failed while allocating memory for console event listener.\n");
     382            }
     383            es->vtbl->nsisupports.Release((nsISupports *)es);
     384        }
     385        console->vtbl->nsisupports.Release((nsISupports *)console);
     386    }
     387}
     388
     389/**
     390 * Start a VM.
     391 *
     392 * @param   virtualBox ptr to IVirtualBox object
     393 * @param   session    ptr to ISession object
     394 * @param   id         identifies the machine to start
     395 * @param   queue      handle to the event queue
     396 */
     397
     398static void startVM(IVirtualBox *virtualBox, ISession *session, PRUnichar *id, nsIEventQueue *queue)
     399{
     400    nsresult rc;
     401    IMachine  *machine    = NULL;
     402    IProgress *progress   = NULL;
     403    PRUnichar *env        = NULL;
     404    PRUnichar *sessionType;
     405
     406    rc = virtualBox->vtbl->FindMachine(virtualBox, id, &machine);
     407
     408    if (NS_FAILED(rc) || !machine)
     409    {
     410        fprintf(stderr, "Error: Couldn't get the machine handle.\n");
     411        return;
     412    }
     413
     414    g_pVBoxFuncs->pfnUtf8ToUtf16("gui", &sessionType);
     415
     416    rc = machine->vtbl->LaunchVMProcess(machine,
     417        session,
     418        sessionType,
     419        env,
     420        &progress
     421    );
     422
     423    g_pVBoxFuncs->pfnUtf16Free(sessionType);
     424
     425    if (NS_FAILED(rc))
     426    {
     427        fprintf(stderr, "Error: OpenRemoteSession failed.\n");
     428    }
     429    else
     430    {
     431        PRBool completed;
     432        PRInt32 resultCode;
     433
     434        printf("Waiting for the remote session to open...\n");
     435        progress->vtbl->WaitForCompletion(progress, -1);
     436
     437        rc = progress->vtbl->GetCompleted(progress, &completed);
     438        if (NS_FAILED(rc))
     439        {
     440            fprintf (stderr, "Error: GetCompleted status failed.\n");
     441        }
     442
     443        progress->vtbl->GetResultCode(progress, &resultCode);
     444        if (NS_FAILED(resultCode))
     445        {
     446            IVirtualBoxErrorInfo *errorInfo;
     447            PRUnichar *textUtf16;
     448            char *text;
     449
     450            progress->vtbl->GetErrorInfo(progress, &errorInfo);
     451            errorInfo->vtbl->GetText(errorInfo, &textUtf16);
     452            g_pVBoxFuncs->pfnUtf16ToUtf8(textUtf16, &text);
     453            printf("Error: %s\n", text);
     454
     455            g_pVBoxFuncs->pfnComUnallocMem(textUtf16);
     456            g_pVBoxFuncs->pfnUtf8Free(text);
    393457        }
    394458        else
    395459        {
    396             printf("Failed while allocating memory for console Callback.\n");
    397         }
    398     }
     460            fprintf(stderr, "Remote session has been successfully opened.\n");
     461            registerEventListener(virtualBox, session, id, queue);
     462        }
     463        progress->vtbl->nsisupports.Release((nsISupports *)progress);
     464    }
     465
     466    /* It's important to always release resources. */
     467    machine->vtbl->nsisupports.Release((nsISupports *)machine);
    399468}
    400469
     
    515584                printf("\tGuest OS:    %s\n\n", osName);
    516585
    517                 osType->vtbl->nsisupports.Release((void *)osType);
     586                osType->vtbl->nsisupports.Release((nsISupports *)osType);
    518587                g_pVBoxFuncs->pfnUtf8Free(osName);
    519588                g_pVBoxFuncs->pfnComUnallocMem(osNameUtf16);
     
    559628        }
    560629    }
    561 }
    562 
    563 /**
    564  * Start a VM.
    565  *
    566  * @param   virtualBox ptr to IVirtualBox object
    567  * @param   session    ptr to ISession object
    568  * @param   id         identifies the machine to start
    569  * @param   queue      handle to the event queue
    570  */
    571 
    572 static void startVM(IVirtualBox *virtualBox, ISession *session, PRUnichar *id, nsIEventQueue *queue)
    573 {
    574     nsresult rc;
    575     IMachine  *machine    = NULL;
    576     IProgress *progress   = NULL;
    577     PRUnichar *env        = NULL;
    578     PRUnichar *sessionType;
    579 
    580     rc = virtualBox->vtbl->GetMachine(virtualBox, id, &machine);
    581 
    582     if (NS_FAILED(rc) || !machine)
    583     {
    584         fprintf(stderr, "Error: Couldn't get the machine handle.\n");
    585         return;
    586     }
    587 
    588     g_pVBoxFuncs->pfnUtf8ToUtf16("gui", &sessionType);
    589 
    590     rc = virtualBox->vtbl->OpenRemoteSession(
    591         virtualBox,
    592         session,
    593         id,
    594         sessionType,
    595         env,
    596         &progress
    597     );
    598 
    599     g_pVBoxFuncs->pfnUtf16Free(sessionType);
    600 
    601     if (NS_FAILED(rc))
    602     {
    603         fprintf(stderr, "Error: OpenRemoteSession failed.\n");
    604     }
    605     else
    606     {
    607         PRBool completed;
    608         PRInt32 resultCode;
    609 
    610         printf("Waiting for the remote session to open...\n");
    611         progress->vtbl->WaitForCompletion(progress, -1);
    612 
    613         rc = progress->vtbl->GetCompleted(progress, &completed);
    614         if (NS_FAILED(rc))
    615         {
    616             fprintf (stderr, "Error: GetCompleted status failed.\n");
    617         }
    618 
    619         progress->vtbl->GetResultCode(progress, &resultCode);
    620         if (NS_FAILED(resultCode))
    621         {
    622             IVirtualBoxErrorInfo *errorInfo;
    623             PRUnichar *textUtf16;
    624             char *text;
    625 
    626             progress->vtbl->GetErrorInfo(progress, &errorInfo);
    627             errorInfo->vtbl->GetText(errorInfo, &textUtf16);
    628             g_pVBoxFuncs->pfnUtf16ToUtf8(textUtf16, &text);
    629             printf("Error: %s\n", text);
    630 
    631             g_pVBoxFuncs->pfnComUnallocMem(textUtf16);
    632             g_pVBoxFuncs->pfnUtf8Free(text);
    633         }
    634         else
    635         {
    636             fprintf(stderr, "Remote session has been successfully opened.\n");
    637             registerCallBack(virtualBox, session, id, queue);
    638         }
    639         progress->vtbl->nsisupports.Release((void *)progress);
    640     }
    641 
    642     /* It's important to always release resources. */
    643     machine->vtbl->nsisupports.Release((void *)machine);
    644630}
    645631
     
    743729
    744730    listVMs(vbox, session, queue);
    745     session->vtbl->Close(session);
     731    session->vtbl->UnlockMachine(session);
    746732
    747733    printf("----------------------------------------------------\n");
  • trunk/src/VBox/Main/cbinding/tstXPCOMCGlue.c

    r44529 r48225  
    77
    88/*
    9  * Copyright (C) 2009-2010 Oracle Corporation
     9 * Copyright (C) 2009-2013 Oracle Corporation
    1010 *
    1111 * This file is part of VirtualBox Open Source Edition (OSE), as
     
    2525#include <string.h>
    2626#include <stdlib.h>
    27 
    28 static void listVMs(IVirtualBox *virtualBox, ISession *session);
    29 static void startVM(IVirtualBox *virtualBox, ISession *session, PRUnichar *id);
    30 
    31 /**
    32  * List the registered VMs.
    33  *
    34  * @param   virtualBox ptr to IVirtualBox object
    35  * @param   session    ptr to ISession object
    36  */
    37 static void listVMs(IVirtualBox *virtualBox, ISession *session)
    38 {
    39     nsresult rc;
    40     IMachine **machines = NULL;
    41     PRUint32 machineCnt = 0;
    42     PRUint32 i;
    43     unsigned start_id;
    44 
    45     /*
    46      * Get the list of all registered VMs.
    47      */
    48 
    49     rc = virtualBox->vtbl->GetMachines(virtualBox, &machineCnt, &machines);
    50     if (NS_FAILED(rc))
    51     {
    52         fprintf(stderr, "could not get list of machines, rc=%08x\n",
    53             (unsigned)rc);
    54         return;
    55     }
    56 
    57     if (machineCnt == 0)
    58     {
    59         printf("\tNo VMs\n");
    60         return;
    61     }
    62 
    63     printf("VM List:\n\n");
    64 
    65     /*
    66      * Iterate through the collection.
    67      */
    68 
    69     for (i = 0; i < machineCnt; ++i)
    70     {
    71         IMachine *machine      = machines[i];
    72         PRBool    isAccessible = PR_FALSE;
    73 
    74         printf("\tMachine #%u\n", (unsigned)i);
    75 
    76         if (!machine)
    77         {
    78             printf("\t(skipped, NULL)\n");
    79             continue;
    80         }
    81 
    82         machine->vtbl->GetAccessible(machine, &isAccessible);
    83 
    84         if (isAccessible)
    85         {
    86             PRUnichar *machineNameUtf16;
    87             char *machineName;
    88 
    89             machine->vtbl->GetName(machine, &machineNameUtf16);
    90             g_pVBoxFuncs->pfnUtf16ToUtf8(machineNameUtf16,&machineName);
    91             printf("\tName:        %s\n", machineName);
    92 
    93             g_pVBoxFuncs->pfnUtf8Free(machineName);
    94             g_pVBoxFuncs->pfnComUnallocMem(machineNameUtf16);
    95         }
    96         else
    97         {
    98             printf("\tName:        <inaccessible>\n");
    99         }
    100 
    101 
    102         {
    103             PRUnichar *uuidUtf16 = NULL;
    104             char      *uuidUtf8  = NULL;
    105 
    106             machine->vtbl->GetId(machine, &uuidUtf16);
    107             g_pVBoxFuncs->pfnUtf16ToUtf8(uuidUtf16, &uuidUtf8);
    108             printf("\tUUID:        %s\n", uuidUtf8);
    109 
    110             g_pVBoxFuncs->pfnUtf8Free(uuidUtf8);
    111             g_pVBoxFuncs->pfnUtf16Free(uuidUtf16);
    112         }
    113 
    114         if (isAccessible)
    115         {
    116             {
    117                 PRUnichar *configFile;
    118                 char      *configFile1 = calloc((size_t)64, (size_t)1);
    119 
    120                 machine->vtbl->GetSettingsFilePath(machine, &configFile);
    121                 g_pVBoxFuncs->pfnUtf16ToUtf8(configFile, &configFile1);
    122                 printf("\tConfig file: %s\n", configFile1);
    123 
    124                 free(configFile1);
    125                 g_pVBoxFuncs->pfnComUnallocMem(configFile);
    126             }
    127 
    128             {
    129                 PRUint32 memorySize;
    130 
    131                 machine->vtbl->GetMemorySize(machine, &memorySize);
    132                 printf("\tMemory size: %uMB\n", memorySize);
    133             }
    134 
    135             {
    136                 PRUnichar *typeId;
    137                 PRUnichar *osNameUtf16;
    138                 char *osName;
    139                 IGuestOSType *osType = NULL;
    140 
    141                 machine->vtbl->GetOSTypeId(machine, &typeId);
    142                 virtualBox->vtbl->GetGuestOSType(virtualBox, typeId, &osType);
    143                 osType->vtbl->GetDescription(osType, &osNameUtf16);
    144                 g_pVBoxFuncs->pfnUtf16ToUtf8(osNameUtf16,&osName);
    145                 printf("\tGuest OS:    %s\n\n", osName);
    146 
    147                 osType->vtbl->nsisupports.Release((void *)osType);
    148                 g_pVBoxFuncs->pfnUtf8Free(osName);
    149                 g_pVBoxFuncs->pfnComUnallocMem(osNameUtf16);
    150                 g_pVBoxFuncs->pfnComUnallocMem(typeId);
    151             }
    152         }
    153     }
    154 
    155     /*
    156      * Let the user chose a machine to start.
    157      */
    158 
    159     printf("Type Machine# to start (0 - %u) or 'quit' to do nothing: ",
    160         (unsigned)(machineCnt - 1));
    161     fflush(stdout);
    162 
    163     if (scanf("%u", &start_id) == 1 && start_id < machineCnt)
    164     {
    165         IMachine *machine = machines[start_id];
    166 
    167         if (machine)
    168         {
    169             PRUnichar *uuidUtf16 = NULL;
    170 
    171             machine->vtbl->GetId(machine, &uuidUtf16);
    172             startVM(virtualBox, session, uuidUtf16);
    173 
    174             g_pVBoxFuncs->pfnUtf16Free(uuidUtf16);
    175         }
    176     }
    177 
    178     /*
    179      * Don't forget to release the objects in the array.
    180      */
    181 
    182     for (i = 0; i < machineCnt; ++i)
    183     {
    184         IMachine *machine = machines[i];
    185 
    186         if (machine)
    187         {
    188             machine->vtbl->nsisupports.Release((void *)machine);
    189         }
    190     }
    191 }
    19227
    19328/**
     
    26297            fprintf(stderr, "Remote session has been successfully opened.\n");
    26398        }
    264         progress->vtbl->nsisupports.Release((void *)progress);
     99        progress->vtbl->nsisupports.Release((nsISupports *)progress);
    265100    }
    266101
    267102    /* It's important to always release resources. */
    268     machine->vtbl->nsisupports.Release((void *)machine);
     103    machine->vtbl->nsisupports.Release((nsISupports *)machine);
     104}
     105
     106/**
     107 * List the registered VMs.
     108 *
     109 * @param   virtualBox ptr to IVirtualBox object
     110 * @param   session    ptr to ISession object
     111 */
     112static void listVMs(IVirtualBox *virtualBox, ISession *session)
     113{
     114    nsresult rc;
     115    IMachine **machines = NULL;
     116    PRUint32 machineCnt = 0;
     117    PRUint32 i;
     118    unsigned start_id;
     119
     120    /*
     121     * Get the list of all registered VMs.
     122     */
     123
     124    rc = virtualBox->vtbl->GetMachines(virtualBox, &machineCnt, &machines);
     125    if (NS_FAILED(rc))
     126    {
     127        fprintf(stderr, "could not get list of machines, rc=%08x\n",
     128            (unsigned)rc);
     129        return;
     130    }
     131
     132    if (machineCnt == 0)
     133    {
     134        printf("\tNo VMs\n");
     135        return;
     136    }
     137
     138    printf("VM List:\n\n");
     139
     140    /*
     141     * Iterate through the collection.
     142     */
     143
     144    for (i = 0; i < machineCnt; ++i)
     145    {
     146        IMachine *machine      = machines[i];
     147        PRBool    isAccessible = PR_FALSE;
     148
     149        printf("\tMachine #%u\n", (unsigned)i);
     150
     151        if (!machine)
     152        {
     153            printf("\t(skipped, NULL)\n");
     154            continue;
     155        }
     156
     157        machine->vtbl->GetAccessible(machine, &isAccessible);
     158
     159        if (isAccessible)
     160        {
     161            PRUnichar *machineNameUtf16;
     162            char *machineName;
     163
     164            machine->vtbl->GetName(machine, &machineNameUtf16);
     165            g_pVBoxFuncs->pfnUtf16ToUtf8(machineNameUtf16,&machineName);
     166            printf("\tName:        %s\n", machineName);
     167
     168            g_pVBoxFuncs->pfnUtf8Free(machineName);
     169            g_pVBoxFuncs->pfnComUnallocMem(machineNameUtf16);
     170        }
     171        else
     172        {
     173            printf("\tName:        <inaccessible>\n");
     174        }
     175
     176        {
     177            PRUnichar *uuidUtf16 = NULL;
     178            char      *uuidUtf8  = NULL;
     179
     180            machine->vtbl->GetId(machine, &uuidUtf16);
     181            g_pVBoxFuncs->pfnUtf16ToUtf8(uuidUtf16, &uuidUtf8);
     182            printf("\tUUID:        %s\n", uuidUtf8);
     183
     184            g_pVBoxFuncs->pfnUtf8Free(uuidUtf8);
     185            g_pVBoxFuncs->pfnUtf16Free(uuidUtf16);
     186        }
     187
     188        if (isAccessible)
     189        {
     190            {
     191                PRUnichar *configFile;
     192                char      *configFile1 = calloc((size_t)64, (size_t)1);
     193
     194                machine->vtbl->GetSettingsFilePath(machine, &configFile);
     195                g_pVBoxFuncs->pfnUtf16ToUtf8(configFile, &configFile1);
     196                printf("\tConfig file: %s\n", configFile1);
     197
     198                free(configFile1);
     199                g_pVBoxFuncs->pfnComUnallocMem(configFile);
     200            }
     201
     202            {
     203                PRUint32 memorySize;
     204
     205                machine->vtbl->GetMemorySize(machine, &memorySize);
     206                printf("\tMemory size: %uMB\n", memorySize);
     207            }
     208
     209            {
     210                PRUnichar *typeId;
     211                PRUnichar *osNameUtf16;
     212                char *osName;
     213                IGuestOSType *osType = NULL;
     214
     215                machine->vtbl->GetOSTypeId(machine, &typeId);
     216                virtualBox->vtbl->GetGuestOSType(virtualBox, typeId, &osType);
     217                osType->vtbl->GetDescription(osType, &osNameUtf16);
     218                g_pVBoxFuncs->pfnUtf16ToUtf8(osNameUtf16,&osName);
     219                printf("\tGuest OS:    %s\n\n", osName);
     220
     221                osType->vtbl->nsisupports.Release((nsISupports *)osType);
     222                g_pVBoxFuncs->pfnUtf8Free(osName);
     223                g_pVBoxFuncs->pfnComUnallocMem(osNameUtf16);
     224                g_pVBoxFuncs->pfnComUnallocMem(typeId);
     225            }
     226        }
     227    }
     228
     229    /*
     230     * Let the user chose a machine to start.
     231     */
     232
     233    printf("Type Machine# to start (0 - %u) or 'quit' to do nothing: ",
     234        (unsigned)(machineCnt - 1));
     235    fflush(stdout);
     236
     237    if (scanf("%u", &start_id) == 1 && start_id < machineCnt)
     238    {
     239        IMachine *machine = machines[start_id];
     240
     241        if (machine)
     242        {
     243            PRUnichar *uuidUtf16 = NULL;
     244
     245            machine->vtbl->GetId(machine, &uuidUtf16);
     246            startVM(virtualBox, session, uuidUtf16);
     247
     248            g_pVBoxFuncs->pfnUtf16Free(uuidUtf16);
     249        }
     250    }
     251
     252    /*
     253     * Don't forget to release the objects in the array.
     254     */
     255
     256    for (i = 0; i < machineCnt; ++i)
     257    {
     258        IMachine *machine = machines[i];
     259
     260        if (machine)
     261        {
     262            machine->vtbl->nsisupports.Release((nsISupports *)machine);
     263        }
     264    }
    269265}
    270266
     
    273269int main(int argc, char **argv)
    274270{
    275     IVirtualBox *vbox           = NULL;
     271    IVirtualBox *vbox            = NULL;
    276272    ISession   *session          = NULL;
    277273    PRUint32    revision         = 0;
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