HRESULT Close(void)
Frees resources associated with the COM Object.
Dim lib
Dim host
Dim vm
Dim err
Dim results
Dim job
Set lib = CreateObject("VixCOM.VixLib")
' Connect to the local installation of Workstation. This also initializes the VIX API.
Set job = lib.Connect(VixCOM.Constants.VIX_API_VERSION, VixCOM.Constants.VIX_SERVICEPROVIDER_VMWARE_WORKSTATION, Empty, 0, Empty, Empty, 0, Nothing, Nothing)
' results needs to be initialized before it's used, even if it's just going to be overwritten.
Set results = Nothing
' Wait waits until the job started by an asynchronous function call has finished. It also
' can be used to get various properties from the job. The first argument is an array
' of VIX property IDs that specify the properties requested. When Wait returns, the
' second argument will be set to an array that holds the values for those properties,
' one for each ID requested.
err = job.Wait(Array(VixCOM.Constants.VIX_PROPERTY_JOB_RESULT_HANDLE), results)
If lib.ErrorIndicatesFailure(err) Then
' Handle the error...
End If
' The job result handle will be first element in the results array.
Set host = results(0)
' Open the virtual machine with the given .vmx file.
Set job = host.OpenVM("c:\\Virtual Machines\\vm1\\win2000.vmx", Nothing)
err = job.Wait(Array(VixCOM.Constants.VIX_PROPERTY_JOB_RESULT_HANDLE), results)
If lib.ErrorIndicatesFailure(err) Then
' Handle the error...
End If
Set vm = results(0)
'Execute other commands here
Set results = Nothing
Set job = Nothing
Set vm = Nothing
host.Disconnect()
C#:
class Program
{
static void Main(string[] args)
{
VixCOM.VixLibClass lib = new VixCOM.VixLibClass();
UInt64 err;
object results = null;
VixCOM.IJob job = lib.Connect(VixCOM.Constants.VIX_API_VERSION,
VixCOM.Constants.VIX_SERVICEPROVIDER_VMWARE_WORKSTATION,
null,
0,
null,
null,
0,
null,
null);
err = job.Wait(new int[] { VixCOM.Constants.VIX_PROPERTY_JOB_RESULT_HANDLE },
ref results);
if (lib.ErrorIndicatesFailure(err)) {
// Handle the error...
}
VixCOM.IHost host = (VixCOM.IHost)((object[])results)[0];
CloseVixObject(job);
job = host.OpenVM("c:\\Virtual Machines\\vm1\\win2000.vmx", null);
err = job.Wait(new int[] { VixCOM.Constants.VIX_PROPERTY_JOB_RESULT_HANDLE },
ref results);
if (lib.ErrorIndicatesFailure(err)) {
// Handle the error...
}
VixCOM.IVM2 vm = (VixCOM.IVM2)((object[])results)[0];
CloseVixObject(job);
// ...Do everything in your program...
CloseVixObject(vm);
host.Disconnect();
}
static void CloseVixObject(Object vixObject)
{
try
{
((IVixHandle2)vixObject).Close();
}
catch(Exception)
{
//Close is not supported in this version of Vix COM - Ignore
}
}
}