Microsoft KB Archive/152392

= You receive an "Unable to import OLE control" error message when you try to import an ActiveX control =

Article ID: 152392

Article Last Modified on 6/2/2005

-

APPLIES TO


 * Microsoft Visual C++ 4.0 Standard Edition
 * Microsoft Visual C++ 4.1 Subscription
 * Microsoft Visual C++ 5.0 Enterprise Edition
 * Microsoft Visual C++ 6.0 Enterprise Edition
 * Microsoft Visual C++ 5.0 Professional Edition
 * Microsoft Visual C++ 6.0 Professional Edition
 * Microsoft Visual C++ 6.0 Standard Edition

-



This article was previously published under Q152392



SYMPTOMS
Microsoft Developer Studio with Visual C++, versions 4.0 and 4.1, reports the error message:

Unable to import OLE control.

Make sure the control contains a valid type library" when attempting to import an ActiveX control (OLE control).

In Visual C++, version 4.2, the error states:

The OLE control is not registered properly or its type library version is incorrect.

In Visual C++, versions 5.0 and 6.0, the error states:

Unable to open this ActiveX Control. Make sure the control contains a valid type library.



CAUSE
By default, MFC applications use ID binding to call methods in ActiveX controls. Because of this behavior, Developer Studio checks to make sure that the version of the type library is the same as that of the control. If the versions are not the same, Developer Studio reports an error.

This error is usually caused by incrementing the version of the ActiveX Control but not the version of the type library.

For more information on ID binding, please see the following article in the Microsoft Knowledge Base:

138138 Three Binding Types (Late, ID, Early) Possible in VB for Apps



RESOLUTION
Make sure that the version of the ActiveX control matches the version of its type library.

In an MFC control, the version of the control is represented by constants found in the implementation file for the OLE control class:   const WORD _wVerMajor = 1; const WORD _wVerMinor = 0; In the same project, the version for the type library is represented by the version keyword in the .odl file for the OLE control: [ uuid(AFCDB500-BB23-11CF-A685-00AA00A70FC2), version(1.0), helpstring("VersionTest OLE Control module"), control ]



STATUS
This behavior is by design.



MORE INFORMATION
An updated version of this control would have version identifiers similar to the following: const WORD _wVerMajor = 2; const WORD _wVerMinor = 4;

[ uuid(AFCDB500-BB23-11CF-A685-00AA00A70FC2), version(2.4), helpstring("VersionTest OLE Control module"), control ]

Additional query words: import control MfcOLE CDKIss VWBIss

Keywords: kberrmsg kbtshoot kbide kbprb kbctrl KB152392

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.