VirtualBox

source: vbox/trunk/src/VBox/Frontends/VBoxManage/VBoxManageList.cpp@ 64273

Last change on this file since 64273 was 63404, checked in by vboxsync, 8 years ago

gcc warnings.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 53.8 KB
Line 
1/* $Id: VBoxManageList.cpp 63404 2016-08-12 20:58:24Z vboxsync $ */
2/** @file
3 * VBoxManage - The 'list' command.
4 */
5
6/*
7 * Copyright (C) 2006-2016 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef VBOX_ONLY_DOCS
19
20
21/*********************************************************************************************************************************
22* Header Files *
23*********************************************************************************************************************************/
24#include <VBox/com/com.h>
25#include <VBox/com/string.h>
26#include <VBox/com/Guid.h>
27#include <VBox/com/array.h>
28#include <VBox/com/ErrorInfo.h>
29#include <VBox/com/errorprint.h>
30
31#include <VBox/com/VirtualBox.h>
32
33#include <VBox/log.h>
34#include <iprt/stream.h>
35#include <iprt/string.h>
36#include <iprt/time.h>
37#include <iprt/getopt.h>
38#include <iprt/ctype.h>
39
40#include "VBoxManage.h"
41using namespace com;
42
43#ifdef VBOX_WITH_HOSTNETIF_API
44static const char *getHostIfMediumTypeText(HostNetworkInterfaceMediumType_T enmType)
45{
46 switch (enmType)
47 {
48 case HostNetworkInterfaceMediumType_Ethernet: return "Ethernet";
49 case HostNetworkInterfaceMediumType_PPP: return "PPP";
50 case HostNetworkInterfaceMediumType_SLIP: return "SLIP";
51 case HostNetworkInterfaceMediumType_Unknown: return "Unknown";
52 }
53 return "unknown";
54}
55
56static const char *getHostIfStatusText(HostNetworkInterfaceStatus_T enmStatus)
57{
58 switch (enmStatus)
59 {
60 case HostNetworkInterfaceStatus_Up: return "Up";
61 case HostNetworkInterfaceStatus_Down: return "Down";
62 case HostNetworkInterfaceStatus_Unknown: return "Unknown";
63 }
64 return "unknown";
65}
66#endif /* VBOX_WITH_HOSTNETIF_API */
67
68static const char*getDeviceTypeText(DeviceType_T enmType)
69{
70 switch (enmType)
71 {
72 case DeviceType_HardDisk: return "HardDisk";
73 case DeviceType_DVD: return "DVD";
74 case DeviceType_Floppy: return "Floppy";
75 /* Make MSC happy */
76 case DeviceType_Null: return "Null";
77 case DeviceType_Network: return "Network";
78 case DeviceType_USB: return "USB";
79 case DeviceType_SharedFolder: return "SharedFolder";
80 case DeviceType_Graphics3D: return "Graphics3D";
81 }
82 return "Unknown";
83}
84
85
86/**
87 * List internal networks.
88 *
89 * @returns See produceList.
90 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
91 */
92static HRESULT listInternalNetworks(const ComPtr<IVirtualBox> pVirtualBox)
93{
94 HRESULT rc;
95 com::SafeArray<BSTR> internalNetworks;
96 CHECK_ERROR(pVirtualBox, COMGETTER(InternalNetworks)(ComSafeArrayAsOutParam(internalNetworks)));
97 for (size_t i = 0; i < internalNetworks.size(); ++i)
98 {
99 RTPrintf("Name: %ls\n", internalNetworks[i]);
100 }
101 return rc;
102}
103
104
105/**
106 * List network interfaces information (bridged/host only).
107 *
108 * @returns See produceList.
109 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
110 * @param fIsBridged Selects between listing host interfaces (for
111 * use with bridging) or host only interfaces.
112 */
113static HRESULT listNetworkInterfaces(const ComPtr<IVirtualBox> pVirtualBox,
114 bool fIsBridged)
115{
116 HRESULT rc;
117 ComPtr<IHost> host;
118 CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam()));
119 com::SafeIfaceArray<IHostNetworkInterface> hostNetworkInterfaces;
120#if defined(VBOX_WITH_NETFLT)
121 if (fIsBridged)
122 CHECK_ERROR(host, FindHostNetworkInterfacesOfType(HostNetworkInterfaceType_Bridged,
123 ComSafeArrayAsOutParam(hostNetworkInterfaces)));
124 else
125 CHECK_ERROR(host, FindHostNetworkInterfacesOfType(HostNetworkInterfaceType_HostOnly,
126 ComSafeArrayAsOutParam(hostNetworkInterfaces)));
127#else
128 RT_NOREF(fIsBridged);
129 CHECK_ERROR(host, COMGETTER(NetworkInterfaces)(ComSafeArrayAsOutParam(hostNetworkInterfaces)));
130#endif
131 for (size_t i = 0; i < hostNetworkInterfaces.size(); ++i)
132 {
133 ComPtr<IHostNetworkInterface> networkInterface = hostNetworkInterfaces[i];
134#ifndef VBOX_WITH_HOSTNETIF_API
135 Bstr interfaceName;
136 networkInterface->COMGETTER(Name)(interfaceName.asOutParam());
137 RTPrintf("Name: %ls\n", interfaceName.raw());
138 Guid interfaceGuid;
139 networkInterface->COMGETTER(Id)(interfaceGuid.asOutParam());
140 RTPrintf("GUID: %ls\n\n", Bstr(interfaceGuid.toString()).raw());
141#else /* VBOX_WITH_HOSTNETIF_API */
142 Bstr interfaceName;
143 networkInterface->COMGETTER(Name)(interfaceName.asOutParam());
144 RTPrintf("Name: %ls\n", interfaceName.raw());
145 Bstr interfaceGuid;
146 networkInterface->COMGETTER(Id)(interfaceGuid.asOutParam());
147 RTPrintf("GUID: %ls\n", interfaceGuid.raw());
148 BOOL bDHCPEnabled;
149 networkInterface->COMGETTER(DHCPEnabled)(&bDHCPEnabled);
150 RTPrintf("DHCP: %s\n", bDHCPEnabled ? "Enabled" : "Disabled");
151
152 Bstr IPAddress;
153 networkInterface->COMGETTER(IPAddress)(IPAddress.asOutParam());
154 RTPrintf("IPAddress: %ls\n", IPAddress.raw());
155 Bstr NetworkMask;
156 networkInterface->COMGETTER(NetworkMask)(NetworkMask.asOutParam());
157 RTPrintf("NetworkMask: %ls\n", NetworkMask.raw());
158 Bstr IPV6Address;
159 networkInterface->COMGETTER(IPV6Address)(IPV6Address.asOutParam());
160 RTPrintf("IPV6Address: %ls\n", IPV6Address.raw());
161 ULONG IPV6NetworkMaskPrefixLength;
162 networkInterface->COMGETTER(IPV6NetworkMaskPrefixLength)(&IPV6NetworkMaskPrefixLength);
163 RTPrintf("IPV6NetworkMaskPrefixLength: %d\n", IPV6NetworkMaskPrefixLength);
164 Bstr HardwareAddress;
165 networkInterface->COMGETTER(HardwareAddress)(HardwareAddress.asOutParam());
166 RTPrintf("HardwareAddress: %ls\n", HardwareAddress.raw());
167 HostNetworkInterfaceMediumType_T Type;
168 networkInterface->COMGETTER(MediumType)(&Type);
169 RTPrintf("MediumType: %s\n", getHostIfMediumTypeText(Type));
170 HostNetworkInterfaceStatus_T Status;
171 networkInterface->COMGETTER(Status)(&Status);
172 RTPrintf("Status: %s\n", getHostIfStatusText(Status));
173 Bstr netName;
174 networkInterface->COMGETTER(NetworkName)(netName.asOutParam());
175 RTPrintf("VBoxNetworkName: %ls\n\n", netName.raw());
176#endif
177 }
178 return rc;
179}
180
181
182/**
183 * List host information.
184 *
185 * @returns See produceList.
186 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
187 */
188static HRESULT listHostInfo(const ComPtr<IVirtualBox> pVirtualBox)
189{
190 static struct
191 {
192 ProcessorFeature_T feature;
193 const char *pszName;
194 } features[]
195 =
196 {
197 { ProcessorFeature_HWVirtEx, "HW virtualization" },
198 { ProcessorFeature_PAE, "PAE" },
199 { ProcessorFeature_LongMode, "long mode" },
200 { ProcessorFeature_NestedPaging, "nested paging" },
201 };
202 HRESULT rc;
203 ComPtr<IHost> Host;
204 CHECK_ERROR(pVirtualBox, COMGETTER(Host)(Host.asOutParam()));
205
206 RTPrintf("Host Information:\n\n");
207
208 LONG64 u64UtcTime = 0;
209 CHECK_ERROR(Host, COMGETTER(UTCTime)(&u64UtcTime));
210 RTTIMESPEC timeSpec;
211 char szTime[32];
212 RTPrintf("Host time: %s\n", RTTimeSpecToString(RTTimeSpecSetMilli(&timeSpec, u64UtcTime), szTime, sizeof(szTime)));
213
214 ULONG processorOnlineCount = 0;
215 CHECK_ERROR(Host, COMGETTER(ProcessorOnlineCount)(&processorOnlineCount));
216 RTPrintf("Processor online count: %lu\n", processorOnlineCount);
217 ULONG processorCount = 0;
218 CHECK_ERROR(Host, COMGETTER(ProcessorCount)(&processorCount));
219 RTPrintf("Processor count: %lu\n", processorCount);
220 ULONG processorOnlineCoreCount = 0;
221 CHECK_ERROR(Host, COMGETTER(ProcessorOnlineCoreCount)(&processorOnlineCoreCount));
222 RTPrintf("Processor online core count: %lu\n", processorOnlineCoreCount);
223 ULONG processorCoreCount = 0;
224 CHECK_ERROR(Host, COMGETTER(ProcessorCoreCount)(&processorCoreCount));
225 RTPrintf("Processor core count: %lu\n", processorCoreCount);
226 for (unsigned i = 0; i < RT_ELEMENTS(features); i++)
227 {
228 BOOL supported;
229 CHECK_ERROR(Host, GetProcessorFeature(features[i].feature, &supported));
230 RTPrintf("Processor supports %s: %s\n", features[i].pszName, supported ? "yes" : "no");
231 }
232 for (ULONG i = 0; i < processorCount; i++)
233 {
234 ULONG processorSpeed = 0;
235 CHECK_ERROR(Host, GetProcessorSpeed(i, &processorSpeed));
236 if (processorSpeed)
237 RTPrintf("Processor#%u speed: %lu MHz\n", i, processorSpeed);
238 else
239 RTPrintf("Processor#%u speed: unknown\n", i);
240 Bstr processorDescription;
241 CHECK_ERROR(Host, GetProcessorDescription(i, processorDescription.asOutParam()));
242 RTPrintf("Processor#%u description: %ls\n", i, processorDescription.raw());
243 }
244
245 ULONG memorySize = 0;
246 CHECK_ERROR(Host, COMGETTER(MemorySize)(&memorySize));
247 RTPrintf("Memory size: %lu MByte\n", memorySize);
248
249 ULONG memoryAvailable = 0;
250 CHECK_ERROR(Host, COMGETTER(MemoryAvailable)(&memoryAvailable));
251 RTPrintf("Memory available: %lu MByte\n", memoryAvailable);
252
253 Bstr operatingSystem;
254 CHECK_ERROR(Host, COMGETTER(OperatingSystem)(operatingSystem.asOutParam()));
255 RTPrintf("Operating system: %ls\n", operatingSystem.raw());
256
257 Bstr oSVersion;
258 CHECK_ERROR(Host, COMGETTER(OSVersion)(oSVersion.asOutParam()));
259 RTPrintf("Operating system version: %ls\n", oSVersion.raw());
260 return rc;
261}
262
263
264/**
265 * List media information.
266 *
267 * @returns See produceList.
268 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
269 * @param aMedia Medium objects to list information for.
270 * @param pszParentUUIDStr String with the parent UUID string (or "base").
271 * @param fOptLong Long (@c true) or short list format.
272 */
273static HRESULT listMedia(const ComPtr<IVirtualBox> pVirtualBox,
274 const com::SafeIfaceArray<IMedium> &aMedia,
275 const char *pszParentUUIDStr,
276 bool fOptLong)
277{
278 HRESULT rc = S_OK;
279 for (size_t i = 0; i < aMedia.size(); ++i)
280 {
281 ComPtr<IMedium> pMedium = aMedia[i];
282
283 rc = showMediumInfo(pVirtualBox, pMedium, pszParentUUIDStr, fOptLong);
284
285 RTPrintf("\n");
286
287 com::SafeIfaceArray<IMedium> children;
288 CHECK_ERROR(pMedium, COMGETTER(Children)(ComSafeArrayAsOutParam(children)));
289 if (children.size() > 0)
290 {
291 Bstr uuid;
292 pMedium->COMGETTER(Id)(uuid.asOutParam());
293
294 // depth first listing of child media
295 rc = listMedia(pVirtualBox, children, Utf8Str(uuid).c_str(), fOptLong);
296 }
297 }
298
299 return rc;
300}
301
302
303/**
304 * List virtual image backends.
305 *
306 * @returns See produceList.
307 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
308 */
309static HRESULT listHddBackends(const ComPtr<IVirtualBox> pVirtualBox)
310{
311 HRESULT rc;
312 ComPtr<ISystemProperties> systemProperties;
313 CHECK_ERROR(pVirtualBox, COMGETTER(SystemProperties)(systemProperties.asOutParam()));
314 com::SafeIfaceArray<IMediumFormat> mediumFormats;
315 CHECK_ERROR(systemProperties, COMGETTER(MediumFormats)(ComSafeArrayAsOutParam(mediumFormats)));
316
317 RTPrintf("Supported hard disk backends:\n\n");
318 for (size_t i = 0; i < mediumFormats.size(); ++i)
319 {
320 /* General information */
321 Bstr id;
322 CHECK_ERROR(mediumFormats[i], COMGETTER(Id)(id.asOutParam()));
323
324 Bstr description;
325 CHECK_ERROR(mediumFormats[i],
326 COMGETTER(Name)(description.asOutParam()));
327
328 ULONG caps = 0;
329 com::SafeArray <MediumFormatCapabilities_T> mediumFormatCap;
330 CHECK_ERROR(mediumFormats[i],
331 COMGETTER(Capabilities)(ComSafeArrayAsOutParam(mediumFormatCap)));
332 for (ULONG j = 0; j < mediumFormatCap.size(); j++)
333 caps |= mediumFormatCap[j];
334
335
336 RTPrintf("Backend %u: id='%ls' description='%ls' capabilities=%#06x extensions='",
337 i, id.raw(), description.raw(), caps);
338
339 /* File extensions */
340 com::SafeArray<BSTR> fileExtensions;
341 com::SafeArray<DeviceType_T> deviceTypes;
342 CHECK_ERROR(mediumFormats[i],
343 DescribeFileExtensions(ComSafeArrayAsOutParam(fileExtensions), ComSafeArrayAsOutParam(deviceTypes)));
344 for (size_t j = 0; j < fileExtensions.size(); ++j)
345 {
346 RTPrintf("%ls (%s)", Bstr(fileExtensions[j]).raw(), getDeviceTypeText(deviceTypes[j]));
347 if (j != fileExtensions.size()-1)
348 RTPrintf(",");
349 }
350 RTPrintf("'");
351
352 /* Configuration keys */
353 com::SafeArray<BSTR> propertyNames;
354 com::SafeArray<BSTR> propertyDescriptions;
355 com::SafeArray<DataType_T> propertyTypes;
356 com::SafeArray<ULONG> propertyFlags;
357 com::SafeArray<BSTR> propertyDefaults;
358 CHECK_ERROR(mediumFormats[i],
359 DescribeProperties(ComSafeArrayAsOutParam(propertyNames),
360 ComSafeArrayAsOutParam(propertyDescriptions),
361 ComSafeArrayAsOutParam(propertyTypes),
362 ComSafeArrayAsOutParam(propertyFlags),
363 ComSafeArrayAsOutParam(propertyDefaults)));
364
365 RTPrintf(" properties=(");
366 if (propertyNames.size() > 0)
367 {
368 for (size_t j = 0; j < propertyNames.size(); ++j)
369 {
370 RTPrintf("\n name='%ls' desc='%ls' type=",
371 Bstr(propertyNames[j]).raw(), Bstr(propertyDescriptions[j]).raw());
372 switch (propertyTypes[j])
373 {
374 case DataType_Int32: RTPrintf("int"); break;
375 case DataType_Int8: RTPrintf("byte"); break;
376 case DataType_String: RTPrintf("string"); break;
377 }
378 RTPrintf(" flags=%#04x", propertyFlags[j]);
379 RTPrintf(" default='%ls'", Bstr(propertyDefaults[j]).raw());
380 if (j != propertyNames.size()-1)
381 RTPrintf(", ");
382 }
383 }
384 RTPrintf(")\n");
385 }
386 return rc;
387}
388
389
390/**
391 * List USB devices attached to the host.
392 *
393 * @returns See produceList.
394 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
395 */
396static HRESULT listUsbHost(const ComPtr<IVirtualBox> &pVirtualBox)
397{
398 HRESULT rc;
399 ComPtr<IHost> Host;
400 CHECK_ERROR_RET(pVirtualBox, COMGETTER(Host)(Host.asOutParam()), 1);
401
402 SafeIfaceArray<IHostUSBDevice> CollPtr;
403 CHECK_ERROR_RET(Host, COMGETTER(USBDevices)(ComSafeArrayAsOutParam(CollPtr)), 1);
404
405 RTPrintf("Host USB Devices:\n\n");
406
407 if (CollPtr.size() == 0)
408 {
409 RTPrintf("<none>\n\n");
410 }
411 else
412 {
413 for (size_t i = 0; i < CollPtr.size(); ++i)
414 {
415 ComPtr<IHostUSBDevice> dev = CollPtr[i];
416
417 /* Query info. */
418 Bstr id;
419 CHECK_ERROR_RET(dev, COMGETTER(Id)(id.asOutParam()), 1);
420 USHORT usVendorId;
421 CHECK_ERROR_RET(dev, COMGETTER(VendorId)(&usVendorId), 1);
422 USHORT usProductId;
423 CHECK_ERROR_RET(dev, COMGETTER(ProductId)(&usProductId), 1);
424 USHORT bcdRevision;
425 CHECK_ERROR_RET(dev, COMGETTER(Revision)(&bcdRevision), 1);
426 USHORT usPort;
427 CHECK_ERROR_RET(dev, COMGETTER(Port)(&usPort), 1);
428 USHORT usVersion;
429 CHECK_ERROR_RET(dev, COMGETTER(Version)(&usVersion), 1);
430 USHORT usPortVersion;
431 CHECK_ERROR_RET(dev, COMGETTER(PortVersion)(&usPortVersion), 1);
432 USBConnectionSpeed_T enmSpeed;
433 CHECK_ERROR_RET(dev, COMGETTER(Speed)(&enmSpeed), 1);
434
435 RTPrintf("UUID: %s\n"
436 "VendorId: %#06x (%04X)\n"
437 "ProductId: %#06x (%04X)\n"
438 "Revision: %u.%u (%02u%02u)\n"
439 "Port: %u\n",
440 Utf8Str(id).c_str(),
441 usVendorId, usVendorId, usProductId, usProductId,
442 bcdRevision >> 8, bcdRevision & 0xff,
443 bcdRevision >> 8, bcdRevision & 0xff,
444 usPort);
445
446 const char *pszSpeed = "?";
447 switch (enmSpeed)
448 {
449 case USBConnectionSpeed_Low:
450 pszSpeed = "Low";
451 break;
452 case USBConnectionSpeed_Full:
453 pszSpeed = "Full";
454 break;
455 case USBConnectionSpeed_High:
456 pszSpeed = "High";
457 break;
458 case USBConnectionSpeed_Super:
459 pszSpeed = "Super";
460 break;
461 case USBConnectionSpeed_SuperPlus:
462 pszSpeed = "SuperPlus";
463 break;
464 default:
465 ASSERT(false);
466 break;
467 }
468
469 RTPrintf("USB version/speed: %u/%s\n", usVersion, pszSpeed);
470
471 /* optional stuff. */
472 SafeArray<BSTR> CollDevInfo;
473 Bstr bstr;
474 CHECK_ERROR_RET(dev, COMGETTER(DeviceInfo)(ComSafeArrayAsOutParam(CollDevInfo)), 1);
475 if (CollDevInfo.size() >= 1)
476 bstr = Bstr(CollDevInfo[0]);
477 if (!bstr.isEmpty())
478 RTPrintf("Manufacturer: %ls\n", bstr.raw());
479 if (CollDevInfo.size() >= 2)
480 bstr = Bstr(CollDevInfo[1]);
481 if (!bstr.isEmpty())
482 RTPrintf("Product: %ls\n", bstr.raw());
483 CHECK_ERROR_RET(dev, COMGETTER(SerialNumber)(bstr.asOutParam()), 1);
484 if (!bstr.isEmpty())
485 RTPrintf("SerialNumber: %ls\n", bstr.raw());
486 CHECK_ERROR_RET(dev, COMGETTER(Address)(bstr.asOutParam()), 1);
487 if (!bstr.isEmpty())
488 RTPrintf("Address: %ls\n", bstr.raw());
489
490 /* current state */
491 USBDeviceState_T state;
492 CHECK_ERROR_RET(dev, COMGETTER(State)(&state), 1);
493 const char *pszState = "?";
494 switch (state)
495 {
496 case USBDeviceState_NotSupported:
497 pszState = "Not supported";
498 break;
499 case USBDeviceState_Unavailable:
500 pszState = "Unavailable";
501 break;
502 case USBDeviceState_Busy:
503 pszState = "Busy";
504 break;
505 case USBDeviceState_Available:
506 pszState = "Available";
507 break;
508 case USBDeviceState_Held:
509 pszState = "Held";
510 break;
511 case USBDeviceState_Captured:
512 pszState = "Captured";
513 break;
514 default:
515 ASSERT(false);
516 break;
517 }
518 RTPrintf("Current State: %s\n\n", pszState);
519 }
520 }
521 return rc;
522}
523
524
525/**
526 * List USB filters.
527 *
528 * @returns See produceList.
529 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
530 */
531static HRESULT listUsbFilters(const ComPtr<IVirtualBox> &pVirtualBox)
532{
533 HRESULT rc;
534
535 RTPrintf("Global USB Device Filters:\n\n");
536
537 ComPtr<IHost> host;
538 CHECK_ERROR_RET(pVirtualBox, COMGETTER(Host)(host.asOutParam()), 1);
539
540 SafeIfaceArray<IHostUSBDeviceFilter> coll;
541 CHECK_ERROR_RET(host, COMGETTER(USBDeviceFilters)(ComSafeArrayAsOutParam(coll)), 1);
542
543 if (coll.size() == 0)
544 {
545 RTPrintf("<none>\n\n");
546 }
547 else
548 {
549 for (size_t index = 0; index < coll.size(); ++index)
550 {
551 ComPtr<IHostUSBDeviceFilter> flt = coll[index];
552
553 /* Query info. */
554
555 RTPrintf("Index: %zu\n", index);
556
557 BOOL active = FALSE;
558 CHECK_ERROR_RET(flt, COMGETTER(Active)(&active), 1);
559 RTPrintf("Active: %s\n", active ? "yes" : "no");
560
561 USBDeviceFilterAction_T action;
562 CHECK_ERROR_RET(flt, COMGETTER(Action)(&action), 1);
563 const char *pszAction = "<invalid>";
564 switch (action)
565 {
566 case USBDeviceFilterAction_Ignore:
567 pszAction = "Ignore";
568 break;
569 case USBDeviceFilterAction_Hold:
570 pszAction = "Hold";
571 break;
572 default:
573 break;
574 }
575 RTPrintf("Action: %s\n", pszAction);
576
577 Bstr bstr;
578 CHECK_ERROR_RET(flt, COMGETTER(Name)(bstr.asOutParam()), 1);
579 RTPrintf("Name: %ls\n", bstr.raw());
580 CHECK_ERROR_RET(flt, COMGETTER(VendorId)(bstr.asOutParam()), 1);
581 RTPrintf("VendorId: %ls\n", bstr.raw());
582 CHECK_ERROR_RET(flt, COMGETTER(ProductId)(bstr.asOutParam()), 1);
583 RTPrintf("ProductId: %ls\n", bstr.raw());
584 CHECK_ERROR_RET(flt, COMGETTER(Revision)(bstr.asOutParam()), 1);
585 RTPrintf("Revision: %ls\n", bstr.raw());
586 CHECK_ERROR_RET(flt, COMGETTER(Manufacturer)(bstr.asOutParam()), 1);
587 RTPrintf("Manufacturer: %ls\n", bstr.raw());
588 CHECK_ERROR_RET(flt, COMGETTER(Product)(bstr.asOutParam()), 1);
589 RTPrintf("Product: %ls\n", bstr.raw());
590 CHECK_ERROR_RET(flt, COMGETTER(SerialNumber)(bstr.asOutParam()), 1);
591 RTPrintf("Serial Number: %ls\n\n", bstr.raw());
592 }
593 }
594 return rc;
595}
596
597
598/**
599 * List system properties.
600 *
601 * @returns See produceList.
602 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
603 */
604static HRESULT listSystemProperties(const ComPtr<IVirtualBox> &pVirtualBox)
605{
606 ComPtr<ISystemProperties> systemProperties;
607 pVirtualBox->COMGETTER(SystemProperties)(systemProperties.asOutParam());
608
609 Bstr str;
610 ULONG ulValue;
611 LONG64 i64Value;
612 BOOL fValue;
613 const char *psz;
614
615 pVirtualBox->COMGETTER(APIVersion)(str.asOutParam());
616 RTPrintf("API version: %ls\n", str.raw());
617
618 systemProperties->COMGETTER(MinGuestRAM)(&ulValue);
619 RTPrintf("Minimum guest RAM size: %u Megabytes\n", ulValue);
620 systemProperties->COMGETTER(MaxGuestRAM)(&ulValue);
621 RTPrintf("Maximum guest RAM size: %u Megabytes\n", ulValue);
622 systemProperties->COMGETTER(MinGuestVRAM)(&ulValue);
623 RTPrintf("Minimum video RAM size: %u Megabytes\n", ulValue);
624 systemProperties->COMGETTER(MaxGuestVRAM)(&ulValue);
625 RTPrintf("Maximum video RAM size: %u Megabytes\n", ulValue);
626 systemProperties->COMGETTER(MaxGuestMonitors)(&ulValue);
627 RTPrintf("Maximum guest monitor count: %u\n", ulValue);
628 systemProperties->COMGETTER(MinGuestCPUCount)(&ulValue);
629 RTPrintf("Minimum guest CPU count: %u\n", ulValue);
630 systemProperties->COMGETTER(MaxGuestCPUCount)(&ulValue);
631 RTPrintf("Maximum guest CPU count: %u\n", ulValue);
632 systemProperties->COMGETTER(InfoVDSize)(&i64Value);
633 RTPrintf("Virtual disk limit (info): %lld Bytes\n", i64Value);
634 systemProperties->COMGETTER(SerialPortCount)(&ulValue);
635 RTPrintf("Maximum Serial Port count: %u\n", ulValue);
636 systemProperties->COMGETTER(ParallelPortCount)(&ulValue);
637 RTPrintf("Maximum Parallel Port count: %u\n", ulValue);
638 systemProperties->COMGETTER(MaxBootPosition)(&ulValue);
639 RTPrintf("Maximum Boot Position: %u\n", ulValue);
640 systemProperties->GetMaxNetworkAdapters(ChipsetType_PIIX3, &ulValue);
641 RTPrintf("Maximum PIIX3 Network Adapter count: %u\n", ulValue);
642 systemProperties->GetMaxNetworkAdapters(ChipsetType_ICH9, &ulValue);
643 RTPrintf("Maximum ICH9 Network Adapter count: %u\n", ulValue);
644 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_IDE, &ulValue);
645 RTPrintf("Maximum PIIX3 IDE Controllers: %u\n", ulValue);
646 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_IDE, &ulValue);
647 RTPrintf("Maximum ICH9 IDE Controllers: %u\n", ulValue);
648 systemProperties->GetMaxPortCountForStorageBus(StorageBus_IDE, &ulValue);
649 RTPrintf("Maximum IDE Port count: %u\n", ulValue);
650 systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_IDE, &ulValue);
651 RTPrintf("Maximum Devices per IDE Port: %u\n", ulValue);
652 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_SATA, &ulValue);
653 RTPrintf("Maximum PIIX3 SATA Controllers: %u\n", ulValue);
654 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_SATA, &ulValue);
655 RTPrintf("Maximum ICH9 SATA Controllers: %u\n", ulValue);
656 systemProperties->GetMaxPortCountForStorageBus(StorageBus_SATA, &ulValue);
657 RTPrintf("Maximum SATA Port count: %u\n", ulValue);
658 systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_SATA, &ulValue);
659 RTPrintf("Maximum Devices per SATA Port: %u\n", ulValue);
660 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_SCSI, &ulValue);
661 RTPrintf("Maximum PIIX3 SCSI Controllers: %u\n", ulValue);
662 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_SCSI, &ulValue);
663 RTPrintf("Maximum ICH9 SCSI Controllers: %u\n", ulValue);
664 systemProperties->GetMaxPortCountForStorageBus(StorageBus_SCSI, &ulValue);
665 RTPrintf("Maximum SCSI Port count: %u\n", ulValue);
666 systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_SCSI, &ulValue);
667 RTPrintf("Maximum Devices per SCSI Port: %u\n", ulValue);
668 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_SAS, &ulValue);
669 RTPrintf("Maximum SAS PIIX3 Controllers: %u\n", ulValue);
670 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_SAS, &ulValue);
671 RTPrintf("Maximum SAS ICH9 Controllers: %u\n", ulValue);
672 systemProperties->GetMaxPortCountForStorageBus(StorageBus_SAS, &ulValue);
673 RTPrintf("Maximum SAS Port count: %u\n", ulValue);
674 systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_SAS, &ulValue);
675 RTPrintf("Maximum Devices per SAS Port: %u\n", ulValue);
676 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_Floppy, &ulValue);
677 RTPrintf("Maximum PIIX3 Floppy Controllers:%u\n", ulValue);
678 systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_Floppy, &ulValue);
679 RTPrintf("Maximum ICH9 Floppy Controllers: %u\n", ulValue);
680 systemProperties->GetMaxPortCountForStorageBus(StorageBus_Floppy, &ulValue);
681 RTPrintf("Maximum Floppy Port count: %u\n", ulValue);
682 systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_Floppy, &ulValue);
683 RTPrintf("Maximum Devices per Floppy Port: %u\n", ulValue);
684#if 0
685 systemProperties->GetFreeDiskSpaceWarning(&i64Value);
686 RTPrintf("Free disk space warning at: %u Bytes\n", i64Value);
687 systemProperties->GetFreeDiskSpacePercentWarning(&ulValue);
688 RTPrintf("Free disk space warning at: %u %%\n", ulValue);
689 systemProperties->GetFreeDiskSpaceError(&i64Value);
690 RTPrintf("Free disk space error at: %u Bytes\n", i64Value);
691 systemProperties->GetFreeDiskSpacePercentError(&ulValue);
692 RTPrintf("Free disk space error at: %u %%\n", ulValue);
693#endif
694 systemProperties->COMGETTER(DefaultMachineFolder)(str.asOutParam());
695 RTPrintf("Default machine folder: %ls\n", str.raw());
696 systemProperties->COMGETTER(RawModeSupported)(&fValue);
697 RTPrintf("Raw-mode Supported: %s\n", fValue ? "yes" : "no");
698 systemProperties->COMGETTER(ExclusiveHwVirt)(&fValue);
699 RTPrintf("Exclusive HW virtualization use: %s\n", fValue ? "on" : "off");
700 systemProperties->COMGETTER(DefaultHardDiskFormat)(str.asOutParam());
701 RTPrintf("Default hard disk format: %ls\n", str.raw());
702 systemProperties->COMGETTER(VRDEAuthLibrary)(str.asOutParam());
703 RTPrintf("VRDE auth library: %ls\n", str.raw());
704 systemProperties->COMGETTER(WebServiceAuthLibrary)(str.asOutParam());
705 RTPrintf("Webservice auth. library: %ls\n", str.raw());
706 systemProperties->COMGETTER(DefaultVRDEExtPack)(str.asOutParam());
707 RTPrintf("Remote desktop ExtPack: %ls\n", str.raw());
708 systemProperties->COMGETTER(LogHistoryCount)(&ulValue);
709 RTPrintf("Log history count: %u\n", ulValue);
710 systemProperties->COMGETTER(DefaultFrontend)(str.asOutParam());
711 RTPrintf("Default frontend: %ls\n", str.raw());
712 AudioDriverType_T enmAudio;
713 systemProperties->COMGETTER(DefaultAudioDriver)(&enmAudio);
714 switch (enmAudio)
715 {
716 case AudioDriverType_Null: psz = "Null"; break;
717 case AudioDriverType_WinMM: psz = "WinMM"; break;
718 case AudioDriverType_OSS: psz = "OSS"; break;
719 case AudioDriverType_ALSA: psz = "ALSA"; break;
720 case AudioDriverType_DirectSound: psz = "DirectSound"; break;
721 case AudioDriverType_CoreAudio: psz = "CoreAudio"; break;
722 case AudioDriverType_MMPM: psz = "MMPM"; break;
723 case AudioDriverType_Pulse: psz = "Pulse"; break;
724 case AudioDriverType_SolAudio: psz = "SolAudio"; break;
725 default: psz = "Unknown";
726 }
727 RTPrintf("Default audio driver: %s\n", psz);
728 systemProperties->COMGETTER(AutostartDatabasePath)(str.asOutParam());
729 RTPrintf("Autostart database path: %ls\n", str.raw());
730 systemProperties->COMGETTER(DefaultAdditionsISO)(str.asOutParam());
731 RTPrintf("Default Guest Additions ISO: %ls\n", str.raw());
732 systemProperties->COMGETTER(LoggingLevel)(str.asOutParam());
733 RTPrintf("Logging Level: %ls\n", str.raw());
734 return S_OK;
735}
736
737
738/**
739 * List extension packs.
740 *
741 * @returns See produceList.
742 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
743 */
744static HRESULT listExtensionPacks(const ComPtr<IVirtualBox> &pVirtualBox)
745{
746 ComObjPtr<IExtPackManager> ptrExtPackMgr;
747 CHECK_ERROR2I_RET(pVirtualBox, COMGETTER(ExtensionPackManager)(ptrExtPackMgr.asOutParam()), hrcCheck);
748
749 SafeIfaceArray<IExtPack> extPacks;
750 CHECK_ERROR2I_RET(ptrExtPackMgr, COMGETTER(InstalledExtPacks)(ComSafeArrayAsOutParam(extPacks)), hrcCheck);
751 RTPrintf("Extension Packs: %u\n", extPacks.size());
752
753 HRESULT hrc = S_OK;
754 for (size_t i = 0; i < extPacks.size(); i++)
755 {
756 /* Read all the properties. */
757 Bstr bstrName;
758 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Name)(bstrName.asOutParam()), hrc = hrcCheck; bstrName.setNull());
759 Bstr bstrDesc;
760 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Description)(bstrDesc.asOutParam()), hrc = hrcCheck; bstrDesc.setNull());
761 Bstr bstrVersion;
762 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Version)(bstrVersion.asOutParam()), hrc = hrcCheck; bstrVersion.setNull());
763 ULONG uRevision;
764 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Revision)(&uRevision), hrc = hrcCheck; uRevision = 0);
765 Bstr bstrEdition;
766 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Edition)(bstrEdition.asOutParam()), hrc = hrcCheck; bstrEdition.setNull());
767 Bstr bstrVrdeModule;
768 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(VRDEModule)(bstrVrdeModule.asOutParam()),hrc=hrcCheck; bstrVrdeModule.setNull());
769 BOOL fUsable;
770 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Usable)(&fUsable), hrc = hrcCheck; fUsable = FALSE);
771 Bstr bstrWhy;
772 CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(WhyUnusable)(bstrWhy.asOutParam()), hrc = hrcCheck; bstrWhy.setNull());
773
774 /* Display them. */
775 if (i)
776 RTPrintf("\n");
777 RTPrintf("Pack no.%2zu: %ls\n"
778 "Version: %ls\n"
779 "Revision: %u\n"
780 "Edition: %ls\n"
781 "Description: %ls\n"
782 "VRDE Module: %ls\n"
783 "Usable: %RTbool\n"
784 "Why unusable: %ls\n",
785 i, bstrName.raw(),
786 bstrVersion.raw(),
787 uRevision,
788 bstrEdition.raw(),
789 bstrDesc.raw(),
790 bstrVrdeModule.raw(),
791 fUsable != FALSE,
792 bstrWhy.raw());
793
794 /* Query plugins and display them. */
795 }
796 return hrc;
797}
798
799
800/**
801 * List machine groups.
802 *
803 * @returns See produceList.
804 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
805 */
806static HRESULT listGroups(const ComPtr<IVirtualBox> &pVirtualBox)
807{
808 SafeArray<BSTR> groups;
809 CHECK_ERROR2I_RET(pVirtualBox, COMGETTER(MachineGroups)(ComSafeArrayAsOutParam(groups)), hrcCheck);
810
811 for (size_t i = 0; i < groups.size(); i++)
812 {
813 RTPrintf("\"%ls\"\n", groups[i]);
814 }
815 return S_OK;
816}
817
818
819/**
820 * List video capture devices.
821 *
822 * @returns See produceList.
823 * @param pVirtualBox Reference to the IVirtualBox pointer.
824 */
825static HRESULT listVideoInputDevices(const ComPtr<IVirtualBox> pVirtualBox)
826{
827 HRESULT rc;
828 ComPtr<IHost> host;
829 CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam()));
830 com::SafeIfaceArray<IHostVideoInputDevice> hostVideoInputDevices;
831 CHECK_ERROR(host, COMGETTER(VideoInputDevices)(ComSafeArrayAsOutParam(hostVideoInputDevices)));
832 RTPrintf("Video Input Devices: %u\n", hostVideoInputDevices.size());
833 for (size_t i = 0; i < hostVideoInputDevices.size(); ++i)
834 {
835 ComPtr<IHostVideoInputDevice> p = hostVideoInputDevices[i];
836 Bstr name;
837 p->COMGETTER(Name)(name.asOutParam());
838 Bstr path;
839 p->COMGETTER(Path)(path.asOutParam());
840 Bstr alias;
841 p->COMGETTER(Alias)(alias.asOutParam());
842 RTPrintf("%ls \"%ls\"\n%ls\n", alias.raw(), name.raw(), path.raw());
843 }
844 return rc;
845}
846
847/**
848 * List supported screen shot formats.
849 *
850 * @returns See produceList.
851 * @param pVirtualBox Reference to the IVirtualBox pointer.
852 */
853static HRESULT listScreenShotFormats(const ComPtr<IVirtualBox> pVirtualBox)
854{
855 HRESULT rc = S_OK;
856 ComPtr<ISystemProperties> systemProperties;
857 CHECK_ERROR(pVirtualBox, COMGETTER(SystemProperties)(systemProperties.asOutParam()));
858 com::SafeArray<BitmapFormat_T> formats;
859 CHECK_ERROR(systemProperties, COMGETTER(ScreenShotFormats)(ComSafeArrayAsOutParam(formats)));
860
861 RTPrintf("Supported %d screen shot formats:\n", formats.size());
862 for (size_t i = 0; i < formats.size(); ++i)
863 {
864 uint32_t u32Format = (uint32_t)formats[i];
865 char szFormat[5];
866 szFormat[0] = RT_BYTE1(u32Format);
867 szFormat[1] = RT_BYTE2(u32Format);
868 szFormat[2] = RT_BYTE3(u32Format);
869 szFormat[3] = RT_BYTE4(u32Format);
870 szFormat[4] = 0;
871 RTPrintf(" BitmapFormat_%s (0x%08X)\n", szFormat, u32Format);
872 }
873 return rc;
874}
875
876
877/**
878 * The type of lists we can produce.
879 */
880enum enmListType
881{
882 kListNotSpecified = 1000,
883 kListVMs,
884 kListRunningVMs,
885 kListOsTypes,
886 kListHostDvds,
887 kListHostFloppies,
888 kListInternalNetworks,
889 kListBridgedInterfaces,
890#if defined(VBOX_WITH_NETFLT)
891 kListHostOnlyInterfaces,
892#endif
893 kListHostCpuIDs,
894 kListHostInfo,
895 kListHddBackends,
896 kListHdds,
897 kListDvds,
898 kListFloppies,
899 kListUsbHost,
900 kListUsbFilters,
901 kListSystemProperties,
902 kListDhcpServers,
903 kListExtPacks,
904 kListGroups,
905 kListNatNetworks,
906 kListVideoInputDevices,
907 kListScreenShotFormats
908};
909
910
911/**
912 * Produces the specified listing.
913 *
914 * @returns S_OK or some COM error code that has been reported in full.
915 * @param enmList The list to produce.
916 * @param fOptLong Long (@c true) or short list format.
917 * @param pVirtualBox Reference to the IVirtualBox smart pointer.
918 */
919static HRESULT produceList(enum enmListType enmCommand, bool fOptLong, const ComPtr<IVirtualBox> &pVirtualBox)
920{
921 HRESULT rc = S_OK;
922 switch (enmCommand)
923 {
924 case kListNotSpecified:
925 AssertFailed();
926 return E_FAIL;
927
928 case kListVMs:
929 {
930 /*
931 * Get the list of all registered VMs
932 */
933 com::SafeIfaceArray<IMachine> machines;
934 rc = pVirtualBox->COMGETTER(Machines)(ComSafeArrayAsOutParam(machines));
935 if (SUCCEEDED(rc))
936 {
937 /*
938 * Iterate through the collection
939 */
940 for (size_t i = 0; i < machines.size(); ++i)
941 {
942 if (machines[i])
943 rc = showVMInfo(pVirtualBox, machines[i], NULL, fOptLong ? VMINFO_STANDARD : VMINFO_COMPACT);
944 }
945 }
946 break;
947 }
948
949 case kListRunningVMs:
950 {
951 /*
952 * Get the list of all _running_ VMs
953 */
954 com::SafeIfaceArray<IMachine> machines;
955 rc = pVirtualBox->COMGETTER(Machines)(ComSafeArrayAsOutParam(machines));
956 com::SafeArray<MachineState_T> states;
957 if (SUCCEEDED(rc))
958 rc = pVirtualBox->GetMachineStates(ComSafeArrayAsInParam(machines), ComSafeArrayAsOutParam(states));
959 if (SUCCEEDED(rc))
960 {
961 /*
962 * Iterate through the collection
963 */
964 for (size_t i = 0; i < machines.size(); ++i)
965 {
966 if (machines[i])
967 {
968 MachineState_T machineState = states[i];
969 switch (machineState)
970 {
971 case MachineState_Running:
972 case MachineState_Teleporting:
973 case MachineState_LiveSnapshotting:
974 case MachineState_Paused:
975 case MachineState_TeleportingPausedVM:
976 rc = showVMInfo(pVirtualBox, machines[i], NULL, fOptLong ? VMINFO_STANDARD : VMINFO_COMPACT);
977 break;
978 default: break; /* Shut up MSC */
979 }
980 }
981 }
982 }
983 break;
984 }
985
986 case kListOsTypes:
987 {
988 com::SafeIfaceArray<IGuestOSType> coll;
989 rc = pVirtualBox->COMGETTER(GuestOSTypes)(ComSafeArrayAsOutParam(coll));
990 if (SUCCEEDED(rc))
991 {
992 /*
993 * Iterate through the collection.
994 */
995 for (size_t i = 0; i < coll.size(); ++i)
996 {
997 ComPtr<IGuestOSType> guestOS;
998 guestOS = coll[i];
999 Bstr guestId;
1000 guestOS->COMGETTER(Id)(guestId.asOutParam());
1001 RTPrintf("ID: %ls\n", guestId.raw());
1002 Bstr guestDescription;
1003 guestOS->COMGETTER(Description)(guestDescription.asOutParam());
1004 RTPrintf("Description: %ls\n", guestDescription.raw());
1005 Bstr familyId;
1006 guestOS->COMGETTER(FamilyId)(familyId.asOutParam());
1007 RTPrintf("Family ID: %ls\n", familyId.raw());
1008 Bstr familyDescription;
1009 guestOS->COMGETTER(FamilyDescription)(familyDescription.asOutParam());
1010 RTPrintf("Family Desc: %ls\n", familyDescription.raw());
1011 BOOL is64Bit;
1012 guestOS->COMGETTER(Is64Bit)(&is64Bit);
1013 RTPrintf("64 bit: %RTbool\n", is64Bit);
1014 RTPrintf("\n");
1015 }
1016 }
1017 break;
1018 }
1019
1020 case kListHostDvds:
1021 {
1022 ComPtr<IHost> host;
1023 CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam()));
1024 com::SafeIfaceArray<IMedium> coll;
1025 CHECK_ERROR(host, COMGETTER(DVDDrives)(ComSafeArrayAsOutParam(coll)));
1026 if (SUCCEEDED(rc))
1027 {
1028 for (size_t i = 0; i < coll.size(); ++i)
1029 {
1030 ComPtr<IMedium> dvdDrive = coll[i];
1031 Bstr uuid;
1032 dvdDrive->COMGETTER(Id)(uuid.asOutParam());
1033 RTPrintf("UUID: %s\n", Utf8Str(uuid).c_str());
1034 Bstr location;
1035 dvdDrive->COMGETTER(Location)(location.asOutParam());
1036 RTPrintf("Name: %ls\n\n", location.raw());
1037 }
1038 }
1039 break;
1040 }
1041
1042 case kListHostFloppies:
1043 {
1044 ComPtr<IHost> host;
1045 CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam()));
1046 com::SafeIfaceArray<IMedium> coll;
1047 CHECK_ERROR(host, COMGETTER(FloppyDrives)(ComSafeArrayAsOutParam(coll)));
1048 if (SUCCEEDED(rc))
1049 {
1050 for (size_t i = 0; i < coll.size(); ++i)
1051 {
1052 ComPtr<IMedium> floppyDrive = coll[i];
1053 Bstr uuid;
1054 floppyDrive->COMGETTER(Id)(uuid.asOutParam());
1055 RTPrintf("UUID: %s\n", Utf8Str(uuid).c_str());
1056 Bstr location;
1057 floppyDrive->COMGETTER(Location)(location.asOutParam());
1058 RTPrintf("Name: %ls\n\n", location.raw());
1059 }
1060 }
1061 break;
1062 }
1063
1064 case kListInternalNetworks:
1065 rc = listInternalNetworks(pVirtualBox);
1066 break;
1067
1068 case kListBridgedInterfaces:
1069#if defined(VBOX_WITH_NETFLT)
1070 case kListHostOnlyInterfaces:
1071#endif
1072 rc = listNetworkInterfaces(pVirtualBox, enmCommand == kListBridgedInterfaces);
1073 break;
1074
1075 case kListHostInfo:
1076 rc = listHostInfo(pVirtualBox);
1077 break;
1078
1079 case kListHostCpuIDs:
1080 {
1081 ComPtr<IHost> Host;
1082 CHECK_ERROR(pVirtualBox, COMGETTER(Host)(Host.asOutParam()));
1083
1084 RTPrintf("Host CPUIDs:\n\nLeaf no. EAX EBX ECX EDX\n");
1085 ULONG uCpuNo = 0; /* ASSUMES that CPU#0 is online. */
1086 static uint32_t const s_auCpuIdRanges[] =
1087 {
1088 UINT32_C(0x00000000), UINT32_C(0x0000007f),
1089 UINT32_C(0x80000000), UINT32_C(0x8000007f),
1090 UINT32_C(0xc0000000), UINT32_C(0xc000007f)
1091 };
1092 for (unsigned i = 0; i < RT_ELEMENTS(s_auCpuIdRanges); i += 2)
1093 {
1094 ULONG uEAX, uEBX, uECX, uEDX, cLeafs;
1095 CHECK_ERROR(Host, GetProcessorCPUIDLeaf(uCpuNo, s_auCpuIdRanges[i], 0, &cLeafs, &uEBX, &uECX, &uEDX));
1096 if (cLeafs < s_auCpuIdRanges[i] || cLeafs > s_auCpuIdRanges[i+1])
1097 continue;
1098 cLeafs++;
1099 for (ULONG iLeaf = s_auCpuIdRanges[i]; iLeaf <= cLeafs; iLeaf++)
1100 {
1101 CHECK_ERROR(Host, GetProcessorCPUIDLeaf(uCpuNo, iLeaf, 0, &uEAX, &uEBX, &uECX, &uEDX));
1102 RTPrintf("%08x %08x %08x %08x %08x\n", iLeaf, uEAX, uEBX, uECX, uEDX);
1103 }
1104 }
1105 break;
1106 }
1107
1108 case kListHddBackends:
1109 rc = listHddBackends(pVirtualBox);
1110 break;
1111
1112 case kListHdds:
1113 {
1114 com::SafeIfaceArray<IMedium> hdds;
1115 CHECK_ERROR(pVirtualBox, COMGETTER(HardDisks)(ComSafeArrayAsOutParam(hdds)));
1116 rc = listMedia(pVirtualBox, hdds, "base", fOptLong);
1117 break;
1118 }
1119
1120 case kListDvds:
1121 {
1122 com::SafeIfaceArray<IMedium> dvds;
1123 CHECK_ERROR(pVirtualBox, COMGETTER(DVDImages)(ComSafeArrayAsOutParam(dvds)));
1124 rc = listMedia(pVirtualBox, dvds, NULL, fOptLong);
1125 break;
1126 }
1127
1128 case kListFloppies:
1129 {
1130 com::SafeIfaceArray<IMedium> floppies;
1131 CHECK_ERROR(pVirtualBox, COMGETTER(FloppyImages)(ComSafeArrayAsOutParam(floppies)));
1132 rc = listMedia(pVirtualBox, floppies, NULL, fOptLong);
1133 break;
1134 }
1135
1136 case kListUsbHost:
1137 rc = listUsbHost(pVirtualBox);
1138 break;
1139
1140 case kListUsbFilters:
1141 rc = listUsbFilters(pVirtualBox);
1142 break;
1143
1144 case kListSystemProperties:
1145 rc = listSystemProperties(pVirtualBox);
1146 break;
1147
1148 case kListDhcpServers:
1149 {
1150 com::SafeIfaceArray<IDHCPServer> svrs;
1151 CHECK_ERROR(pVirtualBox, COMGETTER(DHCPServers)(ComSafeArrayAsOutParam(svrs)));
1152 for (size_t i = 0; i < svrs.size(); ++i)
1153 {
1154 ComPtr<IDHCPServer> svr = svrs[i];
1155 Bstr netName;
1156 svr->COMGETTER(NetworkName)(netName.asOutParam());
1157 RTPrintf("NetworkName: %ls\n", netName.raw());
1158 Bstr ip;
1159 svr->COMGETTER(IPAddress)(ip.asOutParam());
1160 RTPrintf("IP: %ls\n", ip.raw());
1161 Bstr netmask;
1162 svr->COMGETTER(NetworkMask)(netmask.asOutParam());
1163 RTPrintf("NetworkMask: %ls\n", netmask.raw());
1164 Bstr lowerIp;
1165 svr->COMGETTER(LowerIP)(lowerIp.asOutParam());
1166 RTPrintf("lowerIPAddress: %ls\n", lowerIp.raw());
1167 Bstr upperIp;
1168 svr->COMGETTER(UpperIP)(upperIp.asOutParam());
1169 RTPrintf("upperIPAddress: %ls\n", upperIp.raw());
1170 BOOL fEnabled;
1171 svr->COMGETTER(Enabled)(&fEnabled);
1172 RTPrintf("Enabled: %s\n", fEnabled ? "Yes" : "No");
1173 RTPrintf("\n");
1174 }
1175 break;
1176 }
1177
1178 case kListExtPacks:
1179 rc = listExtensionPacks(pVirtualBox);
1180 break;
1181
1182 case kListGroups:
1183 rc = listGroups(pVirtualBox);
1184 break;
1185
1186 case kListNatNetworks:
1187 {
1188 com::SafeIfaceArray<INATNetwork> nets;
1189 CHECK_ERROR(pVirtualBox, COMGETTER(NATNetworks)(ComSafeArrayAsOutParam(nets)));
1190 for (size_t i = 0; i < nets.size(); ++i)
1191 {
1192 ComPtr<INATNetwork> net = nets[i];
1193 Bstr netName;
1194 net->COMGETTER(NetworkName)(netName.asOutParam());
1195 RTPrintf("NetworkName: %ls\n", netName.raw());
1196 Bstr gateway;
1197 net->COMGETTER(Gateway)(gateway.asOutParam());
1198 RTPrintf("IP: %ls\n", gateway.raw());
1199 Bstr network;
1200 net->COMGETTER(Network)(network.asOutParam());
1201 RTPrintf("Network: %ls\n", network.raw());
1202 BOOL fEnabled;
1203 net->COMGETTER(IPv6Enabled)(&fEnabled);
1204 RTPrintf("IPv6 Enabled: %s\n", fEnabled ? "Yes" : "No");
1205 Bstr ipv6prefix;
1206 net->COMGETTER(IPv6Prefix)(ipv6prefix.asOutParam());
1207 RTPrintf("IPv6 Prefix: %ls\n", ipv6prefix.raw());
1208 net->COMGETTER(NeedDhcpServer)(&fEnabled);
1209 RTPrintf("DHCP Enabled: %s\n", fEnabled ? "Yes" : "No");
1210 net->COMGETTER(Enabled)(&fEnabled);
1211 RTPrintf("Enabled: %s\n", fEnabled ? "Yes" : "No");
1212
1213#define PRINT_STRING_ARRAY(title) \
1214 if (strs.size() > 0) \
1215 { \
1216 RTPrintf(title); \
1217 size_t j = 0; \
1218 for (;j < strs.size(); ++j) \
1219 RTPrintf(" %s\n", Utf8Str(strs[j]).c_str()); \
1220 }
1221
1222 com::SafeArray<BSTR> strs;
1223
1224 CHECK_ERROR(nets[i], COMGETTER(PortForwardRules4)(ComSafeArrayAsOutParam(strs)));
1225 PRINT_STRING_ARRAY("Port-forwarding (ipv4)\n");
1226 strs.setNull();
1227
1228 CHECK_ERROR(nets[i], COMGETTER(PortForwardRules6)(ComSafeArrayAsOutParam(strs)));
1229 PRINT_STRING_ARRAY("Port-forwarding (ipv6)\n");
1230 strs.setNull();
1231
1232 CHECK_ERROR(nets[i], COMGETTER(LocalMappings)(ComSafeArrayAsOutParam(strs)));
1233 PRINT_STRING_ARRAY("loopback mappings (ipv4)\n");
1234 strs.setNull();
1235
1236#undef PRINT_STRING_ARRAY
1237 RTPrintf("\n");
1238 }
1239 break;
1240 }
1241
1242 case kListVideoInputDevices:
1243 rc = listVideoInputDevices(pVirtualBox);
1244 break;
1245
1246 case kListScreenShotFormats:
1247 rc = listScreenShotFormats(pVirtualBox);
1248 break;
1249
1250 /* No default here, want gcc warnings. */
1251
1252 } /* end switch */
1253
1254 return rc;
1255}
1256
1257/**
1258 * Handles the 'list' command.
1259 *
1260 * @returns Appropriate exit code.
1261 * @param a Handler argument.
1262 */
1263RTEXITCODE handleList(HandlerArg *a)
1264{
1265 bool fOptLong = false;
1266 bool fOptMultiple = false;
1267 enum enmListType enmOptCommand = kListNotSpecified;
1268
1269 static const RTGETOPTDEF s_aListOptions[] =
1270 {
1271 { "--long", 'l', RTGETOPT_REQ_NOTHING },
1272 { "--multiple", 'm', RTGETOPT_REQ_NOTHING }, /* not offical yet */
1273 { "vms", kListVMs, RTGETOPT_REQ_NOTHING },
1274 { "runningvms", kListRunningVMs, RTGETOPT_REQ_NOTHING },
1275 { "ostypes", kListOsTypes, RTGETOPT_REQ_NOTHING },
1276 { "hostdvds", kListHostDvds, RTGETOPT_REQ_NOTHING },
1277 { "hostfloppies", kListHostFloppies, RTGETOPT_REQ_NOTHING },
1278 { "intnets", kListInternalNetworks, RTGETOPT_REQ_NOTHING },
1279 { "hostifs", kListBridgedInterfaces, RTGETOPT_REQ_NOTHING }, /* backward compatibility */
1280 { "bridgedifs", kListBridgedInterfaces, RTGETOPT_REQ_NOTHING },
1281#if defined(VBOX_WITH_NETFLT)
1282 { "hostonlyifs", kListHostOnlyInterfaces, RTGETOPT_REQ_NOTHING },
1283#endif
1284 { "natnetworks", kListNatNetworks, RTGETOPT_REQ_NOTHING },
1285 { "natnets", kListNatNetworks, RTGETOPT_REQ_NOTHING },
1286 { "hostinfo", kListHostInfo, RTGETOPT_REQ_NOTHING },
1287 { "hostcpuids", kListHostCpuIDs, RTGETOPT_REQ_NOTHING },
1288 { "hddbackends", kListHddBackends, RTGETOPT_REQ_NOTHING },
1289 { "hdds", kListHdds, RTGETOPT_REQ_NOTHING },
1290 { "dvds", kListDvds, RTGETOPT_REQ_NOTHING },
1291 { "floppies", kListFloppies, RTGETOPT_REQ_NOTHING },
1292 { "usbhost", kListUsbHost, RTGETOPT_REQ_NOTHING },
1293 { "usbfilters", kListUsbFilters, RTGETOPT_REQ_NOTHING },
1294 { "systemproperties", kListSystemProperties, RTGETOPT_REQ_NOTHING },
1295 { "dhcpservers", kListDhcpServers, RTGETOPT_REQ_NOTHING },
1296 { "extpacks", kListExtPacks, RTGETOPT_REQ_NOTHING },
1297 { "groups", kListGroups, RTGETOPT_REQ_NOTHING },
1298 { "webcams", kListVideoInputDevices, RTGETOPT_REQ_NOTHING },
1299 { "screenshotformats", kListScreenShotFormats, RTGETOPT_REQ_NOTHING },
1300 };
1301
1302 int ch;
1303 RTGETOPTUNION ValueUnion;
1304 RTGETOPTSTATE GetState;
1305 RTGetOptInit(&GetState, a->argc, a->argv, s_aListOptions, RT_ELEMENTS(s_aListOptions),
1306 0, RTGETOPTINIT_FLAGS_NO_STD_OPTS);
1307 while ((ch = RTGetOpt(&GetState, &ValueUnion)))
1308 {
1309 switch (ch)
1310 {
1311 case 'l': /* --long */
1312 fOptLong = true;
1313 break;
1314
1315 case 'm':
1316 fOptMultiple = true;
1317 if (enmOptCommand == kListNotSpecified)
1318 break;
1319 ch = enmOptCommand;
1320 /* fall thru */
1321
1322 case kListVMs:
1323 case kListRunningVMs:
1324 case kListOsTypes:
1325 case kListHostDvds:
1326 case kListHostFloppies:
1327 case kListInternalNetworks:
1328 case kListBridgedInterfaces:
1329#if defined(VBOX_WITH_NETFLT)
1330 case kListHostOnlyInterfaces:
1331#endif
1332 case kListHostInfo:
1333 case kListHostCpuIDs:
1334 case kListHddBackends:
1335 case kListHdds:
1336 case kListDvds:
1337 case kListFloppies:
1338 case kListUsbHost:
1339 case kListUsbFilters:
1340 case kListSystemProperties:
1341 case kListDhcpServers:
1342 case kListExtPacks:
1343 case kListGroups:
1344 case kListNatNetworks:
1345 case kListVideoInputDevices:
1346 case kListScreenShotFormats:
1347 enmOptCommand = (enum enmListType)ch;
1348 if (fOptMultiple)
1349 {
1350 HRESULT hrc = produceList((enum enmListType)ch, fOptLong, a->virtualBox);
1351 if (FAILED(hrc))
1352 return RTEXITCODE_FAILURE;
1353 }
1354 break;
1355
1356 case VINF_GETOPT_NOT_OPTION:
1357 return errorSyntax(USAGE_LIST, "Unknown subcommand \"%s\".", ValueUnion.psz);
1358
1359 default:
1360 return errorGetOpt(USAGE_LIST, ch, &ValueUnion);
1361 }
1362 }
1363
1364 /*
1365 * If not in multiple list mode, we have to produce the list now.
1366 */
1367 if (enmOptCommand == kListNotSpecified)
1368 return errorSyntax(USAGE_LIST, "Missing subcommand for \"list\" command.\n");
1369 if (!fOptMultiple)
1370 {
1371 HRESULT hrc = produceList(enmOptCommand, fOptLong, a->virtualBox);
1372 if (FAILED(hrc))
1373 return RTEXITCODE_FAILURE;
1374 }
1375
1376 return RTEXITCODE_SUCCESS;
1377}
1378
1379#endif /* !VBOX_ONLY_DOCS */
1380/* vi: set tabstop=4 shiftwidth=4 expandtab: */
Note: See TracBrowser for help on using the repository browser.

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