/* $Id: VBoxManageList.cpp 85688 2020-08-11 12:37:34Z vboxsync $ */ /** @file * VBoxManage - The 'list' command. */ /* * Copyright (C) 2006-2020 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ #ifndef VBOX_ONLY_DOCS /********************************************************************************************************************************* * Header Files * *********************************************************************************************************************************/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "VBoxManage.h" using namespace com; #ifdef VBOX_WITH_HOSTNETIF_API static const char *getHostIfMediumTypeText(HostNetworkInterfaceMediumType_T enmType) { switch (enmType) { case HostNetworkInterfaceMediumType_Ethernet: return "Ethernet"; case HostNetworkInterfaceMediumType_PPP: return "PPP"; case HostNetworkInterfaceMediumType_SLIP: return "SLIP"; case HostNetworkInterfaceMediumType_Unknown: return "Unknown"; #ifdef VBOX_WITH_XPCOM_CPP_ENUM_HACK case HostNetworkInterfaceMediumType_32BitHack: break; /* Shut up compiler warnings. */ #endif } return "unknown"; } static const char *getHostIfStatusText(HostNetworkInterfaceStatus_T enmStatus) { switch (enmStatus) { case HostNetworkInterfaceStatus_Up: return "Up"; case HostNetworkInterfaceStatus_Down: return "Down"; case HostNetworkInterfaceStatus_Unknown: return "Unknown"; #ifdef VBOX_WITH_XPCOM_CPP_ENUM_HACK case HostNetworkInterfaceStatus_32BitHack: break; /* Shut up compiler warnings. */ #endif } return "unknown"; } #endif /* VBOX_WITH_HOSTNETIF_API */ static const char*getDeviceTypeText(DeviceType_T enmType) { switch (enmType) { case DeviceType_HardDisk: return "HardDisk"; case DeviceType_DVD: return "DVD"; case DeviceType_Floppy: return "Floppy"; /* Make MSC happy */ case DeviceType_Null: return "Null"; case DeviceType_Network: return "Network"; case DeviceType_USB: return "USB"; case DeviceType_SharedFolder: return "SharedFolder"; case DeviceType_Graphics3D: return "Graphics3D"; #ifdef VBOX_WITH_XPCOM_CPP_ENUM_HACK case DeviceType_32BitHack: break; /* Shut up compiler warnings. */ #endif } return "Unknown"; } /** * List internal networks. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listInternalNetworks(const ComPtr pVirtualBox) { HRESULT rc; com::SafeArray internalNetworks; CHECK_ERROR(pVirtualBox, COMGETTER(InternalNetworks)(ComSafeArrayAsOutParam(internalNetworks))); for (size_t i = 0; i < internalNetworks.size(); ++i) { RTPrintf("Name: %ls\n", internalNetworks[i]); } return rc; } /** * List network interfaces information (bridged/host only). * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. * @param fIsBridged Selects between listing host interfaces (for * use with bridging) or host only interfaces. */ static HRESULT listNetworkInterfaces(const ComPtr pVirtualBox, bool fIsBridged) { HRESULT rc; ComPtr host; CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam())); com::SafeIfaceArray hostNetworkInterfaces; #if defined(VBOX_WITH_NETFLT) if (fIsBridged) CHECK_ERROR(host, FindHostNetworkInterfacesOfType(HostNetworkInterfaceType_Bridged, ComSafeArrayAsOutParam(hostNetworkInterfaces))); else CHECK_ERROR(host, FindHostNetworkInterfacesOfType(HostNetworkInterfaceType_HostOnly, ComSafeArrayAsOutParam(hostNetworkInterfaces))); #else RT_NOREF(fIsBridged); CHECK_ERROR(host, COMGETTER(NetworkInterfaces)(ComSafeArrayAsOutParam(hostNetworkInterfaces))); #endif for (size_t i = 0; i < hostNetworkInterfaces.size(); ++i) { ComPtr networkInterface = hostNetworkInterfaces[i]; #ifndef VBOX_WITH_HOSTNETIF_API Bstr interfaceName; networkInterface->COMGETTER(Name)(interfaceName.asOutParam()); RTPrintf("Name: %ls\n", interfaceName.raw()); Guid interfaceGuid; networkInterface->COMGETTER(Id)(interfaceGuid.asOutParam()); RTPrintf("GUID: %ls\n\n", Bstr(interfaceGuid.toString()).raw()); #else /* VBOX_WITH_HOSTNETIF_API */ Bstr interfaceName; networkInterface->COMGETTER(Name)(interfaceName.asOutParam()); RTPrintf("Name: %ls\n", interfaceName.raw()); Bstr interfaceGuid; networkInterface->COMGETTER(Id)(interfaceGuid.asOutParam()); RTPrintf("GUID: %ls\n", interfaceGuid.raw()); BOOL fDHCPEnabled = FALSE; networkInterface->COMGETTER(DHCPEnabled)(&fDHCPEnabled); RTPrintf("DHCP: %s\n", fDHCPEnabled ? "Enabled" : "Disabled"); Bstr IPAddress; networkInterface->COMGETTER(IPAddress)(IPAddress.asOutParam()); RTPrintf("IPAddress: %ls\n", IPAddress.raw()); Bstr NetworkMask; networkInterface->COMGETTER(NetworkMask)(NetworkMask.asOutParam()); RTPrintf("NetworkMask: %ls\n", NetworkMask.raw()); Bstr IPV6Address; networkInterface->COMGETTER(IPV6Address)(IPV6Address.asOutParam()); RTPrintf("IPV6Address: %ls\n", IPV6Address.raw()); ULONG IPV6NetworkMaskPrefixLength; networkInterface->COMGETTER(IPV6NetworkMaskPrefixLength)(&IPV6NetworkMaskPrefixLength); RTPrintf("IPV6NetworkMaskPrefixLength: %d\n", IPV6NetworkMaskPrefixLength); Bstr HardwareAddress; networkInterface->COMGETTER(HardwareAddress)(HardwareAddress.asOutParam()); RTPrintf("HardwareAddress: %ls\n", HardwareAddress.raw()); HostNetworkInterfaceMediumType_T Type; networkInterface->COMGETTER(MediumType)(&Type); RTPrintf("MediumType: %s\n", getHostIfMediumTypeText(Type)); BOOL fWireless = FALSE; networkInterface->COMGETTER(Wireless)(&fWireless); RTPrintf("Wireless: %s\n", fWireless ? "Yes" : "No"); HostNetworkInterfaceStatus_T Status; networkInterface->COMGETTER(Status)(&Status); RTPrintf("Status: %s\n", getHostIfStatusText(Status)); Bstr netName; networkInterface->COMGETTER(NetworkName)(netName.asOutParam()); RTPrintf("VBoxNetworkName: %ls\n\n", netName.raw()); #endif } return rc; } #ifdef VBOX_WITH_CLOUD_NET /** * List configured cloud network attachments. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. * @param Reserved Placeholder! */ static HRESULT listCloudNetworks(const ComPtr pVirtualBox) { HRESULT rc; com::SafeIfaceArray cloudNetworks; CHECK_ERROR(pVirtualBox, COMGETTER(CloudNetworks)(ComSafeArrayAsOutParam(cloudNetworks))); for (size_t i = 0; i < cloudNetworks.size(); ++i) { ComPtr cloudNetwork = cloudNetworks[i]; Bstr networkName; cloudNetwork->COMGETTER(NetworkName)(networkName.asOutParam()); RTPrintf("Name: %ls\n", networkName.raw()); // Guid interfaceGuid; // cloudNetwork->COMGETTER(Id)(interfaceGuid.asOutParam()); // RTPrintf("GUID: %ls\n\n", Bstr(interfaceGuid.toString()).raw()); BOOL fEnabled = FALSE; cloudNetwork->COMGETTER(Enabled)(&fEnabled); RTPrintf("State: %s\n", fEnabled ? "Enabled" : "Disabled"); Bstr Provider; cloudNetwork->COMGETTER(Provider)(Provider.asOutParam()); RTPrintf("CloudProvider: %ls\n", Provider.raw()); Bstr Profile; cloudNetwork->COMGETTER(Profile)(Profile.asOutParam()); RTPrintf("CloudProfile: %ls\n", Profile.raw()); Bstr NetworkId; cloudNetwork->COMGETTER(NetworkId)(NetworkId.asOutParam()); RTPrintf("CloudNetworkId: %ls\n", NetworkId.raw()); Bstr netName = BstrFmt("cloud-%ls", networkName.raw()); RTPrintf("VBoxNetworkName: %ls\n\n", netName.raw()); } return rc; } #endif /* VBOX_WITH_CLOUD_NET */ /** * List host information. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listHostInfo(const ComPtr pVirtualBox) { static struct { ProcessorFeature_T feature; const char *pszName; } features[] = { { ProcessorFeature_HWVirtEx, "HW virtualization" }, { ProcessorFeature_PAE, "PAE" }, { ProcessorFeature_LongMode, "long mode" }, { ProcessorFeature_NestedPaging, "nested paging" }, { ProcessorFeature_UnrestrictedGuest, "unrestricted guest" }, { ProcessorFeature_NestedHWVirt, "nested HW virtualization" }, }; HRESULT rc; ComPtr Host; CHECK_ERROR(pVirtualBox, COMGETTER(Host)(Host.asOutParam())); RTPrintf("Host Information:\n\n"); LONG64 u64UtcTime = 0; CHECK_ERROR(Host, COMGETTER(UTCTime)(&u64UtcTime)); RTTIMESPEC timeSpec; char szTime[32]; RTPrintf("Host time: %s\n", RTTimeSpecToString(RTTimeSpecSetMilli(&timeSpec, u64UtcTime), szTime, sizeof(szTime))); ULONG processorOnlineCount = 0; CHECK_ERROR(Host, COMGETTER(ProcessorOnlineCount)(&processorOnlineCount)); RTPrintf("Processor online count: %lu\n", processorOnlineCount); ULONG processorCount = 0; CHECK_ERROR(Host, COMGETTER(ProcessorCount)(&processorCount)); RTPrintf("Processor count: %lu\n", processorCount); ULONG processorOnlineCoreCount = 0; CHECK_ERROR(Host, COMGETTER(ProcessorOnlineCoreCount)(&processorOnlineCoreCount)); RTPrintf("Processor online core count: %lu\n", processorOnlineCoreCount); ULONG processorCoreCount = 0; CHECK_ERROR(Host, COMGETTER(ProcessorCoreCount)(&processorCoreCount)); RTPrintf("Processor core count: %lu\n", processorCoreCount); for (unsigned i = 0; i < RT_ELEMENTS(features); i++) { BOOL supported; CHECK_ERROR(Host, GetProcessorFeature(features[i].feature, &supported)); RTPrintf("Processor supports %s: %s\n", features[i].pszName, supported ? "yes" : "no"); } for (ULONG i = 0; i < processorCount; i++) { ULONG processorSpeed = 0; CHECK_ERROR(Host, GetProcessorSpeed(i, &processorSpeed)); if (processorSpeed) RTPrintf("Processor#%u speed: %lu MHz\n", i, processorSpeed); else RTPrintf("Processor#%u speed: unknown\n", i); Bstr processorDescription; CHECK_ERROR(Host, GetProcessorDescription(i, processorDescription.asOutParam())); RTPrintf("Processor#%u description: %ls\n", i, processorDescription.raw()); } ULONG memorySize = 0; CHECK_ERROR(Host, COMGETTER(MemorySize)(&memorySize)); RTPrintf("Memory size: %lu MByte\n", memorySize); ULONG memoryAvailable = 0; CHECK_ERROR(Host, COMGETTER(MemoryAvailable)(&memoryAvailable)); RTPrintf("Memory available: %lu MByte\n", memoryAvailable); Bstr operatingSystem; CHECK_ERROR(Host, COMGETTER(OperatingSystem)(operatingSystem.asOutParam())); RTPrintf("Operating system: %ls\n", operatingSystem.raw()); Bstr oSVersion; CHECK_ERROR(Host, COMGETTER(OSVersion)(oSVersion.asOutParam())); RTPrintf("Operating system version: %ls\n", oSVersion.raw()); return rc; } /** * List media information. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. * @param aMedia Medium objects to list information for. * @param pszParentUUIDStr String with the parent UUID string (or "base"). * @param fOptLong Long (@c true) or short list format. */ static HRESULT listMedia(const ComPtr pVirtualBox, const com::SafeIfaceArray &aMedia, const char *pszParentUUIDStr, bool fOptLong) { HRESULT rc = S_OK; for (size_t i = 0; i < aMedia.size(); ++i) { ComPtr pMedium = aMedia[i]; rc = showMediumInfo(pVirtualBox, pMedium, pszParentUUIDStr, fOptLong); RTPrintf("\n"); com::SafeIfaceArray children; CHECK_ERROR(pMedium, COMGETTER(Children)(ComSafeArrayAsOutParam(children))); if (children.size() > 0) { Bstr uuid; pMedium->COMGETTER(Id)(uuid.asOutParam()); // depth first listing of child media rc = listMedia(pVirtualBox, children, Utf8Str(uuid).c_str(), fOptLong); } } return rc; } /** * List virtual image backends. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listHddBackends(const ComPtr pVirtualBox) { HRESULT rc; ComPtr systemProperties; CHECK_ERROR(pVirtualBox, COMGETTER(SystemProperties)(systemProperties.asOutParam())); com::SafeIfaceArray mediumFormats; CHECK_ERROR(systemProperties, COMGETTER(MediumFormats)(ComSafeArrayAsOutParam(mediumFormats))); RTPrintf("Supported hard disk backends:\n\n"); for (size_t i = 0; i < mediumFormats.size(); ++i) { /* General information */ Bstr id; CHECK_ERROR(mediumFormats[i], COMGETTER(Id)(id.asOutParam())); Bstr description; CHECK_ERROR(mediumFormats[i], COMGETTER(Name)(description.asOutParam())); ULONG caps = 0; com::SafeArray mediumFormatCap; CHECK_ERROR(mediumFormats[i], COMGETTER(Capabilities)(ComSafeArrayAsOutParam(mediumFormatCap))); for (ULONG j = 0; j < mediumFormatCap.size(); j++) caps |= mediumFormatCap[j]; RTPrintf("Backend %u: id='%ls' description='%ls' capabilities=%#06x extensions='", i, id.raw(), description.raw(), caps); /* File extensions */ com::SafeArray fileExtensions; com::SafeArray deviceTypes; CHECK_ERROR(mediumFormats[i], DescribeFileExtensions(ComSafeArrayAsOutParam(fileExtensions), ComSafeArrayAsOutParam(deviceTypes))); for (size_t j = 0; j < fileExtensions.size(); ++j) { RTPrintf("%ls (%s)", Bstr(fileExtensions[j]).raw(), getDeviceTypeText(deviceTypes[j])); if (j != fileExtensions.size()-1) RTPrintf(","); } RTPrintf("'"); /* Configuration keys */ com::SafeArray propertyNames; com::SafeArray propertyDescriptions; com::SafeArray propertyTypes; com::SafeArray propertyFlags; com::SafeArray propertyDefaults; CHECK_ERROR(mediumFormats[i], DescribeProperties(ComSafeArrayAsOutParam(propertyNames), ComSafeArrayAsOutParam(propertyDescriptions), ComSafeArrayAsOutParam(propertyTypes), ComSafeArrayAsOutParam(propertyFlags), ComSafeArrayAsOutParam(propertyDefaults))); RTPrintf(" properties=("); if (propertyNames.size() > 0) { for (size_t j = 0; j < propertyNames.size(); ++j) { RTPrintf("\n name='%ls' desc='%ls' type=", Bstr(propertyNames[j]).raw(), Bstr(propertyDescriptions[j]).raw()); switch (propertyTypes[j]) { case DataType_Int32: RTPrintf("int"); break; case DataType_Int8: RTPrintf("byte"); break; case DataType_String: RTPrintf("string"); break; #ifdef VBOX_WITH_XPCOM_CPP_ENUM_HACK case DataType_32BitHack: break; /* Shut up compiler warnings. */ #endif } RTPrintf(" flags=%#04x", propertyFlags[j]); RTPrintf(" default='%ls'", Bstr(propertyDefaults[j]).raw()); if (j != propertyNames.size()-1) RTPrintf(", "); } } RTPrintf(")\n"); } return rc; } /** * List USB devices attached to the host. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listUsbHost(const ComPtr &pVirtualBox) { HRESULT rc; ComPtr Host; CHECK_ERROR_RET(pVirtualBox, COMGETTER(Host)(Host.asOutParam()), 1); SafeIfaceArray CollPtr; CHECK_ERROR_RET(Host, COMGETTER(USBDevices)(ComSafeArrayAsOutParam(CollPtr)), 1); RTPrintf("Host USB Devices:\n\n"); if (CollPtr.size() == 0) { RTPrintf("\n\n"); } else { for (size_t i = 0; i < CollPtr.size(); ++i) { ComPtr dev = CollPtr[i]; /* Query info. */ Bstr id; CHECK_ERROR_RET(dev, COMGETTER(Id)(id.asOutParam()), 1); USHORT usVendorId; CHECK_ERROR_RET(dev, COMGETTER(VendorId)(&usVendorId), 1); USHORT usProductId; CHECK_ERROR_RET(dev, COMGETTER(ProductId)(&usProductId), 1); USHORT bcdRevision; CHECK_ERROR_RET(dev, COMGETTER(Revision)(&bcdRevision), 1); USHORT usPort; CHECK_ERROR_RET(dev, COMGETTER(Port)(&usPort), 1); USHORT usVersion; CHECK_ERROR_RET(dev, COMGETTER(Version)(&usVersion), 1); USBConnectionSpeed_T enmSpeed; CHECK_ERROR_RET(dev, COMGETTER(Speed)(&enmSpeed), 1); RTPrintf("UUID: %s\n" "VendorId: %#06x (%04X)\n" "ProductId: %#06x (%04X)\n" "Revision: %u.%u (%02u%02u)\n" "Port: %u\n", Utf8Str(id).c_str(), usVendorId, usVendorId, usProductId, usProductId, bcdRevision >> 8, bcdRevision & 0xff, bcdRevision >> 8, bcdRevision & 0xff, usPort); const char *pszSpeed = "?"; switch (enmSpeed) { case USBConnectionSpeed_Low: pszSpeed = "Low"; break; case USBConnectionSpeed_Full: pszSpeed = "Full"; break; case USBConnectionSpeed_High: pszSpeed = "High"; break; case USBConnectionSpeed_Super: pszSpeed = "Super"; break; case USBConnectionSpeed_SuperPlus: pszSpeed = "SuperPlus"; break; default: ASSERT(false); break; } RTPrintf("USB version/speed: %u/%s\n", usVersion, pszSpeed); /* optional stuff. */ SafeArray CollDevInfo; Bstr bstr; CHECK_ERROR_RET(dev, COMGETTER(DeviceInfo)(ComSafeArrayAsOutParam(CollDevInfo)), 1); if (CollDevInfo.size() >= 1) bstr = Bstr(CollDevInfo[0]); if (!bstr.isEmpty()) RTPrintf("Manufacturer: %ls\n", bstr.raw()); if (CollDevInfo.size() >= 2) bstr = Bstr(CollDevInfo[1]); if (!bstr.isEmpty()) RTPrintf("Product: %ls\n", bstr.raw()); CHECK_ERROR_RET(dev, COMGETTER(SerialNumber)(bstr.asOutParam()), 1); if (!bstr.isEmpty()) RTPrintf("SerialNumber: %ls\n", bstr.raw()); CHECK_ERROR_RET(dev, COMGETTER(Address)(bstr.asOutParam()), 1); if (!bstr.isEmpty()) RTPrintf("Address: %ls\n", bstr.raw()); CHECK_ERROR_RET(dev, COMGETTER(PortPath)(bstr.asOutParam()), 1); if (!bstr.isEmpty()) RTPrintf("Port path: %ls\n", bstr.raw()); /* current state */ USBDeviceState_T state; CHECK_ERROR_RET(dev, COMGETTER(State)(&state), 1); const char *pszState = "?"; switch (state) { case USBDeviceState_NotSupported: pszState = "Not supported"; break; case USBDeviceState_Unavailable: pszState = "Unavailable"; break; case USBDeviceState_Busy: pszState = "Busy"; break; case USBDeviceState_Available: pszState = "Available"; break; case USBDeviceState_Held: pszState = "Held"; break; case USBDeviceState_Captured: pszState = "Captured"; break; default: ASSERT(false); break; } RTPrintf("Current State: %s\n\n", pszState); } } return rc; } /** * List USB filters. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listUsbFilters(const ComPtr &pVirtualBox) { HRESULT rc; RTPrintf("Global USB Device Filters:\n\n"); ComPtr host; CHECK_ERROR_RET(pVirtualBox, COMGETTER(Host)(host.asOutParam()), 1); SafeIfaceArray coll; CHECK_ERROR_RET(host, COMGETTER(USBDeviceFilters)(ComSafeArrayAsOutParam(coll)), 1); if (coll.size() == 0) { RTPrintf("\n\n"); } else { for (size_t index = 0; index < coll.size(); ++index) { ComPtr flt = coll[index]; /* Query info. */ RTPrintf("Index: %zu\n", index); BOOL active = FALSE; CHECK_ERROR_RET(flt, COMGETTER(Active)(&active), 1); RTPrintf("Active: %s\n", active ? "yes" : "no"); USBDeviceFilterAction_T action; CHECK_ERROR_RET(flt, COMGETTER(Action)(&action), 1); const char *pszAction = ""; switch (action) { case USBDeviceFilterAction_Ignore: pszAction = "Ignore"; break; case USBDeviceFilterAction_Hold: pszAction = "Hold"; break; default: break; } RTPrintf("Action: %s\n", pszAction); Bstr bstr; CHECK_ERROR_RET(flt, COMGETTER(Name)(bstr.asOutParam()), 1); RTPrintf("Name: %ls\n", bstr.raw()); CHECK_ERROR_RET(flt, COMGETTER(VendorId)(bstr.asOutParam()), 1); RTPrintf("VendorId: %ls\n", bstr.raw()); CHECK_ERROR_RET(flt, COMGETTER(ProductId)(bstr.asOutParam()), 1); RTPrintf("ProductId: %ls\n", bstr.raw()); CHECK_ERROR_RET(flt, COMGETTER(Revision)(bstr.asOutParam()), 1); RTPrintf("Revision: %ls\n", bstr.raw()); CHECK_ERROR_RET(flt, COMGETTER(Manufacturer)(bstr.asOutParam()), 1); RTPrintf("Manufacturer: %ls\n", bstr.raw()); CHECK_ERROR_RET(flt, COMGETTER(Product)(bstr.asOutParam()), 1); RTPrintf("Product: %ls\n", bstr.raw()); CHECK_ERROR_RET(flt, COMGETTER(SerialNumber)(bstr.asOutParam()), 1); RTPrintf("Serial Number: %ls\n\n", bstr.raw()); } } return rc; } /** * List system properties. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listSystemProperties(const ComPtr &pVirtualBox) { ComPtr systemProperties; CHECK_ERROR2I_RET(pVirtualBox, COMGETTER(SystemProperties)(systemProperties.asOutParam()), hrcCheck); Bstr str; ULONG ulValue; LONG64 i64Value; BOOL fValue; const char *psz; pVirtualBox->COMGETTER(APIVersion)(str.asOutParam()); RTPrintf("API version: %ls\n", str.raw()); systemProperties->COMGETTER(MinGuestRAM)(&ulValue); RTPrintf("Minimum guest RAM size: %u Megabytes\n", ulValue); systemProperties->COMGETTER(MaxGuestRAM)(&ulValue); RTPrintf("Maximum guest RAM size: %u Megabytes\n", ulValue); systemProperties->COMGETTER(MinGuestVRAM)(&ulValue); RTPrintf("Minimum video RAM size: %u Megabytes\n", ulValue); systemProperties->COMGETTER(MaxGuestVRAM)(&ulValue); RTPrintf("Maximum video RAM size: %u Megabytes\n", ulValue); systemProperties->COMGETTER(MaxGuestMonitors)(&ulValue); RTPrintf("Maximum guest monitor count: %u\n", ulValue); systemProperties->COMGETTER(MinGuestCPUCount)(&ulValue); RTPrintf("Minimum guest CPU count: %u\n", ulValue); systemProperties->COMGETTER(MaxGuestCPUCount)(&ulValue); RTPrintf("Maximum guest CPU count: %u\n", ulValue); systemProperties->COMGETTER(InfoVDSize)(&i64Value); RTPrintf("Virtual disk limit (info): %lld Bytes\n", i64Value); systemProperties->COMGETTER(SerialPortCount)(&ulValue); RTPrintf("Maximum Serial Port count: %u\n", ulValue); systemProperties->COMGETTER(ParallelPortCount)(&ulValue); RTPrintf("Maximum Parallel Port count: %u\n", ulValue); systemProperties->COMGETTER(MaxBootPosition)(&ulValue); RTPrintf("Maximum Boot Position: %u\n", ulValue); systemProperties->GetMaxNetworkAdapters(ChipsetType_PIIX3, &ulValue); RTPrintf("Maximum PIIX3 Network Adapter count: %u\n", ulValue); systemProperties->GetMaxNetworkAdapters(ChipsetType_ICH9, &ulValue); RTPrintf("Maximum ICH9 Network Adapter count: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_IDE, &ulValue); RTPrintf("Maximum PIIX3 IDE Controllers: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_IDE, &ulValue); RTPrintf("Maximum ICH9 IDE Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_IDE, &ulValue); RTPrintf("Maximum IDE Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_IDE, &ulValue); RTPrintf("Maximum Devices per IDE Port: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_SATA, &ulValue); RTPrintf("Maximum PIIX3 SATA Controllers: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_SATA, &ulValue); RTPrintf("Maximum ICH9 SATA Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_SATA, &ulValue); RTPrintf("Maximum SATA Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_SATA, &ulValue); RTPrintf("Maximum Devices per SATA Port: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_SCSI, &ulValue); RTPrintf("Maximum PIIX3 SCSI Controllers: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_SCSI, &ulValue); RTPrintf("Maximum ICH9 SCSI Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_SCSI, &ulValue); RTPrintf("Maximum SCSI Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_SCSI, &ulValue); RTPrintf("Maximum Devices per SCSI Port: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_SAS, &ulValue); RTPrintf("Maximum SAS PIIX3 Controllers: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_SAS, &ulValue); RTPrintf("Maximum SAS ICH9 Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_SAS, &ulValue); RTPrintf("Maximum SAS Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_SAS, &ulValue); RTPrintf("Maximum Devices per SAS Port: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_PCIe, &ulValue); RTPrintf("Maximum NVMe PIIX3 Controllers: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_PCIe, &ulValue); RTPrintf("Maximum NVMe ICH9 Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_PCIe, &ulValue); RTPrintf("Maximum NVMe Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_PCIe, &ulValue); RTPrintf("Maximum Devices per NVMe Port: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_VirtioSCSI, &ulValue); RTPrintf("Maximum virtio-scsi PIIX3 Controllers: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_VirtioSCSI, &ulValue); RTPrintf("Maximum virtio-scsi ICH9 Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_VirtioSCSI, &ulValue); RTPrintf("Maximum virtio-scsi Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_VirtioSCSI, &ulValue); RTPrintf("Maximum Devices per virtio-scsi Port: %u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_PIIX3, StorageBus_Floppy, &ulValue); RTPrintf("Maximum PIIX3 Floppy Controllers:%u\n", ulValue); systemProperties->GetMaxInstancesOfStorageBus(ChipsetType_ICH9, StorageBus_Floppy, &ulValue); RTPrintf("Maximum ICH9 Floppy Controllers: %u\n", ulValue); systemProperties->GetMaxPortCountForStorageBus(StorageBus_Floppy, &ulValue); RTPrintf("Maximum Floppy Port count: %u\n", ulValue); systemProperties->GetMaxDevicesPerPortForStorageBus(StorageBus_Floppy, &ulValue); RTPrintf("Maximum Devices per Floppy Port: %u\n", ulValue); #if 0 systemProperties->GetFreeDiskSpaceWarning(&i64Value); RTPrintf("Free disk space warning at: %u Bytes\n", i64Value); systemProperties->GetFreeDiskSpacePercentWarning(&ulValue); RTPrintf("Free disk space warning at: %u %%\n", ulValue); systemProperties->GetFreeDiskSpaceError(&i64Value); RTPrintf("Free disk space error at: %u Bytes\n", i64Value); systemProperties->GetFreeDiskSpacePercentError(&ulValue); RTPrintf("Free disk space error at: %u %%\n", ulValue); #endif systemProperties->COMGETTER(DefaultMachineFolder)(str.asOutParam()); RTPrintf("Default machine folder: %ls\n", str.raw()); systemProperties->COMGETTER(RawModeSupported)(&fValue); RTPrintf("Raw-mode Supported: %s\n", fValue ? "yes" : "no"); systemProperties->COMGETTER(ExclusiveHwVirt)(&fValue); RTPrintf("Exclusive HW virtualization use: %s\n", fValue ? "on" : "off"); systemProperties->COMGETTER(DefaultHardDiskFormat)(str.asOutParam()); RTPrintf("Default hard disk format: %ls\n", str.raw()); systemProperties->COMGETTER(VRDEAuthLibrary)(str.asOutParam()); RTPrintf("VRDE auth library: %ls\n", str.raw()); systemProperties->COMGETTER(WebServiceAuthLibrary)(str.asOutParam()); RTPrintf("Webservice auth. library: %ls\n", str.raw()); systemProperties->COMGETTER(DefaultVRDEExtPack)(str.asOutParam()); RTPrintf("Remote desktop ExtPack: %ls\n", str.raw()); systemProperties->COMGETTER(LogHistoryCount)(&ulValue); RTPrintf("Log history count: %u\n", ulValue); systemProperties->COMGETTER(DefaultFrontend)(str.asOutParam()); RTPrintf("Default frontend: %ls\n", str.raw()); AudioDriverType_T enmAudio; systemProperties->COMGETTER(DefaultAudioDriver)(&enmAudio); switch (enmAudio) { case AudioDriverType_Null: psz = "Null"; break; case AudioDriverType_WinMM: psz = "WinMM"; break; case AudioDriverType_OSS: psz = "OSS"; break; case AudioDriverType_ALSA: psz = "ALSA"; break; case AudioDriverType_DirectSound: psz = "DirectSound"; break; case AudioDriverType_CoreAudio: psz = "CoreAudio"; break; case AudioDriverType_MMPM: psz = "MMPM"; break; case AudioDriverType_Pulse: psz = "Pulse"; break; case AudioDriverType_SolAudio: psz = "SolAudio"; break; default: psz = "Unknown"; } RTPrintf("Default audio driver: %s\n", psz); systemProperties->COMGETTER(AutostartDatabasePath)(str.asOutParam()); RTPrintf("Autostart database path: %ls\n", str.raw()); systemProperties->COMGETTER(DefaultAdditionsISO)(str.asOutParam()); RTPrintf("Default Guest Additions ISO: %ls\n", str.raw()); systemProperties->COMGETTER(LoggingLevel)(str.asOutParam()); RTPrintf("Logging Level: %ls\n", str.raw()); ProxyMode_T enmProxyMode = (ProxyMode_T)42; systemProperties->COMGETTER(ProxyMode)(&enmProxyMode); psz = "Unknown"; switch (enmProxyMode) { case ProxyMode_System: psz = "System"; break; case ProxyMode_NoProxy: psz = "NoProxy"; break; case ProxyMode_Manual: psz = "Manual"; break; #ifdef VBOX_WITH_XPCOM_CPP_ENUM_HACK case ProxyMode_32BitHack: break; /* Shut up compiler warnings. */ #endif } RTPrintf("Proxy Mode: %s\n", psz); systemProperties->COMGETTER(ProxyURL)(str.asOutParam()); RTPrintf("Proxy URL: %ls\n", str.raw()); systemProperties->COMGETTER(VBoxUpdateEnabled)(&fValue); RTPrintf("Update check enabled: %s\n", fValue ? "yes" : "no"); systemProperties->COMGETTER(VBoxUpdateCount)(&ulValue); RTPrintf("Update check count: %u\n", ulValue); systemProperties->COMGETTER(VBoxUpdateFrequency)(&ulValue); if (ulValue == 0) RTPrintf("Update check frequency: never\n"); else if (ulValue == 1) RTPrintf("Update check frequency: every day\n"); else RTPrintf("Update check frequency: every %u days\n", ulValue); VBoxUpdateTarget_T enmVBoxUpdateTarget; systemProperties->COMGETTER(VBoxUpdateTarget)(&enmVBoxUpdateTarget); switch (enmVBoxUpdateTarget) { case VBoxUpdateTarget_Stable: psz = "Stable: new minor and maintenance releases"; break; case VBoxUpdateTarget_AllReleases: psz = "All releases: new minor, maintenance, and major releases"; break; case VBoxUpdateTarget_WithBetas: psz = "With Betas: new minor, maintenance, major, and beta releases"; break; default: psz = "Unset"; break; } RTPrintf("Update check target: %s\n", psz); systemProperties->COMGETTER(VBoxUpdateLastCheckDate)(str.asOutParam()); RTPrintf("Last check date: %ls\n", str.raw()); return S_OK; } /** * Helper for listDhcpServers() that shows a DHCP configuration. */ static HRESULT showDhcpConfig(ComPtr ptrConfig) { HRESULT hrcRet = S_OK; ULONG secs = 0; CHECK_ERROR2I_STMT(ptrConfig, COMGETTER(MinLeaseTime)(&secs), hrcRet = hrcCheck); if (secs == 0) RTPrintf(" minLeaseTime: default\n"); else RTPrintf(" minLeaseTime: %u sec\n", secs); secs = 0; CHECK_ERROR2I_STMT(ptrConfig, COMGETTER(DefaultLeaseTime)(&secs), hrcRet = hrcCheck); if (secs == 0) RTPrintf(" defaultLeaseTime: default\n"); else RTPrintf(" defaultLeaseTime: %u sec\n", secs); secs = 0; CHECK_ERROR2I_STMT(ptrConfig, COMGETTER(MaxLeaseTime)(&secs), hrcRet = hrcCheck); if (secs == 0) RTPrintf(" maxLeaseTime: default\n"); else RTPrintf(" maxLeaseTime: %u sec\n", secs); com::SafeArray Options; HRESULT hrc; CHECK_ERROR2_STMT(hrc, ptrConfig, COMGETTER(ForcedOptions(ComSafeArrayAsOutParam(Options))), hrcRet = hrc); if (FAILED(hrc)) RTPrintf(" Forced options: %Rhrc\n", hrc); else if (Options.size() == 0) RTPrintf(" Forced options: None\n"); else { RTPrintf(" Forced options: "); for (size_t i = 0; i < Options.size(); i++) RTPrintf(i ? ", %u" : "%u", Options[i]); RTPrintf("\n"); } CHECK_ERROR2_STMT(hrc, ptrConfig, COMGETTER(SuppressedOptions(ComSafeArrayAsOutParam(Options))), hrcRet = hrc); if (FAILED(hrc)) RTPrintf(" Suppressed opt.s: %Rhrc\n", hrc); else if (Options.size() == 0) RTPrintf(" Suppressed opts.: None\n"); else { RTPrintf(" Suppressed opts.: "); for (size_t i = 0; i < Options.size(); i++) RTPrintf(i ? ", %u" : "%u", Options[i]); RTPrintf("\n"); } com::SafeArray Encodings; com::SafeArray Values; CHECK_ERROR2_STMT(hrc, ptrConfig, GetAllOptions(ComSafeArrayAsOutParam(Options), ComSafeArrayAsOutParam(Encodings), ComSafeArrayAsOutParam(Values)), hrcRet = hrc); if (FAILED(hrc)) RTPrintf(" DHCP options: %Rhrc\n", hrc); else if (Options.size() != Encodings.size() || Options.size() != Values.size()) { RTPrintf(" DHCP options: Return count mismatch: %zu, %zu, %zu\n", Options.size(), Encodings.size(), Values.size()); hrcRet = E_FAIL; } else if (Options.size() == 0) RTPrintf(" DHCP options: None\n"); else for (size_t i = 0; i < Options.size(); i++) { switch (Encodings[i]) { case DHCPOptionEncoding_Normal: RTPrintf(" %3d/legacy: %ls\n", Options[i], Values[i]); break; case DHCPOptionEncoding_Hex: RTPrintf(" %3d/hex: %ls\n", Options[i], Values[i]); break; default: RTPrintf(" %3d/%u?: %ls\n", Options[i], Encodings[i], Values[i]); break; } } return S_OK; } /** * List DHCP servers. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listDhcpServers(const ComPtr &pVirtualBox) { HRESULT hrcRet = S_OK; com::SafeIfaceArray DHCPServers; CHECK_ERROR2I_RET(pVirtualBox, COMGETTER(DHCPServers)(ComSafeArrayAsOutParam(DHCPServers)), hrcCheck); for (size_t i = 0; i < DHCPServers.size(); ++i) { if (i > 0) RTPrintf("\n"); ComPtr ptrDHCPServer = DHCPServers[i]; Bstr bstr; CHECK_ERROR2I_STMT(ptrDHCPServer, COMGETTER(NetworkName)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("NetworkName: %ls\n", bstr.raw()); CHECK_ERROR2I_STMT(ptrDHCPServer, COMGETTER(IPAddress)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("Dhcpd IP: %ls\n", bstr.raw()); CHECK_ERROR2I_STMT(ptrDHCPServer, COMGETTER(LowerIP)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("LowerIPAddress: %ls\n", bstr.raw()); CHECK_ERROR2I_STMT(ptrDHCPServer, COMGETTER(UpperIP)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("UpperIPAddress: %ls\n", bstr.raw()); CHECK_ERROR2I_STMT(ptrDHCPServer, COMGETTER(NetworkMask)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("NetworkMask: %ls\n", bstr.raw()); BOOL fEnabled = FALSE; CHECK_ERROR2I_STMT(ptrDHCPServer, COMGETTER(Enabled)(&fEnabled), hrcRet = hrcCheck); RTPrintf("Enabled: %s\n", fEnabled ? "Yes" : "No"); /* Global configuration: */ RTPrintf("Global Configuration:\n"); HRESULT hrc; ComPtr ptrGlobal; CHECK_ERROR2_STMT(hrc, ptrDHCPServer, COMGETTER(GlobalConfig)(ptrGlobal.asOutParam()), hrcRet = hrc); if (SUCCEEDED(hrc)) { hrc = showDhcpConfig(ptrGlobal); if (FAILED(hrc)) hrcRet = hrc; } /* Group configurations: */ com::SafeIfaceArray Groups; CHECK_ERROR2_STMT(hrc, ptrDHCPServer, COMGETTER(GroupConfigs)(ComSafeArrayAsOutParam(Groups)), hrcRet = hrc); if (FAILED(hrc)) RTPrintf("Groups: %Rrc\n", hrc); else if (Groups.size() == 0) RTPrintf("Groups: None\n"); else { for (size_t iGrp = 0; iGrp < Groups.size(); iGrp++) { CHECK_ERROR2I_STMT(Groups[iGrp], COMGETTER(Name)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("Group: %ls\n", bstr.raw()); com::SafeIfaceArray Conditions; CHECK_ERROR2_STMT(hrc, Groups[iGrp], COMGETTER(Conditions)(ComSafeArrayAsOutParam(Conditions)), hrcRet = hrc); if (FAILED(hrc)) RTPrintf(" Conditions: %Rhrc\n", hrc); else if (Conditions.size() == 0) RTPrintf(" Conditions: None\n"); else for (size_t iCond = 0; iCond < Conditions.size(); iCond++) { BOOL fInclusive = TRUE; CHECK_ERROR2_STMT(hrc, Conditions[iCond], COMGETTER(Inclusive)(&fInclusive), hrcRet = hrc); DHCPGroupConditionType_T enmType = DHCPGroupConditionType_MAC; CHECK_ERROR2_STMT(hrc, Conditions[iCond], COMGETTER(Type)(&enmType), hrcRet = hrc); CHECK_ERROR2_STMT(hrc, Conditions[iCond], COMGETTER(Value)(bstr.asOutParam()), hrcRet = hrc); RTPrintf(" Conditions: %s %s %ls\n", fInclusive ? "include" : "exclude", enmType == DHCPGroupConditionType_MAC ? "MAC " : enmType == DHCPGroupConditionType_MACWildcard ? "MAC* " : enmType == DHCPGroupConditionType_vendorClassID ? "VendorCID " : enmType == DHCPGroupConditionType_vendorClassIDWildcard ? "VendorCID*" : enmType == DHCPGroupConditionType_userClassID ? "UserCID " : enmType == DHCPGroupConditionType_userClassIDWildcard ? "UserCID* " : "!UNKNOWN! ", bstr.raw()); } hrc = showDhcpConfig(Groups[iGrp]); if (FAILED(hrc)) hrcRet = hrc; } Groups.setNull(); } /* Individual host / NIC configurations: */ com::SafeIfaceArray Hosts; CHECK_ERROR2_STMT(hrc, ptrDHCPServer, COMGETTER(IndividualConfigs)(ComSafeArrayAsOutParam(Hosts)), hrcRet = hrc); if (FAILED(hrc)) RTPrintf("Individual Configs: %Rrc\n", hrc); else if (Hosts.size() == 0) RTPrintf("Individual Configs: None\n"); else { for (size_t iHost = 0; iHost < Hosts.size(); iHost++) { DHCPConfigScope_T enmScope = DHCPConfigScope_MAC; CHECK_ERROR2I_STMT(Hosts[iHost], COMGETTER(Scope)(&enmScope), hrcRet = hrcCheck); if (enmScope == DHCPConfigScope_MAC) { CHECK_ERROR2I_STMT(Hosts[iHost], COMGETTER(MACAddress)(bstr.asOutParam()), hrcRet = hrcCheck); RTPrintf("Individual Config: MAC %ls\n", bstr.raw()); } else { ULONG uSlot = 0; CHECK_ERROR2I_STMT(Hosts[iHost], COMGETTER(Slot)(&uSlot), hrcRet = hrcCheck); CHECK_ERROR2I_STMT(Hosts[iHost], COMGETTER(MachineId)(bstr.asOutParam()), hrcRet = hrcCheck); Bstr bstrMACAddress; hrc = Hosts[iHost]->COMGETTER(MACAddress)(bstrMACAddress.asOutParam()); /* No CHECK_ERROR2 stuff! */ if (SUCCEEDED(hrc)) RTPrintf("Individual Config: VM NIC: %ls slot %u, MAC %ls\n", bstr.raw(), uSlot, bstrMACAddress.raw()); else RTPrintf("Individual Config: VM NIC: %ls slot %u, MAC %Rhrc\n", bstr.raw(), uSlot, hrc); } CHECK_ERROR2I_STMT(Hosts[iHost], COMGETTER(FixedAddress)(bstr.asOutParam()), hrcRet = hrcCheck); if (bstr.isNotEmpty()) RTPrintf(" Fixed Address: %ls\n", bstr.raw()); else RTPrintf(" Fixed Address: dynamic\n"); hrc = showDhcpConfig(Hosts[iHost]); if (FAILED(hrc)) hrcRet = hrc; } Hosts.setNull(); } } return hrcRet; } /** * List extension packs. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listExtensionPacks(const ComPtr &pVirtualBox) { ComObjPtr ptrExtPackMgr; CHECK_ERROR2I_RET(pVirtualBox, COMGETTER(ExtensionPackManager)(ptrExtPackMgr.asOutParam()), hrcCheck); SafeIfaceArray extPacks; CHECK_ERROR2I_RET(ptrExtPackMgr, COMGETTER(InstalledExtPacks)(ComSafeArrayAsOutParam(extPacks)), hrcCheck); RTPrintf("Extension Packs: %u\n", extPacks.size()); HRESULT hrc = S_OK; for (size_t i = 0; i < extPacks.size(); i++) { /* Read all the properties. */ Bstr bstrName; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Name)(bstrName.asOutParam()), hrc = hrcCheck; bstrName.setNull()); Bstr bstrDesc; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Description)(bstrDesc.asOutParam()), hrc = hrcCheck; bstrDesc.setNull()); Bstr bstrVersion; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Version)(bstrVersion.asOutParam()), hrc = hrcCheck; bstrVersion.setNull()); ULONG uRevision; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Revision)(&uRevision), hrc = hrcCheck; uRevision = 0); Bstr bstrEdition; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Edition)(bstrEdition.asOutParam()), hrc = hrcCheck; bstrEdition.setNull()); Bstr bstrVrdeModule; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(VRDEModule)(bstrVrdeModule.asOutParam()),hrc=hrcCheck; bstrVrdeModule.setNull()); BOOL fUsable; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(Usable)(&fUsable), hrc = hrcCheck; fUsable = FALSE); Bstr bstrWhy; CHECK_ERROR2I_STMT(extPacks[i], COMGETTER(WhyUnusable)(bstrWhy.asOutParam()), hrc = hrcCheck; bstrWhy.setNull()); /* Display them. */ if (i) RTPrintf("\n"); RTPrintf("Pack no.%2zu: %ls\n" "Version: %ls\n" "Revision: %u\n" "Edition: %ls\n" "Description: %ls\n" "VRDE Module: %ls\n" "Usable: %RTbool\n" "Why unusable: %ls\n", i, bstrName.raw(), bstrVersion.raw(), uRevision, bstrEdition.raw(), bstrDesc.raw(), bstrVrdeModule.raw(), fUsable != FALSE, bstrWhy.raw()); /* Query plugins and display them. */ } return hrc; } /** * List machine groups. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT listGroups(const ComPtr &pVirtualBox) { SafeArray groups; CHECK_ERROR2I_RET(pVirtualBox, COMGETTER(MachineGroups)(ComSafeArrayAsOutParam(groups)), hrcCheck); for (size_t i = 0; i < groups.size(); i++) { RTPrintf("\"%ls\"\n", groups[i]); } return S_OK; } /** * List video capture devices. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox pointer. */ static HRESULT listVideoInputDevices(const ComPtr &pVirtualBox) { HRESULT rc; ComPtr host; CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam())); com::SafeIfaceArray hostVideoInputDevices; CHECK_ERROR(host, COMGETTER(VideoInputDevices)(ComSafeArrayAsOutParam(hostVideoInputDevices))); RTPrintf("Video Input Devices: %u\n", hostVideoInputDevices.size()); for (size_t i = 0; i < hostVideoInputDevices.size(); ++i) { ComPtr p = hostVideoInputDevices[i]; Bstr name; p->COMGETTER(Name)(name.asOutParam()); Bstr path; p->COMGETTER(Path)(path.asOutParam()); Bstr alias; p->COMGETTER(Alias)(alias.asOutParam()); RTPrintf("%ls \"%ls\"\n%ls\n", alias.raw(), name.raw(), path.raw()); } return rc; } /** * List supported screen shot formats. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox pointer. */ static HRESULT listScreenShotFormats(const ComPtr &pVirtualBox) { HRESULT rc = S_OK; ComPtr systemProperties; CHECK_ERROR(pVirtualBox, COMGETTER(SystemProperties)(systemProperties.asOutParam())); com::SafeArray formats; CHECK_ERROR(systemProperties, COMGETTER(ScreenShotFormats)(ComSafeArrayAsOutParam(formats))); RTPrintf("Supported %d screen shot formats:\n", formats.size()); for (size_t i = 0; i < formats.size(); ++i) { uint32_t u32Format = (uint32_t)formats[i]; char szFormat[5]; szFormat[0] = RT_BYTE1(u32Format); szFormat[1] = RT_BYTE2(u32Format); szFormat[2] = RT_BYTE3(u32Format); szFormat[3] = RT_BYTE4(u32Format); szFormat[4] = 0; RTPrintf(" BitmapFormat_%s (0x%08X)\n", szFormat, u32Format); } return rc; } /** * List available cloud providers. * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox pointer. */ static HRESULT listCloudProviders(const ComPtr &pVirtualBox) { HRESULT rc = S_OK; ComPtr pCloudProviderManager; CHECK_ERROR(pVirtualBox, COMGETTER(CloudProviderManager)(pCloudProviderManager.asOutParam())); com::SafeIfaceArray apCloudProviders; CHECK_ERROR(pCloudProviderManager, COMGETTER(Providers)(ComSafeArrayAsOutParam(apCloudProviders))); RTPrintf("Supported %d cloud providers:\n", apCloudProviders.size()); for (size_t i = 0; i < apCloudProviders.size(); ++i) { ComPtr pCloudProvider = apCloudProviders[i]; Bstr bstrProviderName; pCloudProvider->COMGETTER(Name)(bstrProviderName.asOutParam()); RTPrintf("Name: %ls\n", bstrProviderName.raw()); pCloudProvider->COMGETTER(ShortName)(bstrProviderName.asOutParam()); RTPrintf("Short Name: %ls\n", bstrProviderName.raw()); Bstr bstrProviderID; pCloudProvider->COMGETTER(Id)(bstrProviderID.asOutParam()); RTPrintf("GUID: %ls\n", bstrProviderID.raw()); RTPrintf("\n"); } return rc; } /** * List all available cloud profiles (by iterating over the cloud providers). * * @returns See produceList. * @param pVirtualBox Reference to the IVirtualBox pointer. * @param fOptLong If true, list all profile properties. */ static HRESULT listCloudProfiles(const ComPtr &pVirtualBox, bool fOptLong) { HRESULT rc = S_OK; ComPtr pCloudProviderManager; CHECK_ERROR(pVirtualBox, COMGETTER(CloudProviderManager)(pCloudProviderManager.asOutParam())); com::SafeIfaceArray apCloudProviders; CHECK_ERROR(pCloudProviderManager, COMGETTER(Providers)(ComSafeArrayAsOutParam(apCloudProviders))); for (size_t i = 0; i < apCloudProviders.size(); ++i) { ComPtr pCloudProvider = apCloudProviders[i]; com::SafeIfaceArray apCloudProfiles; CHECK_ERROR(pCloudProvider, COMGETTER(Profiles)(ComSafeArrayAsOutParam(apCloudProfiles))); for (size_t j = 0; j < apCloudProfiles.size(); ++j) { ComPtr pCloudProfile = apCloudProfiles[j]; Bstr bstrProfileName; pCloudProfile->COMGETTER(Name)(bstrProfileName.asOutParam()); RTPrintf("Name: %ls\n", bstrProfileName.raw()); Bstr bstrProviderID; pCloudProfile->COMGETTER(ProviderId)(bstrProviderID.asOutParam()); RTPrintf("Provider GUID: %ls\n", bstrProviderID.raw()); if (fOptLong) { com::SafeArray names; com::SafeArray values; pCloudProfile->GetProperties(Bstr().raw(), ComSafeArrayAsOutParam(names), ComSafeArrayAsOutParam(values)); size_t cNames = names.size(); size_t cValues = values.size(); bool fFirst = true; for (size_t k = 0; k < cNames; k++) { Bstr value; if (k < cValues) value = values[k]; RTPrintf("%s%ls=%ls\n", fFirst ? "Property: " : " ", names[k], value.raw()); fFirst = false; } } RTPrintf("\n"); } } return rc; } static HRESULT displayCPUProfile(ICPUProfile *pProfile, size_t idx, int cchIdx, bool fOptLong, HRESULT hrc) { /* Retrieve the attributes needed for both long and short display. */ Bstr bstrName; CHECK_ERROR2I_RET(pProfile, COMGETTER(Name)(bstrName.asOutParam()), hrcCheck); CPUArchitecture_T enmArchitecture = CPUArchitecture_Any; CHECK_ERROR2I_RET(pProfile, COMGETTER(Architecture)(&enmArchitecture), hrcCheck); const char *pszArchitecture = "???"; switch (enmArchitecture) { case CPUArchitecture_x86: pszArchitecture = "x86"; break; case CPUArchitecture_AMD64: pszArchitecture = "AMD64"; break; #ifdef VBOX_WITH_XPCOM_CPP_ENUM_HACK case CPUArchitecture_32BitHack: #endif case CPUArchitecture_Any: break; } /* Print what we've got. */ if (!fOptLong) RTPrintf("#%0*zu: %ls [%s]\n", cchIdx, idx, bstrName.raw(), pszArchitecture); else { RTPrintf("CPU Profile #%02zu:\n", idx); RTPrintf(" Architecture: %s\n", pszArchitecture); RTPrintf(" Name: %ls\n", bstrName.raw()); CHECK_ERROR2I_RET(pProfile, COMGETTER(FullName)(bstrName.asOutParam()), hrcCheck); RTPrintf(" Full Name: %ls\n", bstrName.raw()); } return hrc; } /** * List all CPU profiles. * * @returns See produceList. * @param ptrVirtualBox Reference to the smart IVirtualBox pointer. * @param fOptLong If true, list all profile properties. * @param fOptSorted Sort the output if true, otherwise display in * system order. */ static HRESULT listCPUProfiles(const ComPtr &ptrVirtualBox, bool fOptLong, bool fOptSorted) { ComPtr ptrSysProps; CHECK_ERROR2I_RET(ptrVirtualBox, COMGETTER(SystemProperties)(ptrSysProps.asOutParam()), hrcCheck); com::SafeIfaceArray aCPUProfiles; CHECK_ERROR2I_RET(ptrSysProps, GetCPUProfiles(CPUArchitecture_Any, Bstr().raw(), ComSafeArrayAsOutParam(aCPUProfiles)), hrcCheck); int const cchIdx = 1 + (aCPUProfiles.size() >= 10) + (aCPUProfiles.size() >= 100); HRESULT hrc = S_OK; if (!fOptSorted) for (size_t i = 0; i < aCPUProfiles.size(); i++) hrc = displayCPUProfile(aCPUProfiles[i], i, cchIdx, fOptLong, hrc); else { std::vector > vecSortedProfiles; for (size_t i = 0; i < aCPUProfiles.size(); ++i) { Bstr bstrName; CHECK_ERROR2I_RET(aCPUProfiles[i], COMGETTER(Name)(bstrName.asOutParam()), hrcCheck); try { vecSortedProfiles.push_back(std::pair(bstrName, aCPUProfiles[i])); } catch (std::bad_alloc &) { return E_OUTOFMEMORY; } } std::sort(vecSortedProfiles.begin(), vecSortedProfiles.end()); for (size_t i = 0; i < vecSortedProfiles.size(); i++) hrc = displayCPUProfile(vecSortedProfiles[i].second, i, cchIdx, fOptLong, hrc); } return hrc; } /** * The type of lists we can produce. */ enum ListType_T { kListNotSpecified = 1000, kListVMs, kListRunningVMs, kListOsTypes, kListHostDvds, kListHostFloppies, kListInternalNetworks, kListBridgedInterfaces, #if defined(VBOX_WITH_NETFLT) kListHostOnlyInterfaces, #endif #if defined(VBOX_WITH_CLOUD_NET) kListCloudNetworks, #endif kListHostCpuIDs, kListHostInfo, kListHddBackends, kListHdds, kListDvds, kListFloppies, kListUsbHost, kListUsbFilters, kListSystemProperties, kListDhcpServers, kListExtPacks, kListGroups, kListNatNetworks, kListVideoInputDevices, kListScreenShotFormats, kListCloudProviders, kListCloudProfiles, kListCPUProfiles }; /** * Produces the specified listing. * * @returns S_OK or some COM error code that has been reported in full. * @param enmList The list to produce. * @param fOptLong Long (@c true) or short list format. * @param pVirtualBox Reference to the IVirtualBox smart pointer. */ static HRESULT produceList(enum ListType_T enmCommand, bool fOptLong, bool fOptSorted, const ComPtr &pVirtualBox) { HRESULT rc = S_OK; switch (enmCommand) { case kListNotSpecified: AssertFailed(); return E_FAIL; case kListVMs: { /* * Get the list of all registered VMs */ com::SafeIfaceArray machines; rc = pVirtualBox->COMGETTER(Machines)(ComSafeArrayAsOutParam(machines)); if (SUCCEEDED(rc)) { /* * Display it. */ if (!fOptSorted) { for (size_t i = 0; i < machines.size(); ++i) if (machines[i]) rc = showVMInfo(pVirtualBox, machines[i], NULL, fOptLong ? VMINFO_STANDARD : VMINFO_COMPACT); } else { /* * Sort the list by name before displaying it. */ std::vector > sortedMachines; for (size_t i = 0; i < machines.size(); ++i) { IMachine *pMachine = machines[i]; if (pMachine) /* no idea why we need to do this... */ { Bstr bstrName; pMachine->COMGETTER(Name)(bstrName.asOutParam()); sortedMachines.push_back(std::pair(bstrName, pMachine)); } } std::sort(sortedMachines.begin(), sortedMachines.end()); for (size_t i = 0; i < sortedMachines.size(); ++i) rc = showVMInfo(pVirtualBox, sortedMachines[i].second, NULL, fOptLong ? VMINFO_STANDARD : VMINFO_COMPACT); } } break; } case kListRunningVMs: { /* * Get the list of all _running_ VMs */ com::SafeIfaceArray machines; rc = pVirtualBox->COMGETTER(Machines)(ComSafeArrayAsOutParam(machines)); com::SafeArray states; if (SUCCEEDED(rc)) rc = pVirtualBox->GetMachineStates(ComSafeArrayAsInParam(machines), ComSafeArrayAsOutParam(states)); if (SUCCEEDED(rc)) { /* * Iterate through the collection */ for (size_t i = 0; i < machines.size(); ++i) { if (machines[i]) { MachineState_T machineState = states[i]; switch (machineState) { case MachineState_Running: case MachineState_Teleporting: case MachineState_LiveSnapshotting: case MachineState_Paused: case MachineState_TeleportingPausedVM: rc = showVMInfo(pVirtualBox, machines[i], NULL, fOptLong ? VMINFO_STANDARD : VMINFO_COMPACT); break; default: break; /* Shut up MSC */ } } } } break; } case kListOsTypes: { com::SafeIfaceArray coll; rc = pVirtualBox->COMGETTER(GuestOSTypes)(ComSafeArrayAsOutParam(coll)); if (SUCCEEDED(rc)) { /* * Iterate through the collection. */ for (size_t i = 0; i < coll.size(); ++i) { ComPtr guestOS; guestOS = coll[i]; Bstr guestId; guestOS->COMGETTER(Id)(guestId.asOutParam()); RTPrintf("ID: %ls\n", guestId.raw()); Bstr guestDescription; guestOS->COMGETTER(Description)(guestDescription.asOutParam()); RTPrintf("Description: %ls\n", guestDescription.raw()); Bstr familyId; guestOS->COMGETTER(FamilyId)(familyId.asOutParam()); RTPrintf("Family ID: %ls\n", familyId.raw()); Bstr familyDescription; guestOS->COMGETTER(FamilyDescription)(familyDescription.asOutParam()); RTPrintf("Family Desc: %ls\n", familyDescription.raw()); BOOL is64Bit; guestOS->COMGETTER(Is64Bit)(&is64Bit); RTPrintf("64 bit: %RTbool\n", is64Bit); RTPrintf("\n"); } } break; } case kListHostDvds: { ComPtr host; CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam())); com::SafeIfaceArray coll; CHECK_ERROR(host, COMGETTER(DVDDrives)(ComSafeArrayAsOutParam(coll))); if (SUCCEEDED(rc)) { for (size_t i = 0; i < coll.size(); ++i) { ComPtr dvdDrive = coll[i]; Bstr uuid; dvdDrive->COMGETTER(Id)(uuid.asOutParam()); RTPrintf("UUID: %s\n", Utf8Str(uuid).c_str()); Bstr location; dvdDrive->COMGETTER(Location)(location.asOutParam()); RTPrintf("Name: %ls\n\n", location.raw()); } } break; } case kListHostFloppies: { ComPtr host; CHECK_ERROR(pVirtualBox, COMGETTER(Host)(host.asOutParam())); com::SafeIfaceArray coll; CHECK_ERROR(host, COMGETTER(FloppyDrives)(ComSafeArrayAsOutParam(coll))); if (SUCCEEDED(rc)) { for (size_t i = 0; i < coll.size(); ++i) { ComPtr floppyDrive = coll[i]; Bstr uuid; floppyDrive->COMGETTER(Id)(uuid.asOutParam()); RTPrintf("UUID: %s\n", Utf8Str(uuid).c_str()); Bstr location; floppyDrive->COMGETTER(Location)(location.asOutParam()); RTPrintf("Name: %ls\n\n", location.raw()); } } break; } case kListInternalNetworks: rc = listInternalNetworks(pVirtualBox); break; case kListBridgedInterfaces: #if defined(VBOX_WITH_NETFLT) case kListHostOnlyInterfaces: #endif rc = listNetworkInterfaces(pVirtualBox, enmCommand == kListBridgedInterfaces); break; #if defined(VBOX_WITH_CLOUD_NET) case kListCloudNetworks: rc = listCloudNetworks(pVirtualBox); break; #endif case kListHostInfo: rc = listHostInfo(pVirtualBox); break; case kListHostCpuIDs: { ComPtr Host; CHECK_ERROR(pVirtualBox, COMGETTER(Host)(Host.asOutParam())); RTPrintf("Host CPUIDs:\n\nLeaf no. EAX EBX ECX EDX\n"); ULONG uCpuNo = 0; /* ASSUMES that CPU#0 is online. */ static uint32_t const s_auCpuIdRanges[] = { UINT32_C(0x00000000), UINT32_C(0x0000007f), UINT32_C(0x80000000), UINT32_C(0x8000007f), UINT32_C(0xc0000000), UINT32_C(0xc000007f) }; for (unsigned i = 0; i < RT_ELEMENTS(s_auCpuIdRanges); i += 2) { ULONG uEAX, uEBX, uECX, uEDX, cLeafs; CHECK_ERROR(Host, GetProcessorCPUIDLeaf(uCpuNo, s_auCpuIdRanges[i], 0, &cLeafs, &uEBX, &uECX, &uEDX)); if (cLeafs < s_auCpuIdRanges[i] || cLeafs > s_auCpuIdRanges[i+1]) continue; cLeafs++; for (ULONG iLeaf = s_auCpuIdRanges[i]; iLeaf <= cLeafs; iLeaf++) { CHECK_ERROR(Host, GetProcessorCPUIDLeaf(uCpuNo, iLeaf, 0, &uEAX, &uEBX, &uECX, &uEDX)); RTPrintf("%08x %08x %08x %08x %08x\n", iLeaf, uEAX, uEBX, uECX, uEDX); } } break; } case kListHddBackends: rc = listHddBackends(pVirtualBox); break; case kListHdds: { com::SafeIfaceArray hdds; CHECK_ERROR(pVirtualBox, COMGETTER(HardDisks)(ComSafeArrayAsOutParam(hdds))); rc = listMedia(pVirtualBox, hdds, "base", fOptLong); break; } case kListDvds: { com::SafeIfaceArray dvds; CHECK_ERROR(pVirtualBox, COMGETTER(DVDImages)(ComSafeArrayAsOutParam(dvds))); rc = listMedia(pVirtualBox, dvds, NULL, fOptLong); break; } case kListFloppies: { com::SafeIfaceArray floppies; CHECK_ERROR(pVirtualBox, COMGETTER(FloppyImages)(ComSafeArrayAsOutParam(floppies))); rc = listMedia(pVirtualBox, floppies, NULL, fOptLong); break; } case kListUsbHost: rc = listUsbHost(pVirtualBox); break; case kListUsbFilters: rc = listUsbFilters(pVirtualBox); break; case kListSystemProperties: rc = listSystemProperties(pVirtualBox); break; case kListDhcpServers: rc = listDhcpServers(pVirtualBox); break; case kListExtPacks: rc = listExtensionPacks(pVirtualBox); break; case kListGroups: rc = listGroups(pVirtualBox); break; case kListNatNetworks: { com::SafeIfaceArray nets; CHECK_ERROR(pVirtualBox, COMGETTER(NATNetworks)(ComSafeArrayAsOutParam(nets))); for (size_t i = 0; i < nets.size(); ++i) { ComPtr net = nets[i]; Bstr netName; net->COMGETTER(NetworkName)(netName.asOutParam()); RTPrintf("NetworkName: %ls\n", netName.raw()); Bstr gateway; net->COMGETTER(Gateway)(gateway.asOutParam()); RTPrintf("IP: %ls\n", gateway.raw()); Bstr network; net->COMGETTER(Network)(network.asOutParam()); RTPrintf("Network: %ls\n", network.raw()); BOOL fEnabled; net->COMGETTER(IPv6Enabled)(&fEnabled); RTPrintf("IPv6 Enabled: %s\n", fEnabled ? "Yes" : "No"); Bstr ipv6prefix; net->COMGETTER(IPv6Prefix)(ipv6prefix.asOutParam()); RTPrintf("IPv6 Prefix: %ls\n", ipv6prefix.raw()); net->COMGETTER(NeedDhcpServer)(&fEnabled); RTPrintf("DHCP Enabled: %s\n", fEnabled ? "Yes" : "No"); net->COMGETTER(Enabled)(&fEnabled); RTPrintf("Enabled: %s\n", fEnabled ? "Yes" : "No"); #define PRINT_STRING_ARRAY(title) \ if (strs.size() > 0) \ { \ RTPrintf(title); \ size_t j = 0; \ for (;j < strs.size(); ++j) \ RTPrintf(" %s\n", Utf8Str(strs[j]).c_str()); \ } com::SafeArray strs; CHECK_ERROR(nets[i], COMGETTER(PortForwardRules4)(ComSafeArrayAsOutParam(strs))); PRINT_STRING_ARRAY("Port-forwarding (ipv4)\n"); strs.setNull(); CHECK_ERROR(nets[i], COMGETTER(PortForwardRules6)(ComSafeArrayAsOutParam(strs))); PRINT_STRING_ARRAY("Port-forwarding (ipv6)\n"); strs.setNull(); CHECK_ERROR(nets[i], COMGETTER(LocalMappings)(ComSafeArrayAsOutParam(strs))); PRINT_STRING_ARRAY("loopback mappings (ipv4)\n"); strs.setNull(); #undef PRINT_STRING_ARRAY RTPrintf("\n"); } break; } case kListVideoInputDevices: rc = listVideoInputDevices(pVirtualBox); break; case kListScreenShotFormats: rc = listScreenShotFormats(pVirtualBox); break; case kListCloudProviders: rc = listCloudProviders(pVirtualBox); break; case kListCloudProfiles: rc = listCloudProfiles(pVirtualBox, fOptLong); break; case kListCPUProfiles: rc = listCPUProfiles(pVirtualBox, fOptLong, fOptSorted); break; /* No default here, want gcc warnings. */ } /* end switch */ return rc; } /** * Handles the 'list' command. * * @returns Appropriate exit code. * @param a Handler argument. */ RTEXITCODE handleList(HandlerArg *a) { bool fOptLong = false; bool fOptMultiple = false; bool fOptSorted = false; enum ListType_T enmOptCommand = kListNotSpecified; static const RTGETOPTDEF s_aListOptions[] = { { "--long", 'l', RTGETOPT_REQ_NOTHING }, { "--multiple", 'm', RTGETOPT_REQ_NOTHING }, /* not offical yet */ { "--sorted", 's', RTGETOPT_REQ_NOTHING }, { "vms", kListVMs, RTGETOPT_REQ_NOTHING }, { "runningvms", kListRunningVMs, RTGETOPT_REQ_NOTHING }, { "ostypes", kListOsTypes, RTGETOPT_REQ_NOTHING }, { "hostdvds", kListHostDvds, RTGETOPT_REQ_NOTHING }, { "hostfloppies", kListHostFloppies, RTGETOPT_REQ_NOTHING }, { "intnets", kListInternalNetworks, RTGETOPT_REQ_NOTHING }, { "hostifs", kListBridgedInterfaces, RTGETOPT_REQ_NOTHING }, /* backward compatibility */ { "bridgedifs", kListBridgedInterfaces, RTGETOPT_REQ_NOTHING }, #if defined(VBOX_WITH_NETFLT) { "hostonlyifs", kListHostOnlyInterfaces, RTGETOPT_REQ_NOTHING }, #endif #if defined(VBOX_WITH_CLOUD_NET) { "cloudnets", kListCloudNetworks, RTGETOPT_REQ_NOTHING }, #endif { "natnetworks", kListNatNetworks, RTGETOPT_REQ_NOTHING }, { "natnets", kListNatNetworks, RTGETOPT_REQ_NOTHING }, { "hostinfo", kListHostInfo, RTGETOPT_REQ_NOTHING }, { "hostcpuids", kListHostCpuIDs, RTGETOPT_REQ_NOTHING }, { "hddbackends", kListHddBackends, RTGETOPT_REQ_NOTHING }, { "hdds", kListHdds, RTGETOPT_REQ_NOTHING }, { "dvds", kListDvds, RTGETOPT_REQ_NOTHING }, { "floppies", kListFloppies, RTGETOPT_REQ_NOTHING }, { "usbhost", kListUsbHost, RTGETOPT_REQ_NOTHING }, { "usbfilters", kListUsbFilters, RTGETOPT_REQ_NOTHING }, { "systemproperties", kListSystemProperties, RTGETOPT_REQ_NOTHING }, { "dhcpservers", kListDhcpServers, RTGETOPT_REQ_NOTHING }, { "extpacks", kListExtPacks, RTGETOPT_REQ_NOTHING }, { "groups", kListGroups, RTGETOPT_REQ_NOTHING }, { "webcams", kListVideoInputDevices, RTGETOPT_REQ_NOTHING }, { "screenshotformats", kListScreenShotFormats, RTGETOPT_REQ_NOTHING }, { "cloudproviders", kListCloudProviders, RTGETOPT_REQ_NOTHING }, { "cloudprofiles", kListCloudProfiles, RTGETOPT_REQ_NOTHING }, { "cpu-profiles", kListCPUProfiles, RTGETOPT_REQ_NOTHING }, }; int ch; RTGETOPTUNION ValueUnion; RTGETOPTSTATE GetState; RTGetOptInit(&GetState, a->argc, a->argv, s_aListOptions, RT_ELEMENTS(s_aListOptions), 0, RTGETOPTINIT_FLAGS_NO_STD_OPTS); while ((ch = RTGetOpt(&GetState, &ValueUnion))) { switch (ch) { case 'l': /* --long */ fOptLong = true; break; case 's': fOptSorted = true; break; case 'm': fOptMultiple = true; if (enmOptCommand == kListNotSpecified) break; ch = enmOptCommand; RT_FALL_THRU(); case kListVMs: case kListRunningVMs: case kListOsTypes: case kListHostDvds: case kListHostFloppies: case kListInternalNetworks: case kListBridgedInterfaces: #if defined(VBOX_WITH_NETFLT) case kListHostOnlyInterfaces: #endif #if defined(VBOX_WITH_CLOUD_NET) case kListCloudNetworks: #endif case kListHostInfo: case kListHostCpuIDs: case kListHddBackends: case kListHdds: case kListDvds: case kListFloppies: case kListUsbHost: case kListUsbFilters: case kListSystemProperties: case kListDhcpServers: case kListExtPacks: case kListGroups: case kListNatNetworks: case kListVideoInputDevices: case kListScreenShotFormats: case kListCloudProviders: case kListCloudProfiles: case kListCPUProfiles: enmOptCommand = (enum ListType_T)ch; if (fOptMultiple) { HRESULT hrc = produceList(enmOptCommand, fOptLong, fOptSorted, a->virtualBox); if (FAILED(hrc)) return RTEXITCODE_FAILURE; } break; case VINF_GETOPT_NOT_OPTION: return errorSyntax(USAGE_LIST, "Unknown subcommand \"%s\".", ValueUnion.psz); default: return errorGetOpt(USAGE_LIST, ch, &ValueUnion); } } /* * If not in multiple list mode, we have to produce the list now. */ if (enmOptCommand == kListNotSpecified) return errorSyntax(USAGE_LIST, "Missing subcommand for \"list\" command.\n"); if (!fOptMultiple) { HRESULT hrc = produceList(enmOptCommand, fOptLong, fOptSorted, a->virtualBox); if (FAILED(hrc)) return RTEXITCODE_FAILURE; } return RTEXITCODE_SUCCESS; } #endif /* !VBOX_ONLY_DOCS */ /* vi: set tabstop=4 shiftwidth=4 expandtab: */