如何从IMAPI2使用IFileSystemImage2的put_BootImageOptionsArray(获取E_NOINTERFACE)?

时间:2013-05-17 11:23:52

标签: c++ windows com imapi

我正在尝试使用IFileSystemImage2接口使用Imapi2创建具有多个启动记录的ISO。

为此,我应该能够使用put_BootImageOptionsArray传递SAFEARRAY* VT_DISPATCH类型的IBootOptions,即每个启动选项配置的IBootOptions类型的COM指针。作为一个简短的演示,我有以下代码(在这种情况下我只创建了一个SAFEARRAYBOUND bounds[1]; bounds[0].cElements = 1; bounds[1].lLbound = 0; IBootOptions* BootOptionsArrayData = NULL; SAFEARRAY* Array = SafeArrayCreateEx(VT_DISPATCH, 1, bounds, (void*) &IID_IBootOptions); hr = SafeArrayAccessData(Array, reinterpret_cast<void**>(&BootOptionsArrayData)); BootOptionsArrayData = BootOptions; // BootOptions = IBootOptions* hr = SafeArrayUnaccessData(Array); hr = IsoImage->put_BootImageOptionsArray(Array); ):

put_BootImageOptionsArray

但是,每次拨打E_NOINTERFACE时,我都会返回hr = CoCreateInstance(CLSID_MsftFileSystemImage, NULL, CLSCTX_ALL, __uuidof(IFileSystemImage2), (void**) &IsoImage);

正在按照您的期望创建IsoImage:

IFileSystemImage2

使用IFileSystemImage来自CoCreateInstance的任何继承功能都可以。同样,我可以IFileSystemImage代替CMsftFileSystemImage::put_BootOptionsArray,并且可以正常使用此界面。

我已经在WinDbg中附加了我的进程并在{{1}}中设置了一个断点,但是,这个函数(底层实现)根本就没有被调用。

因此,我的问题很简单:实现似乎存在,但我似乎无法调用它。有没有人有使用这一特定功能的经验,如果是这样,你是如何让它工作的?

1 个答案:

答案 0 :(得分:2)

SAFEARRAY的documentation stipulates必须是包含IDispatch接口指针的VARIANT数组,所以你可以这样做(我使用的智能指针更容易......):

CComPtr<IFileSystemImage2> image;
CComPtr<IBootOptions> options;

image.CoCreateInstance(CLSID_MsftFileSystemImage);
options.CoCreateInstance(CLSID_BootOptions);

// set various options here...
options->put_Manufacturer(CComBSTR(L"joe"));

// create a SAFEARRAY of VARIANT
CComSafeArray<VARIANT> a(1);

// create a VARIANT of type VT_UNKNONW (or VT_DISPATCH)
CComVariant v(options);

// put it in the array
a.SetAt(0, v);

HRESULT hr = pImage->put_BootImageOptionsArray(a.m_psa);