Skip to content

GetIAsyncMessagePointer

Retrieves an IAsyncMessage pointer from the VISA-COM I/O session.

virtual HRESULT GetIAsyncMessagePointer(IAsyncMessage** ppAsyncMessage) override;

ppAsyncMessage

[out] IAsyncMessage pointer.

Returns S_OK if successful, otherwise a failure HRESULT.

This function returns an IAsyncMessage pointer to the current VISA-COM I/O session. This can be useful for accessing VISA-COM functionality not directly exposed in the Nimbus Template Library. Also, the IAsyncMessage pointer can be passed out of the driver to the client application so that end users can directly manipulate aspects of the I/O session.

The following example demonstrates use of the GetIAsyncMessagePointer function.

CoAcme4321.cpp
HRESULT Acme4321::OnFinalInitialize()
{
HRESULT hr = S_OK;
CComPtr<IAsyncMessage> spAsyncMessage;
hr = io.DirectIo.GetIAsyncMessagePointer(&spAsyncMessage);
// Note that the CComPtr smart pointer class automatically calls release when the function exits
return hr;
}