|
Support
ActiveX / COM
Visual C++ / MFC
Customer Spotlight
Corporate Partners
Contact Sales
Call center available M-F 9:00 - 6:00 US Eastern Time. U.S. and Canada International Email |
A Guide To MSDN Integration (Visual Studio 6.0)
Author: Kirk Stowell
Posted: November 16, 2004
Environment: Visual C++ MFC
If you are like me, the lack of documentation can be quite frustrating. It's not enough that you have spent hundreds of hours building your code and polishing your application. Now you have to search endlessly trying to find the answer to a question that should already be documented...somewhere...but is not! That is what I ran into when trying to integrate HTML Help with the MSDN Collection. I finally figured this one out after endless hours of research. Hopefully my frustration and research will benefit those of you who are looking for help with this topic. Getting StartedMSDN stores information about the HTML help files that it will use in what is known as a "collection". A collection is an XML formatted file that contains information about each help file to be used with MSDN. There are two files that the collection uses, msdnxxx.col and hhcolreg.dat. The msdnxxx.col file is the actual collection. This contains a list of all of the html help titles that are to be used with the collection. The name of this file typically begins with "msdn" and ends in ".col". The October 2000 collection file name is MSDN030.COL. The hhcolreg.dat file is the collection's registry. This file stores specific details about each collection title such as the location of the HTML help, index files, and version number. The first thing we will need to do is locate both of these files.
Locating the msdnxxx.col fileWe will need to look in the system registry to find the location of the msdnxxx.col file, you can use regedit for this. If you have the MSDN Library installed you will find the following key:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\HTML Help Collections\Developer Collections This is where Microsoft stores the location of its help collections. Under this key you will notice an entry for Language. The value for this key specifies which language the collection is using. A typical value would be 0x0409 for English, but may vary depending on your language settings. The next key you will find is Preferred. This value tells us which collection is currently the preferred collection for use by MSDN. A typical value for this would be 0x039a24110 but may also vary. Under this key we will find an entry for Filename. This value is the actual location on your hard drive where the msdnxxx.col file is located. Locating the hhcolreg.dat file
The next file we need to be concerned with is hhcolreg.dat.
Like the collection file, this also is a XML formatted file and
contains specific information about your integrated help files. In
older releases of the MSDN Library, this file was located in the Windows\Help
directory. In later releases this has been moved to .\Documents
and Settings\All Users\Application Data\Microsoft\HTML Help\.
Beginning with version 4.71 of the shell32.dll we can make a call Editing the collection file
Now that we have located both the msdnxxx.col and hhcolreg.dat
files, we need to examine these files in order to integrate our
data correctly. The first file we are going to look at is the
msdnxxx.col file. Using a text editor, open this file. You will
see two tags at the beginning of the file
<masterlangid value=1033/><collectionnum value=10001/>
Each entry in the collection will begin with a Here is what a typical collection entry might look like:
<Folder> <TitleString value="Codejock Software"/> <FolderOrder value=2/> <Folder> <TitleString value="=xtreme_toolkit"/> <FolderOrder value=1/> <LangId value=1033/> </Folder> </Folder> Editing the registry file
Next we are going to update the hhcolreg.dat file. Open the
file with a text editor. You will notice that each entry begins
with a Here is what a typical registry entry might look like:
<DocCompilation> <DocCompId value="xtreme_toolkit"/> <DocCompLanguage value=1033/> <LocationHistory> <ColNum value=10001/> <TitleLocation value="[full path]Xtreme.chm"/> <IndexLocation value="[full path]Xtreme.chi"/> <LocationRef value=""/> <Version value=2/> </LocationHistory> </DocCompilation> Getting it all to work
You will need to generate a .chi index and a binary table of
contents when you compile your HTML help file. Both are
requirements for use with MSDN collections. To do this, you will
need to add "Create CHI file=Yes" and "Binary
TOC=Yes" to your .hhp file under the Tools for creating HTML help
Before you begin the journey into MSDN integration, first you
will need to create your HTML help files. In order to do this you
must have HTML Help Workshop installed on your machine. This
program is what will compile your HTML files into a .chm file.
This program is free and can be downloaded from Microsoft.
The MSDN Integration UtilityWell if after all of that if you are completely confused, don't worry, we have an Ace up our sleeves...the MSDN Collection Integration Utility! This program will actually integrate your HTML help files for you! Browse to the location of your .chm and .chi files, supply the title string to be used in the collection, and define a unique identifier to be used for your help files. You can use any string you desire for the unique id, however the safest approach would be to use a GUID to ensure uniqueness. You can create one automatically by pressing the "Gen. GUID" button. You also have the option to set the version label for your help as well. Once you have defined the required fields, the utility will take care of the rest by pressing the "Integrate with MSDN collection" button!
You can download the executable and the complete project source
code. All of the integration code has been encapsulated into a
single class ...enjoy! |

