VirtualBox

source: vbox/trunk/include/VBox/settings.h@ 85007

Last change on this file since 85007 was 82968, checked in by vboxsync, 5 years ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Revision Author Id
File size: 45.2 KB
Line 
1/** @file
2 * Settings file data structures.
3 *
4 * These structures are created by the settings file loader and filled with values
5 * copied from the raw XML data. This was all new with VirtualBox 3.1 and allows us
6 * to finally make the XML reader version-independent and read VirtualBox XML files
7 * from earlier and even newer (future) versions without requiring complicated,
8 * tedious and error-prone XSLT conversions.
9 *
10 * It is this file that defines all structures that map VirtualBox global and
11 * machine settings to XML files. These structures are used by the rest of Main,
12 * even though this header file does not require anything else in Main.
13 *
14 * Note: Headers in Main code have been tweaked to only declare the structures
15 * defined here so that this header need only be included from code files that
16 * actually use these structures.
17 */
18
19/*
20 * Copyright (C) 2007-2020 Oracle Corporation
21 *
22 * This file is part of VirtualBox Open Source Edition (OSE), as
23 * available from http://www.virtualbox.org. This file is free software;
24 * you can redistribute it and/or modify it under the terms of the GNU
25 * General Public License (GPL) as published by the Free Software
26 * Foundation, in version 2 as it comes in the "COPYING" file of the
27 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
28 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
29 *
30 * The contents of this file may alternatively be used under the terms
31 * of the Common Development and Distribution License Version 1.0
32 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
33 * VirtualBox OSE distribution, in which case the provisions of the
34 * CDDL are applicable instead of those of the GPL.
35 *
36 * You may elect to license modified versions of this file under the
37 * terms and conditions of either the GPL or the CDDL or both.
38 */
39
40#ifndef VBOX_INCLUDED_settings_h
41#define VBOX_INCLUDED_settings_h
42#ifndef RT_WITHOUT_PRAGMA_ONCE
43# pragma once
44#endif
45
46#include <iprt/time.h>
47
48#include "VBox/com/VirtualBox.h"
49
50#include <VBox/com/Guid.h>
51#include <VBox/com/string.h>
52
53#include <list>
54#include <map>
55#include <vector>
56
57/**
58 * Maximum depth of a medium tree, to prevent stack overflows.
59 * XPCOM has a relatively low stack size for its workers, and we have
60 * to avoid crashes due to exceeding the limit both on reading and
61 * writing config files.
62 */
63#define SETTINGS_MEDIUM_DEPTH_MAX 300
64
65/**
66 * Maximum depth of the snapshot tree, to prevent stack overflows.
67 * XPCOM has a relatively low stack size for its workers, and we have
68 * to avoid crashes due to exceeding the limit both on reading and
69 * writing config files. The bottleneck is reading config files with
70 * deep snapshot nesting, as libxml2 needs quite some stack space,
71 * so with the current stack size the margin isn't big.
72 */
73#define SETTINGS_SNAPSHOT_DEPTH_MAX 250
74
75namespace xml
76{
77 class ElementNode;
78}
79
80namespace settings
81{
82
83class ConfigFileError;
84
85////////////////////////////////////////////////////////////////////////////////
86//
87// Structures shared between Machine XML and VirtualBox.xml
88//
89////////////////////////////////////////////////////////////////////////////////
90
91typedef std::map<com::Utf8Str, com::Utf8Str> StringsMap;
92typedef std::list<com::Utf8Str> StringsList;
93
94/**
95 * USB device filter definition. This struct is used both in MainConfigFile
96 * (for global USB filters) and MachineConfigFile (for machine filters).
97 *
98 * NOTE: If you add any fields in here, you must update a) the constructor and b)
99 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
100 * your settings might never get saved.
101 */
102struct USBDeviceFilter
103{
104 USBDeviceFilter();
105
106 bool operator==(const USBDeviceFilter&u) const;
107
108 com::Utf8Str strName;
109 bool fActive;
110 com::Utf8Str strVendorId,
111 strProductId,
112 strRevision,
113 strManufacturer,
114 strProduct,
115 strSerialNumber,
116 strPort;
117 USBDeviceFilterAction_T action; // only used with host USB filters
118 com::Utf8Str strRemote; // irrelevant for host USB objects
119 uint32_t ulMaskedInterfaces; // irrelevant for host USB objects
120};
121
122typedef std::list<USBDeviceFilter> USBDeviceFiltersList;
123
124struct Medium;
125typedef std::list<Medium> MediaList;
126
127/**
128 * NOTE: If you add any fields in here, you must update a) the constructor and b)
129 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
130 * your settings might never get saved.
131 */
132struct Medium
133{
134 Medium();
135
136 bool operator==(const Medium &m) const;
137
138 com::Guid uuid;
139 com::Utf8Str strLocation;
140 com::Utf8Str strDescription;
141
142 // the following are for hard disks only:
143 com::Utf8Str strFormat;
144 bool fAutoReset; // optional, only for diffs, default is false
145 StringsMap properties;
146 MediumType_T hdType;
147
148 MediaList llChildren; // only used with hard disks
149
150 static const struct Medium Empty;
151};
152
153/**
154 * A media registry. Starting with VirtualBox 3.3, this can appear in both the
155 * VirtualBox.xml file as well as machine XML files with settings version 1.11
156 * or higher, so these lists are now in ConfigFileBase.
157 *
158 * NOTE: If you add any fields in here, you must update a) the constructor and b)
159 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
160 * your settings might never get saved.
161 */
162struct MediaRegistry
163{
164 bool operator==(const MediaRegistry &m) const;
165
166 MediaList llHardDisks,
167 llDvdImages,
168 llFloppyImages;
169};
170
171/**
172 * NOTE: If you add any fields in here, you must update a) the constructor and b)
173 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
174 * your settings might never get saved.
175 */
176struct NATRule
177{
178 NATRule();
179
180 bool operator==(const NATRule &r) const;
181
182 com::Utf8Str strName;
183 NATProtocol_T proto;
184 uint16_t u16HostPort;
185 com::Utf8Str strHostIP;
186 uint16_t u16GuestPort;
187 com::Utf8Str strGuestIP;
188};
189typedef std::map<com::Utf8Str, NATRule> NATRulesMap;
190
191struct NATHostLoopbackOffset
192{
193 NATHostLoopbackOffset();
194
195 bool operator==(const NATHostLoopbackOffset &o) const;
196
197 bool operator==(const com::Utf8Str& strAddr)
198 {
199 return strLoopbackHostAddress == strAddr;
200 }
201
202 bool operator==(uint32_t off)
203 {
204 return u32Offset == off;
205 }
206
207 /** Note: 128/8 is only acceptable */
208 com::Utf8Str strLoopbackHostAddress;
209 uint32_t u32Offset;
210};
211
212typedef std::list<NATHostLoopbackOffset> NATLoopbackOffsetList;
213
214typedef std::vector<uint8_t> IconBlob;
215
216/**
217 * Common base class for both MainConfigFile and MachineConfigFile
218 * which contains some common logic for both.
219 */
220class ConfigFileBase
221{
222public:
223 bool fileExists();
224
225 void copyBaseFrom(const ConfigFileBase &b);
226
227protected:
228 ConfigFileBase(const com::Utf8Str *pstrFilename);
229 /* Note: this copy constructor doesn't create a full copy of other, cause
230 * the file based stuff (xml doc) could not be copied. */
231 ConfigFileBase(const ConfigFileBase &other);
232
233 ~ConfigFileBase();
234
235 typedef enum {Error, HardDisk, DVDImage, FloppyImage} MediaType;
236
237 static const char *stringifyMediaType(MediaType t);
238 SettingsVersion_T parseVersion(const com::Utf8Str &strVersion,
239 const xml::ElementNode *pElm);
240 void parseUUID(com::Guid &guid,
241 const com::Utf8Str &strUUID,
242 const xml::ElementNode *pElm) const;
243 void parseTimestamp(RTTIMESPEC &timestamp,
244 const com::Utf8Str &str,
245 const xml::ElementNode *pElm) const;
246 void parseBase64(IconBlob &binary,
247 const com::Utf8Str &str,
248 const xml::ElementNode *pElm) const;
249 com::Utf8Str stringifyTimestamp(const RTTIMESPEC &tm) const;
250 void toBase64(com::Utf8Str &str,
251 const IconBlob &binary) const;
252
253 void readExtraData(const xml::ElementNode &elmExtraData,
254 StringsMap &map);
255 void readUSBDeviceFilters(const xml::ElementNode &elmDeviceFilters,
256 USBDeviceFiltersList &ll);
257 void readMediumOne(MediaType t, const xml::ElementNode &elmMedium, Medium &med);
258 void readMedium(MediaType t, uint32_t depth, const xml::ElementNode &elmMedium, Medium &med);
259 void readMediaRegistry(const xml::ElementNode &elmMediaRegistry, MediaRegistry &mr);
260 void readNATForwardRulesMap(const xml::ElementNode &elmParent, NATRulesMap &mapRules);
261 void readNATLoopbacks(const xml::ElementNode &elmParent, NATLoopbackOffsetList &llLoopBacks);
262
263 void setVersionAttribute(xml::ElementNode &elm);
264 void specialBackupIfFirstBump();
265 void createStubDocument();
266
267 void buildExtraData(xml::ElementNode &elmParent, const StringsMap &me);
268 void buildUSBDeviceFilters(xml::ElementNode &elmParent,
269 const USBDeviceFiltersList &ll,
270 bool fHostMode);
271 void buildMedium(MediaType t,
272 uint32_t depth,
273 xml::ElementNode &elmMedium,
274 const Medium &mdm);
275 void buildMediaRegistry(xml::ElementNode &elmParent,
276 const MediaRegistry &mr);
277 void buildNATForwardRulesMap(xml::ElementNode &elmParent, const NATRulesMap &mapRules);
278 void buildNATLoopbacks(xml::ElementNode &elmParent, const NATLoopbackOffsetList &natLoopbackList);
279 void clearDocument();
280
281 struct Data;
282 Data *m;
283
284 friend class ConfigFileError;
285};
286
287////////////////////////////////////////////////////////////////////////////////
288//
289// VirtualBox.xml structures
290//
291////////////////////////////////////////////////////////////////////////////////
292
293struct USBDeviceSource
294{
295 com::Utf8Str strName;
296 com::Utf8Str strBackend;
297 com::Utf8Str strAddress;
298 StringsMap properties;
299};
300
301typedef std::list<USBDeviceSource> USBDeviceSourcesList;
302
303struct Host
304{
305 USBDeviceFiltersList llUSBDeviceFilters;
306 USBDeviceSourcesList llUSBDeviceSources;
307};
308
309struct SystemProperties
310{
311 SystemProperties();
312
313 com::Utf8Str strDefaultMachineFolder;
314 com::Utf8Str strDefaultHardDiskFolder;
315 com::Utf8Str strDefaultHardDiskFormat;
316 com::Utf8Str strVRDEAuthLibrary;
317 com::Utf8Str strWebServiceAuthLibrary;
318 com::Utf8Str strDefaultVRDEExtPack;
319 com::Utf8Str strAutostartDatabasePath;
320 com::Utf8Str strDefaultAdditionsISO;
321 com::Utf8Str strDefaultFrontend;
322 com::Utf8Str strLoggingLevel;
323 com::Utf8Str strProxyUrl;
324 uint32_t uProxyMode; /**< ProxyMode_T */
325 uint32_t uLogHistoryCount;
326 bool fExclusiveHwVirt;
327};
328
329struct MachineRegistryEntry
330{
331 com::Guid uuid;
332 com::Utf8Str strSettingsFile;
333};
334
335typedef std::list<MachineRegistryEntry> MachinesRegistry;
336
337struct DhcpOptValue
338{
339 DhcpOptValue();
340 DhcpOptValue(const com::Utf8Str &aText, DHCPOptionEncoding_T aEncoding = DHCPOptionEncoding_Normal);
341
342 com::Utf8Str strValue;
343 DHCPOptionEncoding_T enmEncoding;
344};
345
346typedef std::map<DHCPOption_T, DhcpOptValue> DhcpOptionMap;
347typedef DhcpOptionMap::value_type DhcpOptValuePair;
348typedef DhcpOptionMap::iterator DhcpOptIterator;
349typedef DhcpOptionMap::const_iterator DhcpOptConstIterator;
350
351struct DHCPGroupCondition
352{
353 DHCPGroupCondition();
354
355 bool fInclusive;
356 DHCPGroupConditionType_T enmType;
357 com::Utf8Str strValue;
358};
359typedef std::vector<DHCPGroupCondition> DHCPGroupConditionVec;
360
361
362struct DHCPConfig
363{
364 DHCPConfig();
365
366 DhcpOptionMap mapOptions;
367 uint32_t secMinLeaseTime;
368 uint32_t secDefaultLeaseTime;
369 uint32_t secMaxLeaseTime;
370 com::Utf8Str strForcedOptions;
371 com::Utf8Str strSuppressedOptions;
372};
373
374struct DHCPGroupConfig : DHCPConfig
375{
376 DHCPGroupConfig();
377
378 com::Utf8Str strName;
379 DHCPGroupConditionVec vecConditions;
380};
381typedef std::vector<DHCPGroupConfig> DHCPGroupConfigVec;
382
383struct DHCPIndividualConfig : DHCPConfig
384{
385 DHCPIndividualConfig();
386
387 com::Utf8Str strMACAddress;
388 com::Utf8Str strVMName;
389 uint32_t uSlot;
390 com::Utf8Str strFixedAddress;
391};
392typedef std::map<com::Utf8Str, DHCPIndividualConfig> DHCPIndividualConfigMap;
393
394struct DHCPServer
395{
396 DHCPServer();
397
398 com::Utf8Str strNetworkName;
399 com::Utf8Str strIPAddress;
400 com::Utf8Str strIPLower;
401 com::Utf8Str strIPUpper;
402 bool fEnabled;
403 DHCPConfig globalConfig;
404 DHCPGroupConfigVec vecGroupConfigs;
405 DHCPIndividualConfigMap mapIndividualConfigs;
406};
407typedef std::list<DHCPServer> DHCPServersList;
408
409
410/**
411 * NAT Networking settings (NAT service).
412 */
413struct NATNetwork
414{
415 NATNetwork();
416
417 com::Utf8Str strNetworkName;
418 com::Utf8Str strIPv4NetworkCidr;
419 com::Utf8Str strIPv6Prefix;
420 bool fEnabled;
421 bool fIPv6Enabled;
422 bool fAdvertiseDefaultIPv6Route;
423 bool fNeedDhcpServer;
424 uint32_t u32HostLoopback6Offset;
425 NATLoopbackOffsetList llHostLoopbackOffsetList;
426 NATRulesMap mapPortForwardRules4;
427 NATRulesMap mapPortForwardRules6;
428};
429
430typedef std::list<NATNetwork> NATNetworksList;
431
432#ifdef VBOX_WITH_CLOUD_NET
433/**
434 * Cloud Networking settings.
435 */
436struct CloudNetwork
437{
438 CloudNetwork();
439
440 com::Utf8Str strNetworkName;
441 com::Utf8Str strProviderShortName;
442 com::Utf8Str strProfileName;
443 com::Utf8Str strNetworkId;
444 bool fEnabled;
445};
446
447typedef std::list<CloudNetwork> CloudNetworksList;
448#endif /* VBOX_WITH_CLOUD_NET */
449
450
451class MainConfigFile : public ConfigFileBase
452{
453public:
454 MainConfigFile(const com::Utf8Str *pstrFilename);
455
456 void readMachineRegistry(const xml::ElementNode &elmMachineRegistry);
457 void readNATNetworks(const xml::ElementNode &elmNATNetworks);
458#ifdef VBOX_WITH_CLOUD_NET
459 void readCloudNetworks(const xml::ElementNode &elmCloudNetworks);
460#endif /* VBOX_WITH_CLOUD_NET */
461
462 void write(const com::Utf8Str strFilename);
463
464 Host host;
465 SystemProperties systemProperties;
466 MediaRegistry mediaRegistry;
467 MachinesRegistry llMachines;
468 DHCPServersList llDhcpServers;
469 NATNetworksList llNATNetworks;
470#ifdef VBOX_WITH_CLOUD_NET
471 CloudNetworksList llCloudNetworks;
472#endif /* VBOX_WITH_CLOUD_NET */
473 StringsMap mapExtraDataItems;
474
475private:
476 void bumpSettingsVersionIfNeeded();
477 void buildUSBDeviceSources(xml::ElementNode &elmParent, const USBDeviceSourcesList &ll);
478 void readUSBDeviceSources(const xml::ElementNode &elmDeviceSources, USBDeviceSourcesList &ll);
479 void buildDHCPServers(xml::ElementNode &elmDHCPServers, DHCPServersList const &ll);
480 void buildDHCPOptions(xml::ElementNode &elmOptions, DHCPConfig const &rConfig, bool fIgnoreSubnetMask);
481 void readDHCPServers(const xml::ElementNode &elmDHCPServers);
482 void readDHCPOptions(DHCPConfig &rConfig, const xml::ElementNode &elmOptions, bool fIgnoreSubnetMask);
483 bool convertGuiProxySettings(const com::Utf8Str &strUIProxySettings);
484};
485
486////////////////////////////////////////////////////////////////////////////////
487//
488// Machine XML structures
489//
490////////////////////////////////////////////////////////////////////////////////
491
492/**
493 * NOTE: If you add any fields in here, you must update a) the constructor and b)
494 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
495 * your settings might never get saved.
496 */
497struct VRDESettings
498{
499 VRDESettings();
500
501 bool areDefaultSettings(SettingsVersion_T sv) const;
502
503 bool operator==(const VRDESettings& v) const;
504
505 bool fEnabled;
506 AuthType_T authType;
507 uint32_t ulAuthTimeout;
508 com::Utf8Str strAuthLibrary;
509 bool fAllowMultiConnection,
510 fReuseSingleConnection;
511 com::Utf8Str strVrdeExtPack;
512 StringsMap mapProperties;
513};
514
515/**
516 * NOTE: If you add any fields in here, you must update a) the constructor and b)
517 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
518 * your settings might never get saved.
519 */
520struct BIOSSettings
521{
522 BIOSSettings();
523
524 bool areDefaultSettings() const;
525
526 bool operator==(const BIOSSettings &d) const;
527
528 bool fACPIEnabled,
529 fIOAPICEnabled,
530 fLogoFadeIn,
531 fLogoFadeOut,
532 fPXEDebugEnabled,
533 fSmbiosUuidLittleEndian;
534 uint32_t ulLogoDisplayTime;
535 BIOSBootMenuMode_T biosBootMenuMode;
536 APICMode_T apicMode; // requires settings version 1.16 (VirtualBox 5.1)
537 int64_t llTimeOffset;
538 com::Utf8Str strLogoImagePath;
539 com::Utf8Str strNVRAMPath;
540};
541
542/** List for keeping a recording feature list. */
543typedef std::map<RecordingFeature_T, bool> RecordingFeatureMap;
544
545struct RecordingScreenSettings
546{
547 RecordingScreenSettings();
548
549 virtual ~RecordingScreenSettings();
550
551 void applyDefaults(void);
552
553 bool areDefaultSettings(void) const;
554
555 bool isFeatureEnabled(RecordingFeature_T enmFeature) const;
556
557 bool operator==(const RecordingScreenSettings &d) const;
558
559 /** Whether to record this screen or not. */
560 bool fEnabled; // requires settings version 1.14 (VirtualBox 4.3)
561 /** Destination to record to. */
562 RecordingDestination_T enmDest; /** @todo Implement with next settings version bump. */
563 /** Which features are enable or not. */
564 RecordingFeatureMap featureMap; /** @todo Implement with next settings version bump. */
565 /** Maximum time (in s) to record. If set to 0, no time limit is set. */
566 uint32_t ulMaxTimeS; // requires settings version 1.14 (VirtualBox 4.3)
567 /** Options string for hidden / advanced / experimental features. */
568 com::Utf8Str strOptions; // new since VirtualBox 5.2.
569
570 /**
571 * Structure holding settings for audio recording.
572 */
573 struct Audio
574 {
575 Audio()
576 : enmAudioCodec(RecordingAudioCodec_Opus)
577 , uHz(22050)
578 , cBits(16)
579 , cChannels(2) { }
580
581 /** The audio codec type to use. */
582 RecordingAudioCodec_T enmAudioCodec; /** @todo Implement with next settings version bump. */
583 /** Hz rate. */
584 uint16_t uHz; /** @todo Implement with next settings version bump. */
585 /** Bits per sample. */
586 uint8_t cBits; /** @todo Implement with next settings version bump. */
587 /** Number of audio channels. */
588 uint8_t cChannels; /** @todo Implement with next settings version bump. */
589 } Audio;
590
591 /**
592 * Structure holding settings for video recording.
593 */
594 struct Video
595 {
596 Video()
597 : enmCodec(RecordingVideoCodec_VP8)
598 , ulWidth(1024)
599 , ulHeight(768)
600 , ulRate(512)
601 , ulFPS(25) { }
602
603 /** The codec to use. */
604 RecordingVideoCodec_T enmCodec; /** @todo Implement with next settings version bump. */
605 /** Target frame width in pixels (X). */
606 uint32_t ulWidth; // requires settings version 1.14 (VirtualBox 4.3)
607 /** Target frame height in pixels (Y). */
608 uint32_t ulHeight; // requires settings version 1.14 (VirtualBox 4.3)
609 /** Encoding rate. */
610 uint32_t ulRate; // requires settings version 1.14 (VirtualBox 4.3)
611 /** Frames per second (FPS). */
612 uint32_t ulFPS; // requires settings version 1.14 (VirtualBox 4.3)
613 } Video;
614
615 /**
616 * Structure holding settings if the destination is a file.
617 */
618 struct File
619 {
620 File()
621 : ulMaxSizeMB(0) { }
622
623 /** Maximum size (in MB) the file is allowed to have.
624 * When reaching the limit, recording will stop. */
625 uint32_t ulMaxSizeMB; // requires settings version 1.14 (VirtualBox 4.3)
626 /** Absolute file name path to use for recording. */
627 com::Utf8Str strName; // requires settings version 1.14 (VirtualBox 4.3)
628 } File;
629};
630
631/** Map for keeping settings per virtual screen.
632 * The key specifies the screen ID. */
633typedef std::map<uint32_t, RecordingScreenSettings> RecordingScreenMap;
634
635/**
636 * NOTE: If you add any fields in here, you must update a) the constructor and b)
637 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
638 * your settings might never get saved.
639 */
640struct RecordingSettings
641{
642 RecordingSettings();
643
644 void applyDefaults(void);
645
646 bool areDefaultSettings(void) const;
647
648 bool operator==(const RecordingSettings &d) const;
649
650 /** Whether recording as a whole is enabled or disabled. */
651 bool fEnabled; // requires settings version 1.14 (VirtualBox 4.3)
652 /** Map of handled recording screen settings.
653 * The key specifies the screen ID. */
654 RecordingScreenMap mapScreens;
655};
656
657/**
658 * NOTE: If you add any fields in here, you must update a) the constructor and b)
659 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
660 * your settings might never get saved.
661 */
662struct GraphicsAdapter
663{
664 GraphicsAdapter();
665
666 bool areDefaultSettings() const;
667
668 bool operator==(const GraphicsAdapter &g) const;
669
670 GraphicsControllerType_T graphicsControllerType;
671 uint32_t ulVRAMSizeMB;
672 uint32_t cMonitors;
673 bool fAccelerate3D,
674 fAccelerate2DVideo; // requires settings version 1.8 (VirtualBox 3.1)
675};
676
677/**
678 * NOTE: If you add any fields in here, you must update a) the constructor and b)
679 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
680 * your settings might never get saved.
681 */
682struct USBController
683{
684 USBController();
685
686 bool operator==(const USBController &u) const;
687
688 com::Utf8Str strName;
689 USBControllerType_T enmType;
690};
691
692typedef std::list<USBController> USBControllerList;
693
694struct USB
695{
696 USB();
697
698 bool operator==(const USB &u) const;
699
700 /** List of USB controllers present. */
701 USBControllerList llUSBControllers;
702 /** List of USB device filters. */
703 USBDeviceFiltersList llDeviceFilters;
704};
705
706struct NAT
707{
708 NAT();
709
710 bool areDNSDefaultSettings() const;
711 bool areAliasDefaultSettings() const;
712 bool areTFTPDefaultSettings() const;
713 bool areDefaultSettings() const;
714
715 bool operator==(const NAT &n) const;
716
717 com::Utf8Str strNetwork;
718 com::Utf8Str strBindIP;
719 uint32_t u32Mtu;
720 uint32_t u32SockRcv;
721 uint32_t u32SockSnd;
722 uint32_t u32TcpRcv;
723 uint32_t u32TcpSnd;
724 com::Utf8Str strTFTPPrefix;
725 com::Utf8Str strTFTPBootFile;
726 com::Utf8Str strTFTPNextServer;
727 bool fDNSPassDomain;
728 bool fDNSProxy;
729 bool fDNSUseHostResolver;
730 bool fAliasLog;
731 bool fAliasProxyOnly;
732 bool fAliasUseSamePorts;
733 NATRulesMap mapRules;
734};
735
736/**
737 * NOTE: If you add any fields in here, you must update a) the constructor and b)
738 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
739 * your settings might never get saved.
740 */
741struct NetworkAdapter
742{
743 NetworkAdapter();
744
745 bool areGenericDriverDefaultSettings() const;
746 bool areDefaultSettings(SettingsVersion_T sv) const;
747 bool areDisabledDefaultSettings() const;
748
749 bool operator==(const NetworkAdapter &n) const;
750
751 uint32_t ulSlot;
752
753 NetworkAdapterType_T type;
754 bool fEnabled;
755 com::Utf8Str strMACAddress;
756 bool fCableConnected;
757 uint32_t ulLineSpeed;
758 NetworkAdapterPromiscModePolicy_T enmPromiscModePolicy;
759 bool fTraceEnabled;
760 com::Utf8Str strTraceFile;
761
762 NetworkAttachmentType_T mode;
763 NAT nat;
764 com::Utf8Str strBridgedName;
765 com::Utf8Str strHostOnlyName;
766 com::Utf8Str strInternalNetworkName;
767 com::Utf8Str strGenericDriver;
768 StringsMap genericProperties;
769 com::Utf8Str strNATNetworkName;
770#ifdef VBOX_WITH_CLOUD_NET
771 com::Utf8Str strCloudNetworkName;
772#endif /* VBOX_WITH_CLOUD_NET */
773 uint32_t ulBootPriority;
774 com::Utf8Str strBandwidthGroup; // requires settings version 1.13 (VirtualBox 4.2)
775};
776
777typedef std::list<NetworkAdapter> NetworkAdaptersList;
778
779/**
780 * NOTE: If you add any fields in here, you must update a) the constructor and b)
781 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
782 * your settings might never get saved.
783 */
784struct SerialPort
785{
786 SerialPort();
787
788 bool operator==(const SerialPort &n) const;
789
790 uint32_t ulSlot;
791
792 bool fEnabled;
793 uint32_t ulIOBase;
794 uint32_t ulIRQ;
795 PortMode_T portMode;
796 com::Utf8Str strPath;
797 bool fServer;
798 UartType_T uartType;
799};
800
801typedef std::list<SerialPort> SerialPortsList;
802
803/**
804 * NOTE: If you add any fields in here, you must update a) the constructor and b)
805 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
806 * your settings might never get saved.
807 */
808struct ParallelPort
809{
810 ParallelPort();
811
812 bool operator==(const ParallelPort &d) const;
813
814 uint32_t ulSlot;
815
816 bool fEnabled;
817 uint32_t ulIOBase;
818 uint32_t ulIRQ;
819 com::Utf8Str strPath;
820};
821
822typedef std::list<ParallelPort> ParallelPortsList;
823
824/**
825 * NOTE: If you add any fields in here, you must update a) the constructor and b)
826 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
827 * your settings might never get saved.
828 */
829struct AudioAdapter
830{
831 AudioAdapter();
832
833 bool areDefaultSettings(SettingsVersion_T sv) const;
834
835 bool operator==(const AudioAdapter &a) const;
836
837 bool fEnabled;
838 bool fEnabledIn;
839 bool fEnabledOut;
840 AudioControllerType_T controllerType;
841 AudioCodecType_T codecType;
842 AudioDriverType_T driverType;
843 settings::StringsMap properties;
844};
845
846/**
847 * NOTE: If you add any fields in here, you must update a) the constructor and b)
848 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
849 * your settings might never get saved.
850 */
851struct SharedFolder
852{
853 SharedFolder();
854
855 bool operator==(const SharedFolder &a) const;
856
857 com::Utf8Str strName,
858 strHostPath;
859 bool fWritable;
860 bool fAutoMount;
861 com::Utf8Str strAutoMountPoint;
862};
863
864typedef std::list<SharedFolder> SharedFoldersList;
865
866/**
867 * NOTE: If you add any fields in here, you must update a) the constructor and b)
868 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
869 * your settings might never get saved.
870 */
871struct GuestProperty
872{
873 GuestProperty();
874
875 bool operator==(const GuestProperty &g) const;
876
877 com::Utf8Str strName,
878 strValue;
879 uint64_t timestamp;
880 com::Utf8Str strFlags;
881};
882
883typedef std::list<GuestProperty> GuestPropertiesList;
884
885typedef std::map<uint32_t, DeviceType_T> BootOrderMap;
886
887/**
888 * NOTE: If you add any fields in here, you must update a) the constructor and b)
889 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
890 * your settings might never get saved.
891 */
892struct CpuIdLeaf
893{
894 CpuIdLeaf();
895
896 bool operator==(const CpuIdLeaf &c) const;
897
898 uint32_t idx;
899 uint32_t idxSub;
900 uint32_t uEax;
901 uint32_t uEbx;
902 uint32_t uEcx;
903 uint32_t uEdx;
904};
905
906typedef std::list<CpuIdLeaf> CpuIdLeafsList;
907
908/**
909 * NOTE: If you add any fields in here, you must update a) the constructor and b)
910 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
911 * your settings might never get saved.
912 */
913struct Cpu
914{
915 Cpu();
916
917 bool operator==(const Cpu &c) const;
918
919 uint32_t ulId;
920};
921
922typedef std::list<Cpu> CpuList;
923
924/**
925 * NOTE: If you add any fields in here, you must update a) the constructor and b)
926 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
927 * your settings might never get saved.
928 */
929struct BandwidthGroup
930{
931 BandwidthGroup();
932
933 bool operator==(const BandwidthGroup &i) const;
934
935 com::Utf8Str strName;
936 uint64_t cMaxBytesPerSec;
937 BandwidthGroupType_T enmType;
938};
939
940typedef std::list<BandwidthGroup> BandwidthGroupList;
941
942/**
943 * NOTE: If you add any fields in here, you must update a) the constructor and b)
944 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
945 * your settings might never get saved.
946 */
947struct IOSettings
948{
949 IOSettings();
950
951 bool areIOCacheDefaultSettings() const;
952 bool areDefaultSettings() const;
953
954 bool operator==(const IOSettings &i) const;
955
956 bool fIOCacheEnabled;
957 uint32_t ulIOCacheSize;
958 BandwidthGroupList llBandwidthGroups;
959};
960
961/**
962 * NOTE: If you add any fields in here, you must update a) the constructor and b)
963 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
964 * your settings might never get saved.
965 */
966struct HostPCIDeviceAttachment
967{
968 HostPCIDeviceAttachment();
969
970 bool operator==(const HostPCIDeviceAttachment &a) const;
971
972 com::Utf8Str strDeviceName;
973 uint32_t uHostAddress;
974 uint32_t uGuestAddress;
975};
976
977typedef std::list<HostPCIDeviceAttachment> HostPCIDeviceAttachmentList;
978
979/**
980 * A device attached to a storage controller. This can either be a
981 * hard disk or a DVD drive or a floppy drive and also specifies
982 * which medium is "in" the drive; as a result, this is a combination
983 * of the Main IMedium and IMediumAttachment interfaces.
984 *
985 * NOTE: If you add any fields in here, you must update a) the constructor and b)
986 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
987 * your settings might never get saved.
988 */
989struct AttachedDevice
990{
991 AttachedDevice();
992
993 bool operator==(const AttachedDevice &a) const;
994
995 DeviceType_T deviceType; // only HardDisk, DVD or Floppy are allowed
996
997 // DVDs can be in pass-through mode:
998 bool fPassThrough;
999
1000 // Whether guest-triggered eject of DVDs will keep the medium in the
1001 // VM config or not:
1002 bool fTempEject;
1003
1004 // Whether the medium is non-rotational:
1005 bool fNonRotational;
1006
1007 // Whether the medium supports discarding unused blocks:
1008 bool fDiscard;
1009
1010 // Whether the medium is hot-pluggable:
1011 bool fHotPluggable;
1012
1013 int32_t lPort;
1014 int32_t lDevice;
1015
1016 // if an image file is attached to the device (ISO, RAW, or hard disk image such as VDI),
1017 // this is its UUID; it depends on deviceType which media registry this then needs to
1018 // be looked up in. If no image file (only permitted for DVDs and floppies), then the UUID is NULL
1019 com::Guid uuid;
1020
1021 // for DVDs and floppies, the attachment can also be a host device:
1022 com::Utf8Str strHostDriveSrc; // if != NULL, value of <HostDrive>/@src
1023
1024 // Bandwidth group the device is attached to.
1025 com::Utf8Str strBwGroup;
1026};
1027
1028typedef std::list<AttachedDevice> AttachedDevicesList;
1029
1030/**
1031 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1032 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1033 * your settings might never get saved.
1034 */
1035struct StorageController
1036{
1037 StorageController();
1038
1039 bool operator==(const StorageController &s) const;
1040
1041 com::Utf8Str strName;
1042 StorageBus_T storageBus; // _SATA, _SCSI, _IDE, _SAS
1043 StorageControllerType_T controllerType;
1044 uint32_t ulPortCount;
1045 uint32_t ulInstance;
1046 bool fUseHostIOCache;
1047 bool fBootable;
1048
1049 // only for when controllerType == StorageControllerType_IntelAhci:
1050 int32_t lIDE0MasterEmulationPort,
1051 lIDE0SlaveEmulationPort,
1052 lIDE1MasterEmulationPort,
1053 lIDE1SlaveEmulationPort;
1054
1055 AttachedDevicesList llAttachedDevices;
1056};
1057
1058typedef std::list<StorageController> StorageControllersList;
1059
1060/**
1061 * We wrap the storage controllers list into an extra struct so we can
1062 * use an undefined struct without needing std::list<> in all the headers.
1063 *
1064 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1065 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1066 * your settings might never get saved.
1067 */
1068struct Storage
1069{
1070 bool operator==(const Storage &s) const;
1071
1072 StorageControllersList llStorageControllers;
1073};
1074
1075/**
1076 * Representation of Machine hardware; this is used in the MachineConfigFile.hardwareMachine
1077 * field.
1078 *
1079 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1080 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1081 * your settings might never get saved.
1082 */
1083struct Hardware
1084{
1085 Hardware();
1086
1087 bool areParavirtDefaultSettings(SettingsVersion_T sv) const;
1088 bool areBootOrderDefaultSettings() const;
1089 bool areDisplayDefaultSettings() const;
1090 bool areAllNetworkAdaptersDefaultSettings(SettingsVersion_T sv) const;
1091
1092 bool operator==(const Hardware&) const;
1093
1094 com::Utf8Str strVersion; // hardware version, optional
1095 com::Guid uuid; // hardware uuid, optional (null).
1096
1097 bool fHardwareVirt,
1098 fNestedPaging,
1099 fLargePages,
1100 fVPID,
1101 fUnrestrictedExecution,
1102 fHardwareVirtForce,
1103 fUseNativeApi,
1104 fSyntheticCpu,
1105 fTripleFaultReset,
1106 fPAE,
1107 fAPIC, // requires settings version 1.16 (VirtualBox 5.1)
1108 fX2APIC; // requires settings version 1.16 (VirtualBox 5.1)
1109 bool fIBPBOnVMExit; //< added out of cycle, after 1.16 was out.
1110 bool fIBPBOnVMEntry; //< added out of cycle, after 1.16 was out.
1111 bool fSpecCtrl; //< added out of cycle, after 1.16 was out.
1112 bool fSpecCtrlByHost; //< added out of cycle, after 1.16 was out.
1113 bool fL1DFlushOnSched ; //< added out of cycle, after 1.16 was out.
1114 bool fL1DFlushOnVMEntry ; //< added out of cycle, after 1.16 was out.
1115 bool fMDSClearOnSched; //< added out of cycle, after 1.16 was out.
1116 bool fMDSClearOnVMEntry; //< added out of cycle, after 1.16 was out.
1117 bool fNestedHWVirt; //< requires settings version 1.17 (VirtualBox 6.0)
1118 typedef enum LongModeType { LongMode_Enabled, LongMode_Disabled, LongMode_Legacy } LongModeType;
1119 LongModeType enmLongMode;
1120 uint32_t cCPUs;
1121 bool fCpuHotPlug; // requires settings version 1.10 (VirtualBox 3.2)
1122 CpuList llCpus; // requires settings version 1.10 (VirtualBox 3.2)
1123 bool fHPETEnabled; // requires settings version 1.10 (VirtualBox 3.2)
1124 uint32_t ulCpuExecutionCap; // requires settings version 1.11 (VirtualBox 3.3)
1125 uint32_t uCpuIdPortabilityLevel; // requires settings version 1.15 (VirtualBox 5.0)
1126 com::Utf8Str strCpuProfile; // requires settings version 1.16 (VirtualBox 5.1)
1127
1128 CpuIdLeafsList llCpuIdLeafs;
1129
1130 uint32_t ulMemorySizeMB;
1131
1132 BootOrderMap mapBootOrder; // item 0 has highest priority
1133
1134 FirmwareType_T firmwareType; // requires settings version 1.9 (VirtualBox 3.1)
1135
1136 PointingHIDType_T pointingHIDType; // requires settings version 1.10 (VirtualBox 3.2)
1137 KeyboardHIDType_T keyboardHIDType; // requires settings version 1.10 (VirtualBox 3.2)
1138
1139 ChipsetType_T chipsetType; // requires settings version 1.11 (VirtualBox 4.0)
1140 ParavirtProvider_T paravirtProvider; // requires settings version 1.15 (VirtualBox 4.4)
1141 com::Utf8Str strParavirtDebug; // requires settings version 1.16 (VirtualBox 5.1)
1142
1143 bool fEmulatedUSBCardReader; // 1.12 (VirtualBox 4.1)
1144
1145 VRDESettings vrdeSettings;
1146
1147 BIOSSettings biosSettings;
1148 RecordingSettings recordingSettings;
1149 GraphicsAdapter graphicsAdapter;
1150 USB usbSettings;
1151 NetworkAdaptersList llNetworkAdapters;
1152 SerialPortsList llSerialPorts;
1153 ParallelPortsList llParallelPorts;
1154 AudioAdapter audioAdapter;
1155 Storage storage;
1156
1157 // technically these two have no business in the hardware section, but for some
1158 // clever reason <Hardware> is where they are in the XML....
1159 SharedFoldersList llSharedFolders;
1160
1161 ClipboardMode_T clipboardMode;
1162 bool fClipboardFileTransfersEnabled;
1163
1164 DnDMode_T dndMode;
1165
1166 uint32_t ulMemoryBalloonSize;
1167 bool fPageFusionEnabled;
1168
1169 GuestPropertiesList llGuestProperties;
1170
1171 IOSettings ioSettings; // requires settings version 1.10 (VirtualBox 3.2)
1172 HostPCIDeviceAttachmentList pciAttachments; // requires settings version 1.12 (VirtualBox 4.1)
1173
1174 com::Utf8Str strDefaultFrontend; // requires settings version 1.14 (VirtualBox 4.3)
1175};
1176
1177/**
1178 * Settings that has to do with debugging.
1179 */
1180struct Debugging
1181{
1182 Debugging();
1183
1184 bool areDefaultSettings() const;
1185
1186 bool operator==(const Debugging &rOther) const;
1187
1188 bool fTracingEnabled;
1189 bool fAllowTracingToAccessVM;
1190 com::Utf8Str strTracingConfig;
1191};
1192
1193/**
1194 * Settings that has to do with autostart.
1195 */
1196struct Autostart
1197{
1198 Autostart();
1199
1200 bool areDefaultSettings() const;
1201
1202 bool operator==(const Autostart &rOther) const;
1203
1204 bool fAutostartEnabled;
1205 uint32_t uAutostartDelay;
1206 AutostopType_T enmAutostopType;
1207};
1208
1209struct Snapshot;
1210typedef std::list<Snapshot> SnapshotsList;
1211
1212/**
1213 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1214 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1215 * your settings might never get saved.
1216 */
1217struct Snapshot
1218{
1219 Snapshot();
1220
1221 bool operator==(const Snapshot &s) const;
1222
1223 com::Guid uuid;
1224 com::Utf8Str strName,
1225 strDescription; // optional
1226 RTTIMESPEC timestamp;
1227
1228 com::Utf8Str strStateFile; // for online snapshots only
1229
1230 Hardware hardware;
1231
1232 Debugging debugging;
1233 Autostart autostart;
1234
1235 SnapshotsList llChildSnapshots;
1236
1237 static const struct Snapshot Empty;
1238};
1239
1240/**
1241 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1242 * the operator== which is used by MachineConfigFile::operator==(), or otherwise
1243 * your settings might never get saved.
1244 */
1245struct MachineUserData
1246{
1247 MachineUserData();
1248
1249 bool operator==(const MachineUserData &c) const;
1250
1251 com::Utf8Str strName;
1252 bool fDirectoryIncludesUUID;
1253 bool fNameSync;
1254 com::Utf8Str strDescription;
1255 StringsList llGroups;
1256 com::Utf8Str strOsType;
1257 com::Utf8Str strSnapshotFolder;
1258 bool fTeleporterEnabled;
1259 uint32_t uTeleporterPort;
1260 com::Utf8Str strTeleporterAddress;
1261 com::Utf8Str strTeleporterPassword;
1262 bool fRTCUseUTC;
1263 IconBlob ovIcon;
1264 VMProcPriority_T enmVMPriority;
1265};
1266
1267
1268/**
1269 * MachineConfigFile represents an XML machine configuration. All the machine settings
1270 * that go out to the XML (or are read from it) are in here.
1271 *
1272 * NOTE: If you add any fields in here, you must update a) the constructor and b)
1273 * the operator== which is used by Machine::saveSettings(), or otherwise your settings
1274 * might never get saved.
1275 */
1276class MachineConfigFile : public ConfigFileBase
1277{
1278public:
1279 com::Guid uuid;
1280
1281 MachineUserData machineUserData;
1282
1283 com::Utf8Str strStateFile;
1284 bool fCurrentStateModified; // optional, default is true
1285 RTTIMESPEC timeLastStateChange; // optional, defaults to now
1286 bool fAborted; // optional, default is false
1287
1288 com::Guid uuidCurrentSnapshot;
1289
1290 Hardware hardwareMachine;
1291 MediaRegistry mediaRegistry;
1292 Debugging debugging;
1293 Autostart autostart;
1294
1295 StringsMap mapExtraDataItems;
1296
1297 SnapshotsList llFirstSnapshot; // first snapshot or empty list if there's none
1298
1299 MachineConfigFile(const com::Utf8Str *pstrFilename);
1300
1301 bool operator==(const MachineConfigFile &m) const;
1302
1303 bool canHaveOwnMediaRegistry() const;
1304
1305 void importMachineXML(const xml::ElementNode &elmMachine);
1306
1307 void write(const com::Utf8Str &strFilename);
1308
1309 enum
1310 {
1311 BuildMachineXML_IncludeSnapshots = 0x01,
1312 BuildMachineXML_WriteVBoxVersionAttribute = 0x02,
1313 BuildMachineXML_SkipRemovableMedia = 0x04,
1314 BuildMachineXML_MediaRegistry = 0x08,
1315 BuildMachineXML_SuppressSavedState = 0x10
1316 };
1317 void buildMachineXML(xml::ElementNode &elmMachine,
1318 uint32_t fl,
1319 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1320
1321 static bool isAudioDriverAllowedOnThisHost(AudioDriverType_T drv);
1322 static AudioDriverType_T getHostDefaultAudioDriver();
1323
1324private:
1325 void readNetworkAdapters(const xml::ElementNode &elmHardware, NetworkAdaptersList &ll);
1326 void readAttachedNetworkMode(const xml::ElementNode &pelmMode, bool fEnabled, NetworkAdapter &nic);
1327 void readCpuIdTree(const xml::ElementNode &elmCpuid, CpuIdLeafsList &ll);
1328 void readCpuTree(const xml::ElementNode &elmCpu, CpuList &ll);
1329 void readSerialPorts(const xml::ElementNode &elmUART, SerialPortsList &ll);
1330 void readParallelPorts(const xml::ElementNode &elmLPT, ParallelPortsList &ll);
1331 void readAudioAdapter(const xml::ElementNode &elmAudioAdapter, AudioAdapter &aa);
1332 void readGuestProperties(const xml::ElementNode &elmGuestProperties, Hardware &hw);
1333 void readStorageControllerAttributes(const xml::ElementNode &elmStorageController, StorageController &sctl);
1334 void readHardware(const xml::ElementNode &elmHardware, Hardware &hw);
1335 void readHardDiskAttachments_pre1_7(const xml::ElementNode &elmHardDiskAttachments, Storage &strg);
1336 void readStorageControllers(const xml::ElementNode &elmStorageControllers, Storage &strg);
1337 void readDVDAndFloppies_pre1_9(const xml::ElementNode &elmHardware, Storage &strg);
1338 void readTeleporter(const xml::ElementNode *pElmTeleporter, MachineUserData *pUserData);
1339 void readDebugging(const xml::ElementNode *pElmDbg, Debugging *pDbg);
1340 void readAutostart(const xml::ElementNode *pElmAutostart, Autostart *pAutostart);
1341 void readGroups(const xml::ElementNode *elmGroups, StringsList *pllGroups);
1342 bool readSnapshot(const com::Guid &curSnapshotUuid, uint32_t depth, const xml::ElementNode &elmSnapshot, Snapshot &snap);
1343 void convertOldOSType_pre1_5(com::Utf8Str &str);
1344 void readMachine(const xml::ElementNode &elmMachine);
1345
1346 void buildHardwareXML(xml::ElementNode &elmParent, const Hardware &hw, uint32_t fl, std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1347 void buildNetworkXML(NetworkAttachmentType_T mode, bool fEnabled, xml::ElementNode &elmParent, const NetworkAdapter &nic);
1348 void buildStorageControllersXML(xml::ElementNode &elmParent,
1349 const Storage &st,
1350 bool fSkipRemovableMedia,
1351 std::list<xml::ElementNode*> *pllElementsWithUuidAttributes);
1352 void buildDebuggingXML(xml::ElementNode *pElmParent, const Debugging *pDbg);
1353 void buildAutostartXML(xml::ElementNode *pElmParent, const Autostart *pAutostart);
1354 void buildGroupsXML(xml::ElementNode *pElmParent, const StringsList *pllGroups);
1355 void buildSnapshotXML(uint32_t depth, xml::ElementNode &elmParent, const Snapshot &snap);
1356
1357 void bumpSettingsVersionIfNeeded();
1358};
1359
1360} // namespace settings
1361
1362
1363#endif /* !VBOX_INCLUDED_settings_h */
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