Hide

SftDirectory 3.5 - ActiveX File/Folder Control

Display
Print

Distributing SftDirectory

This section describes the preferred distribution method when shipping SftDirectory with your application. This method follows Microsoft's guidelines on ActiveX control distribution. While these guidelines are not enforced, it is highly recommended that they are followed as outlined here. This insures that your application can be safely installed and use SftDirectory even if another vendor has already installed an application which also uses SftDirectory.

SftDirectory is not supported on Windows 95, 98, ME or Windows NT 4.0. Supported platforms include Windows 2000 through Windows 10 and their server editions.

Installing SftDirectory (for an Application)

When distributing SftDirectory with your application, only the following files can be distributed with your application royalty-free. These files allow the use of the control with your application. The design-time interface is no longer available once SftDirectory is shipped with your application. For additional information regarding distributing this control with your application, see the license agreement.

Required Files

Important: Redistributable files are located in the SftDirectory installation directory (\Program Files\Softelvdm\SftDirectory 3.5\Redist).

These files must be shipped with your application if SftDirectory is used:

File NameTarget FolderDescription
SftDirectory_IX86_U_35.ocxSee Control Target Directory belowRequired for 32-bit applications. SftDirectory control. When distributing a managed .NET application compiled for "Any CPU", the 32-bit and 64-bit control must be distributed.
SftDirectory_x64_U_35.ocxSee Control Target Directory belowRequired for 64-bit applications. SftDirectory control. When distributing a managed .NET application compiled for "Any CPU", the 32-bit and 64-bit controls must be distributed.
SftDirectoryMUISupport_IX86_U_35.ocxSee Control Target Directory belowRequired for 32-bit applications on Windows Vista and up. SftDirectory control. It can optionally be installed on Windows 2000, XP, Server 2003, but is only used on Windows Vista and above. When distributing a managed .NET application compiled for "Any CPU", the 32-bit and 64-bit control must be distributed.
SftDirectoryMUISupport_x64_U_35.ocxSee Control Target Directory belowRequired for 64-bit applications on Windows Vista and up. SftDirectory control. It can optionally be installed on Windows 2000, XP, Server 2003, but is only used on Windows Vista and above. When distributing a managed .NET application compiled for "Any CPU", the 32-bit and 64-bit control must be distributed.
Softelvdm.OCXHelperV2.dllSee SftHelperComponent Target Directory belowRequired for .NET 2.0 and above ONLY. This .NET component is required when distributing managed .NET applications. It is not used for other (unmanaged) languages, like VC++, VB6, etc. This file requires the .NET 2.0 runtime (or newer). If your application uses the 2.0 runtime (or newer), this file needs to be distributed with your application.
Softelvdm.OCXHelper.dllSee SftHelperComponent Target Directory belowRequired for .NET 1.x ONLY. This .NET component is required when distributing a managed .NET applications which requires the .NET 1.x runtime. It is not used for other (unmanaged) languages, like VC++, VB6, etc. If your application uses the 1.x runtime, this file needs to be distributed with your application.
Softelvdm.NETHelper.dllApplication FolderRequired for .NET 4.0 and above ONLY - Applications compiled for "Any CPU" or "x86". This dll is required when distributing managed .NET applications. It is not used for other (unmanaged) languages, like VC++, VB6, etc. This file is required if your application uses the .NET 4.0 runtime or newer and is compiled for "Any CPU" or "x86". If your application is compiled for "Any CPU" you will need both Softelvdm.NETHelper.dll and Softelvdm.NETHelper_x64.dll. If your application uses the 2.0 runtime or is compiled for "x86", this file can optionally be distributed with your application, but it is not required.
Softelvdm.NETHelper_x64.dllApplication FolderRequired for .NET 4.0 and above ONLY - Applications compiled for "Any CPU" or "x64". This dll is required when distributing managed .NET applications. It is not used for other (unmanaged) languages, like VC++, VB6, etc. This file is required if your application uses the .NET 4.0 runtime or newer and is compiled for "Any CPU" or "x64". If your application is compiled for "Any CPU" you will need both Softelvdm.NETHelper.dll and Softelvdm.NETHelper_x64.dll. If your application uses the 2.0 runtime or is compiled for "x86", this file can optionally be distributed with your application, but it is not required.
Oleaut32.dll\Windows\System32 or \Windows\SysWow64Required. OLE support. While normally present, the installation must insure that the current version is installed. This file is also needed by the container (VB, VC++, etc.) to support OLE and any ActiveX control.
Olepro32.dll\Windows\System32 or \Windows\SysWow64Required. OLE property and standard types support. While normally present, the installation must insure that the current version is installed. This file is also needed by the container (VB, VC++, etc.) to support OLE and any ActiveX control.
Stdole2.tlb\Windows\System32 or \Windows\SysWow64Required. OLE support. While normally present, the installation must insure that the current version is installed. This file is also needed by the container (VB, VC++, etc.) to support OLE and any ActiveX control.
Asycfilt.dll\Windows\System32 or \Windows\SysWow64Required. OLE support. While normally present, the installation must insure that the current version is installed. This file is also needed by the container (VB, VC++, etc.) to support OLE and any ActiveX control.
Comcat.dll\Windows\System32 or \Windows\SysWow64Required. OLE support. While normally present, the installation must insure that the current version is installed. This file is also needed by the container (VB, VC++, etc.) to support OLE and any ActiveX control.
ShFolder.dll\Windows\System32 or \Windows\SysWow64Optional. Depending on CSIDL values (SftDirectorySpecialFolderConstants) used, this file may be required if CSIDL values are used on earlier Windows systems, which don't natively support these.
Regsvr32.exeAnyOptional. Control registration utility, for "manual" registration. Not needed with most commercial Setup creation tools.

Control Target Directory

Depending on the target operating systems, one of the following target directories can be chosen.

A) Windows\System(32)

Installing the ActiveX control into the Windows\System(32) directory (or Windows\SysWOW64 for 32-bit controls on Windows x64) is possible on all supported Windows platforms.

The setup program you provide with your application should install the SftDirectory control SftDirectory_IX86_U_35.ocx into the Windows System directory. The Windows System directory name can be found using the GetSystemDirectory API function. All other files shown in the above tables also have to be installed into the Windows System directory. It is usually named C:\Windows\System32 (or Windows\SysWow64 for 32-bit controls on Windows x64).

The control is installed into the Windows/System(32) directory and registered using proper versioning and reference counting of the OCX file (usually automatic, with most commercial installers).

B) Application Directory

An ActiveX control can be installed in the application directory using DLL/COM redirection, which is available on Windows 2000, 98SE and better only.

DLL/COM redirection is activated on an application-by-application basis by the presence of a ".local" file. The ".local" file is an empty file in the same directory as the application's .exe file, with the same name as the application's .exe file with ".local" appended to the end of the name.

For example, to activate DLL/COM redirection for an application called "SampleApp.exe", create an empty file called "SampleApp.exe.local" in the same directory where SampleApp.exe is installed.

On Windows XP or better, "Registration-Free Activation" (see below) can be used, which eliminates the need for the ".local" file.

Once DLL/COM redirection is activated, whenever the application loads a DLL or an OCX, Windows looks first for the DLL or OCX in the directory where the application's .exe file is installed. If a version of the DLL or OCX is found in the directory where the application's .exe file is installed, the application uses it regardless of any directory path specified in the application or the registry. If a version of the DLL or OCX is not found in the directory where the application's .exe file is installed, the normal search path or server path is used.

Even if DLL/COM redirection is used, the control must be registered during installation (see "Registering SftDirectory" below). The control must be installed into the Windows/System(32) directory and registered using proper versioning and reference counting of the OCX file (usually automatic, with most commercial installers). In addition, a private copy in your application directory is always installed (but not registered), along with the application's ".local" file.

SftHelperComponent Target Directory

The SftHelperComponent (see "Using SftDirectory with .NET") is used by .NET applications. Earlier releases of SftDirectory required this component to be registered using Regasm.exe for COM Interop. This is no longer required. Simply copy the file Softelvdm.OCXHelperV2.dll (or Softelvdm.OCXHelper.dll) to one of the following locations. They are listed in the order they are searched.

Softelvdm.OCXHelperV2.dll:

  • Same folder where the ActiveX control is installed (see Control Target Directory above)
  • \Program Files\Common Files\Softelvdm\Softelvdm.Controls or \Program Files (x86)\Common Files\Softelvdm\Softelvdm.Controls (32-bit applications on 64-bit Windows versions only)
  • \Windows\System32 \Windows\SysWow64 (32-bit applications on 64-bit Windows versions only)

Softelvdm.OCXHelper.dll:

  • Same folder where the ActiveX control is installed (see Control Target Directory above)
  • \Program Files\Common Files\Softelvdm\Softelvdm.Controls or \Program Files (x86)\Common Files\Softelvdm\Softelvdm.Controls (32-bit applications on 64-bit Windows versions only)
  • \Windows\System32 \Windows\SysWow64 (32-bit applications on 64-bit Windows versions only)

The actual path (\Program Files or \Windows) may differ due to localization.

Version Control

The setup program should only install the SftDirectory files if the version number in the new files is higher than the files already installed. Maintenance releases and new versions of the product are fully upward compatible and are guaranteed to have a newer version number. New versions of the product will use new file names and new GUIDs so there will be no conflict between different (major) versions, such as 2.0 and 2.5.

Reference Counting

When installing DLLs or OCX files into a "shared" location, such as the Windows\System(32) directory, proper reference counting must be performed, to insure that the file isn't uninstalled until all applications making use of the DLL or OCX have also been uninstalled. Reference counting is generally available with most commercial installers. The Windows Registry contains a count of all such shared files in the following Registry location:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\SharedDLLs

Registering SftDirectory

Depending on the target operating systems, one of the following ActiveX/COM registration methods can be selected.

A) Windows Registry

Registering the ActiveX control in the Windows Registry is possible on all supported Windows platforms.

The setup program should register SftDirectory in the Windows registration database (Registry). This can be done manually using Regsvr32.exe which is discouraged. Many commercially available setup programs can register SftDirectory during the installation of your application. Please keep in mind that 64-bit versions of Windows have two versions of RegSvr32.exe. \Windows\System32\RegSvr32.exe is used to register 64-bit controls and \Windows\SysWOW64\RegSvr32.exe is used to register 32-bit controls. On Windows Vista and above, RegSvr32.exe must be run with elevated privileges as administrator.

SftDirectory is a self-registering ActiveX control. By using the LoadLibrary Windows API function, the GetProcAddress API can be used to obtain the DllRegisterServer function. By calling this function, the SftDirectory control will register itself with the Windows registration database (Registry). Most commercially available setup programs have support for this built-in. Check the documentation of your setup application for information on how to install ActiveX controls. Please keep in mind that an application using the LoadLibrary API can only load the control of the same machine type, meaning a 32-bit application can only load and register 32-bit controls, a 64-bit application can only load 64-bit controls.

The following files need to be registered in this manner:

File NameDescription
SftDirectory_IX86_U_35.ocxRequired for 32-bit applications. SftDirectory control
SftDirectory_x64_U_35.ocxRequired for 64-bit applications. SftDirectory control
Comcat.dllOLE support
Oleaut32.dllOLE support
Olepro32.dllOLE support

B) Registration-Free Activation

On Windows XP and better it is possible to deploy this ActiveX control using "Registration-Free Activation". Registration-free activation allows distribution of the control without the requirement to register the ActiveX control in the Windows Registry (using REGSVR32 or a Setup application). Registration-free activation is supported by the operating system, so the .NET run-time is not required for registration-free activation.

By using registration-free activation, true XCOPY deployment is possible. Your application uses its own copy of the control. Versioning, reference counting and registration of the control are completely eliminated and other installed versions of the control cannot interfere with your application.

By using an application manifest and copying the OCX file SftDirectory_IX86_U_35.ocx into your application directory, the ActiveX control is automatically registered when it is used the first time. Your application manifest must include the comClass and typelib definitions shown below. These insure that you application automatically registers the control and uses the control located in your application directory, regardless of any other controls or other versions of the same control already installed or in use.

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
    <assemblyIdentity version="3.5.0.0" processorArchitecture="x86" name="SoftelvdmInc.SftDirectory35.Sample.exe" type="win32" />
    <description>SftDirectory Sample Application</description>
    <dependency>
        <dependentAssembly>
            <assemblyIdentity type="win32" name="Microsoft.Windows.Common-Controls" version="6.0.0.0"
            processorArchitecture="x86" publicKeyToken="6595b64144ccf1df" language="*" />
        </dependentAssembly>
    </dependency>
    <file name="SftDirectory_IX86_U_35.ocx">
        <comClass description="SftDirectory Control" clsid="{4CFACA84-AA04-421F-97AF-5A46A5F5C697}"
        threadingModel = "Apartment"
        miscStatus="setclientsitefirst,alignable,activatewhenvisible,insideout,cantlinkinside,recomposeonresize"
        progid="SftDirectory35.SftDirectory.2" tlbid = "{5D4DD600-A491-4f1c-9768-EE878F77EF2E}"/>
        <typelib tlbid="{4CFACA80-AA04-421F-97AF-5A46A5F5C697}" version="3.5" helpdir=""/>
    </file>
</assembly>

Testing a Setup Program

If you test the installation of your application's Setup program on a system where the development version of SftDirectory is installed, you may notice that you can no longer use SftDirectory in your development environment. This is caused by the fact that your Setup program installed a "run-time only" control on your system, which has replaced the "design-time" or development version of SftDirectory. You can reinstate (or re-register) the design-time version of SftDirectory by using the program entry 'Maintenance, Register SftDirectory in Windows Registry' in the SftDirectory 3.5 program group.


Last Updated 08/13/2020 - (email)
© 2024 Softel vdm, Inc.