Index   Commented   Search   About

PARAM.CPP (BROWSEH OLE Sample)

/*************************************************************************

  • OLE Automation TypeLibrary Browse Helper Sample

  • param.cpp

  • CParameter implementation

  • Written by Microsoft Product Support Services, Windows Developer Support

  • (c) Copyright Microsoft Corp. 1994 All Rights Reserved

  • ***********************************************************************/

#include <windows.h>

#include <windowsx.h>

#ifdef WIN16

#include <ole2.h>

#include <compobj.h>

#include <dispatch.h>

#include <variant.h>

#include <olenls.h>

#endif

#include "browseh.h"

/*

* CParameter::Create

*

* Purpose:

* Creates an instance of the Parameter automation object and initializes it.

*

* Parameters:

* ptinfo TypeInfo in which the function of this parameter is contained.

* bstrName Name of parameter

* ptypedesc Type of parameter.

* pidldesc IDLDESC of parameter.

* ppParameter Returns Parameter automation object.

*

* Return Value:

* HRESULT

*

*/

HRESULT

CParameter::Create(LPTYPEINFO ptinfo, BSTR bstrName, TYPEDESC FAR* ptypedesc,

IDLDESC FAR* pidldesc, CParameter FAR* FAR* ppParameter)

{

HRESULT hr;

CParameter FAR* pParameter = NULL;

CTypeDesc FAR* pTypeDesc = NULL;

*ppParameter = NULL;

// Create object.

pParameter = new CParameter();

if (pParameter == NULL)

{

hr = ResultFromScode(E_OUTOFMEMORY);

goto error;

}

// Load type information for the object from type library.

hr = pParameter->LoadTypeInfo(IID_IParameter);

if (FAILED(hr))

goto error;

pParameter->m_bstrName = SysAllocString(bstrName);

// Parameter type.

hr = CTypeDesc::Create(ptinfo, ptypedesc, &pTypeDesc);

if (FAILED(hr))

goto error;

pTypeDesc->QueryInterface(IID_IDispatch, (LPVOID FAR*)&pParameter->m_pdispTypeDesc);

pParameter->m_wIDLFlags = pidldesc->wIDLFlags;

#ifdef _DEBUG

lstrcpyn(pParameter->m_szClassName, TEXT("Parameter"), 100);

#endif

*ppParameter = pParameter;

return NOERROR;

error:

if (pParameter == NULL) return ResultFromScode(E_OUTOFMEMORY);

delete pParameter;

return hr;

}

/*

* CParameter::CParameter

*

* Purpose:

* Constructor for CParameter object. Initializes members to NULL.

*

*/

CParameter::CParameter()

{

m_bstrName = NULL;

m_pdispTypeDesc = NULL;

}

/*

* CParameter::~CParameter

*

* Purpose:

* Destructor for CParameter object.

*

*/

CParameter::~CParameter()

{

if (m_bstrName) SysFreeString(m_bstrName);

if (m_pdispTypeDesc) m_pdispTypeDesc->Release();

}

STDMETHODIMP_(REFCLSID)

CParameter::GetInterfaceID()

{

return IID_IParameter;

}

STDMETHODIMP_(BSTR)

CParameter::get_Name()

{

return SysAllocString(m_bstrName);

}

STDMETHODIMP_(ITypeDesc FAR*)

CParameter::get_Type()

{

m_pdispTypeDesc->AddRef();

return (ITypeDesc FAR*)m_pdispTypeDesc;

}

STDMETHODIMP_(int)

CParameter::get_IDLFlags()

{

return (int)m_wIDLFlags;

}

STDMETHODIMP_(OBJTYPE)

CParameter::get_Kind()

{

return TYPE_PARAMETER;

}

Related Links

Software for Delphi and C++ Builder developers
Software for Visual Studio .NET developers
Software for Visual Basic 6 developers
Delphi Tips&Tricks
MegaDetailed.NET
TMS Scripter Studio Pro components for Delphi/C++Builder

More Online Helps

Win32 Programmer's Reference (win32.hlp)
Win32 Multimedia Programmer's Reference (mmedia.hlp)
Microsoft Windows Pen API Programmer's Reference (penapi.hlp)
Microsoft Windows Sockets 2 Reference (sock2.hlp)
Microsoft Windows Telephony API (TAPI) Programmer's Reference (sock2.hlp)
Unix Manual Pages

Free Tech Secrets ;) Copyright © 2008 Free Tect Secrets ;) greatis just4fun network just4fun