VirtualBox

Changeset 31595 in vbox for trunk/src/VBox


Ignore:
Timestamp:
Aug 12, 2010 11:44:47 AM (14 years ago)
Author:
vboxsync
Message:

Main: remove deprecated VirtualBox::createLegacyMachine() and corresponding VBoxManage --settingsfile option; new API docs for IMachine::attachDevice() (not yet implemented)

Location:
trunk/src/VBox
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/Frontends/VBoxManage/VBoxManageMisc.cpp

    r31574 r31595  
    182182    HRESULT rc;
    183183    Bstr baseFolder;
    184     Bstr settingsFile;
    185184    Bstr name;
    186185    Bstr osTypeId;
     
    198197            i++;
    199198            baseFolder = a->argv[i];
    200         }
    201         else if (   !strcmp(a->argv[i], "--settingsfile")
    202                  || !strcmp(a->argv[i], "-settingsfile"))
    203         {
    204             if (a->argc <= i + 1)
    205                 return errorArgument("Missing argument to '%s'", a->argv[i]);
    206             i++;
    207             settingsFile = a->argv[i];
    208199        }
    209200        else if (   !strcmp(a->argv[i], "--name")
     
    243234        return errorSyntax(USAGE_CREATEVM, "Parameter --name is required");
    244235
    245     if (!baseFolder.isEmpty() && !settingsFile.isEmpty())
    246         return errorSyntax(USAGE_CREATEVM, "Cannot specify both --basefolder and --settingsfile together");
    247 
    248236    do
    249237    {
    250238        ComPtr<IMachine> machine;
    251239
    252         if (settingsFile.isEmpty())
    253             CHECK_ERROR_BREAK(a->virtualBox,
    254                 CreateMachine(name, osTypeId, baseFolder, Guid(id).toUtf16(), FALSE, machine.asOutParam()));
    255         else
    256             CHECK_ERROR_BREAK(a->virtualBox,
    257                 CreateLegacyMachine(name, osTypeId, settingsFile, Guid(id).toUtf16(), machine.asOutParam()));
     240        CHECK_ERROR_BREAK(a->virtualBox,
     241                          CreateMachine(name,
     242                                        osTypeId,
     243                                        baseFolder,
     244                                        Guid(id).toUtf16(),
     245                                        FALSE,
     246                                        machine.asOutParam()));
    258247
    259248        CHECK_ERROR_BREAK(machine, SaveSettings());
     
    264253        Bstr uuid;
    265254        CHECK_ERROR_BREAK(machine, COMGETTER(Id)(uuid.asOutParam()));
     255        Bstr settingsFile;
    266256        CHECK_ERROR_BREAK(machine, COMGETTER(SettingsFilePath)(settingsFile.asOutParam()));
    267257        RTPrintf("Virtual machine '%ls' is created%s.\n"
  • trunk/src/VBox/Main/VirtualBoxImpl.cpp

    r31579 r31595  
    11801180
    11811181    LogFlowThisFuncLeave();
    1182 
    1183     return rc;
    1184 }
    1185 
    1186 STDMETHODIMP VirtualBox::CreateLegacyMachine(IN_BSTR aName,
    1187                                              IN_BSTR aOsTypeId,
    1188                                              IN_BSTR aSettingsFile,
    1189                                              IN_BSTR aId,
    1190                                              IMachine **aMachine)
    1191 {
    1192     CheckComArgStrNotEmptyOrNull(aName);
    1193     CheckComArgStrNotEmptyOrNull(aSettingsFile);
    1194     /** @todo tighten checks on aId? */
    1195     CheckComArgOutPointerValid(aMachine);
    1196 
    1197     AutoCaller autoCaller(this);
    1198     if (FAILED(autoCaller.rc())) return autoCaller.rc();
    1199 
    1200     HRESULT rc = E_FAIL;
    1201 
    1202     Utf8Str settingsFile = aSettingsFile;
    1203     /* append the default extension if none */
    1204     if (!RTPathHaveExt(settingsFile.c_str()))
    1205         settingsFile = Utf8StrFmt("%s.xml", settingsFile.c_str());
    1206 
    1207     /* create a new object */
    1208     ComObjPtr<Machine> machine;
    1209     rc = machine.createObject();
    1210     if (FAILED(rc)) return rc;
    1211 
    1212     /* Create UUID if an empty one was specified. */
    1213     Guid id(aId);
    1214     if (id.isEmpty())
    1215         id.create();
    1216 
    1217     GuestOSType *osType = NULL;
    1218     rc = findGuestOSType(Bstr(aOsTypeId), osType);
    1219     if (FAILED(rc)) return rc;
    1220 
    1221     /* initialize the machine object */
    1222     rc = machine->init(this,
    1223                        settingsFile,
    1224                        Utf8Str(aName),
    1225                        id,
    1226                        osType,
    1227                        FALSE /* aOverride */,
    1228                        FALSE /* aNameSync */);
    1229     if (SUCCEEDED(rc))
    1230     {
    1231         /* set the return value */
    1232         rc = machine.queryInterfaceTo(aMachine);
    1233         AssertComRC(rc);
    1234     }
    12351182
    12361183    return rc;
  • trunk/src/VBox/Main/idl/VirtualBox.xidl

    r31577 r31595  
    15901590    </method>
    15911591
    1592     <method name="createLegacyMachine">
    1593       <desc>
    1594         Creates a new virtual machine in "legacy" mode, using the specified
    1595         settings file to store machine settings.
    1596 
    1597         As opposed to machines created by <link to="#createMachine"/>,
    1598         the settings file of the machine created in "legacy" mode is not
    1599         automatically renamed when the machine name is changed -- it will always
    1600         remain the same as specified in this method call.
    1601 
    1602         The specified settings file name can be absolute (full path) or relative
    1603         to the <link to="IVirtualBox::homeFolder">VirtualBox home
    1604         directory</link>. If the file name doesn't contain an extension, the
    1605         default extension (.xml) will be appended.
    1606 
    1607         Note that the configuration of the newly created machine is not
    1608         saved to disk (and therefore no settings file is created)
    1609         until <link to="IMachine::saveSettings"/> is called. If the
    1610         specified settings file already exists, this method
    1611         will fail with <link to="VBOX_E_FILE_ERROR"/>.
    1612 
    1613         See <link to="#createMachine"/> for more information.
    1614 
    1615         @deprecated This method may be removed later. Use <link
    1616         to="IVirtualBox::createMachine"/> instead.
    1617 
    1618         <note>
    1619           There is no way to change the name of the settings file
    1620           of the machine created in "legacy" mode.
    1621         </note>
    1622 
    1623         <result name="VBOX_E_OBJECT_NOT_FOUND">
    1624           @a osTypeId is invalid.
    1625         </result>
    1626         <result name="VBOX_E_FILE_ERROR">
    1627           @a settingsFile is invalid or the settings file already exists or
    1628           could not be created due to an I/O error.
    1629         </result>
    1630         <result name="E_INVALIDARG">
    1631           @a name or @a settingsFile is empty or @c null.
    1632         </result>
    1633       </desc>
    1634 
    1635       <param name="name" type="wstring" dir="in">
    1636         <desc>Machine name.</desc>
    1637       </param>
    1638       <param name="osTypeId" type="wstring" dir="in">
    1639         <desc>Machine OS Type ID.</desc>
    1640       </param>
    1641       <param name="settingsFile" type="wstring" dir="in">
    1642         <desc>Name of the machine settings file.</desc>
    1643       </param>
    1644       <param name="id" type="uuid" mod="string" dir="in">
    1645         <desc>Machine UUID (optional).</desc>
    1646       </param>
    1647       <param name="machine" type="IMachine" dir="return">
    1648         <desc>Created machine object.</desc>
    1649       </param>
    1650     </method>
    1651 
    16521592    <method name="openMachine">
    16531593      <desc>
     
    16621602        will be used to construct the machine object.
    16631603
    1664         @deprecated Will be removed soon.
    16651604        <result name="VBOX_E_FILE_ERROR">
    16661605          Settings file name invalid, not found or sharing violation.
     
    42934232        at the indicated port and device.
    42944233
    4295         This method is intended for managing storage devices in general (it works
    4296         for both fixed and removable media) while a machine is powered off.
     4234        This method is intended for managing storage devices in general while a
     4235        machine is powered off. It can be used to attach and detach fixed
     4236        and removeable media.
     4237
     4238        Starting with VirtualBox 3.3, media no longer have to be globally
     4239        registered before they can be attached to a virtual machine. For
     4240        compatibility with machines created by older versions of VirtualBox
     4241        and for greater flexibility with managing removable media, media
     4242        can still be registered globally. As a result, there are now
     4243        several variants of attaching media:
     4244
     4245        <ul>
     4246          <li>To directly attach a medium without first registering it
     4247            globally, simply pass the file name of its storage unit in the
     4248            @a medium string parameter. This works for all media formats
     4249            supported by the <li to="VirtualBox::openMedium" /> method.
     4250            The difference is that the medium will not be saved in the
     4251            global media registry, but only with the machine settings
     4252            XML file. For better portability of the machine as a whole,
     4253            it is recommended to place the storage unit in the machine's
     4254            folder as well.
     4255          </li>
     4256
     4257          <li>To attach a medium that has been globally registered using
     4258            <li to="VirtualBox::openMedium" />, call that method with the
     4259            full path of a storage unit. Then, retrieve the UUID of that
     4260            medium from its <link to="IMedium::id" /> attribute and pass
     4261            that UUID into this method. This way, the medium will be
     4262            saved in the global media registry in the VirtualBox.xml
     4263            settings file. This is still the recommended way to manage
     4264            removable media such as ISO and RAW files if they are to be
     4265            used by several virtual machines and the storage unit is not
     4266            located in the machine's directory.
     4267          </li>
     4268
     4269          <li>Only for storage devices supporting removable media (such as
     4270            DVDs and floppies), you can also specify an empty string to
     4271            indicate an empty drive or the UUID of a host DVD or floppy
     4272            drive; those UUIDs can be obtained from <link to="IHost::DVDDrives" />
     4273            and <link to="IHost::floppyDrives"/>.
     4274            For removeable devices, you can also use <link to="IMachine::mountMedium"/>
     4275            to change the media while the machine is running.
     4276          </li>
     4277        </ul>
     4278
    42974279        In a VM's default configuration of virtual machines, the secondary
    42984280        master of the IDE controller is used for a CD/DVD drive.
    4299 
    4300         For fixed media such as hard disks, the given medium identifier cannot
    4301         be a zero UUID.
    4302 
    4303         For storage devices supporting removable media (such as DVDs and floppies),
    4304         you can also use <link to="IMachine::mountMedium"/> for changing the media
    4305         while the machine is running. For those devices, you can also specify
    4306         a zero UUID to indicate an empty drive or the UUID of a host drive;
    4307         see <link to="IMediumAttachment" /> for details.
    43084281
    43094282        After calling this returns successfully, a new instance of
     
    43114284        attachments (see <link to="IMachine::mediumAttachments"/>).
    43124285
     4286        See <link to="IMedium"/> and <link to="IMediumAttachment"/> for more
     4287        information about attaching media.
     4288
    43134289        The specified device slot must not have a device attached to it,
    43144290        or this method will fail.
    43154291
    4316         See <link to="IMedium"/> and <link to="IMediumAttachment"/> for more
    4317         information about attaching media.
    4318 
    43194292        <note>
    4320           You cannot attach a device to a running machine. Also, you cannot
    4321           attach a device to a newly created machine until this machine's
    4322           settings are saved to disk using <link to="#saveSettings"/>.
     4293          You cannot attach a device to a newly created machine until
     4294          this machine's settings are saved to disk using
     4295          <link to="#saveSettings"/>.
    43234296        </note>
    43244297        <note>
     
    43324305
    43334306        <result name="E_INVALIDARG">
    4334           SATA device, SATA port, IDE port or IDE slot out of range.
     4307          SATA device, SATA port, IDE port or IDE slot out of range, or
     4308          file or UUID not found.
    43354309        </result>
    43364310        <result name="VBOX_E_INVALID_OBJECT_STATE">
     
    43634337        <desc>Device type of the attached device.</desc>
    43644338      </param>
    4365       <param name="id" type="uuid" mod="string" dir="in">
    4366         <desc>UUID of the medium to mount. Can be a zero UUID or the UUID of
    4367           a host drive for removeable media; see <link to="IMediumAttachment" />
    4368           for details.</desc>
     4339      <param name="medium" type="wstring" dir="in">
     4340        <desc>Path of the storage unit or UUID of the medium or the UUID of a
     4341          host drive to mount, or an empty string for an empty drive.</desc>
    43694342      </param>
    43704343    </method>
     
    1422514198      <desc>Type of the medium this event relates to.</desc>
    1422614199    </attribute>
    14227    
     14200
    1422814201    <attribute name="registered" type="boolean" readonly="yes">
    1422914202      <desc>
  • trunk/src/VBox/Main/include/VirtualBoxImpl.h

    r31568 r31595  
    119119
    120120    /* IVirtualBox methods */
    121 
    122121    STDMETHOD(CreateMachine) (IN_BSTR aName, IN_BSTR aOsTypeId, IN_BSTR aBaseFolder,
    123122                              IN_BSTR aId, BOOL aOverride, IMachine **aMachine);
    124     STDMETHOD(CreateLegacyMachine) (IN_BSTR aName, IN_BSTR aOsTypeId, IN_BSTR aSettingsFile,
    125                                     IN_BSTR aId, IMachine **aMachine);
    126123    STDMETHOD(OpenMachine) (IN_BSTR aSettingsFile, IMachine **aMachine);
    127124    STDMETHOD(RegisterMachine) (IMachine *aMachine);
Note: See TracChangeset for help on using the changeset viewer.

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