Click or drag to resize

GetIVisaSessionPointer

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

virtual HRESULT GetIVisaSessionPointer(IVisaSession** ppVisaSession) override;
Parameters
ppVisaSession

[out] IVisaSession pointer.

Return Value

Returns S_OK if successful, otherwise a failure HRESULT.

Remarks

This function returns an IVisaSession 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 IVisaSession 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.

Caution note Caution

The pointer returned by this function is a referenced-counted COM interface pointer. Calling this function increments that reference count, so it is critical that the caller receiving the pointer properly call Release on the interface pointer. If the pointer is passed out of the driver to a client application, then it is the responsibility of the client application to properly release the pointer. Failure to properly manage this interface pointer will cause the entire VISA-COM I/O session to leak memory.

Example

The following example demonstrates use of the GetIVisaSessionPointer function.

C++
// CoAcme4321.cpp
HRESULT Acme4321::OnFinalInitialize()
{
  HRESULT hr = S_OK;

  CComPtr<IVisaSession> spSession;
  hr = io.DirectIo.GetIVisaSessionPointer(&spSession);

  // Note that the CComPtr smart pointer class automatically calls release when the function exits

  return hr;
}

Download a complete CHM version of this documentation here.