About the Windows Component Wizard
The Windows Component Wizard can be accessed from inside the “Add or Remove Programs” control panel (appwiz.cpl) in Windows XP. On the left hand side of the control panel (in the grey band) is a button to “Add/Remove Windows Components”, which will launch the Windows Components Wizard.
The wizard provides and manages a list Windows components and component groups which can be selected for installation or removal. Each item can be checked or uncheck to control it’s installation status. Once the user has selected the configuration they want, they can click the “Next” button and the wizard will perform all of the chosen installation or removal tasks.
About the Sysoc.inf File
All of the entries which are displayed in the Wizard are contained in the file “sysoc.inf” which is stored under the %WinDir%\INF directory (The INF directory may be hidden on some systems, but you can quickly open it by typing “INF” in the Run box).
Many people who tweak XP will recognize this file, as it has hidden components which are not listed in the Wizard (like Windows Messenger) which can be made visible by editing the entries in this file (and then removed using the wizard).
The file can also be used by the System Stand-Alone Component Manager (SYSOCMGR.EXE) tool which is included with Windows 2000 or higher for the unattended addition or removal of Windows components.
The Sysoc.inf Entries
If you open up the file you will see a bunch of INF code. INF is an installation scripting language which looks much more complicated than it actually is. If you’d like to learn about INF files, MSDN has some good documentation here.
Inside the file will be a [Version] section which we don’t have to worry about. The section we want to look at is [Components]. Those are the entries which form the root listing of the Components Wizard.
Each entry will have the following format:
[Component]=[DLL Name],[DLL Entry Point],[INF File],[hide],[Number]
Component is the internal name which is used to reference the component in the INF files. I’m not 100% sure what the DLL name and entry point are for (probably setup procedures). The INF file is a separate INF which contains the component details and installation script. The hide entry is used to hide the item in the Wizard, or is left empty when the item is visible. I don’t know what the last number is for either, it usually is 7. All of the values are required except ‘hide’.
For example, in the line for Windows Messenger:
msmsgs=msgrocm.dll,OcEntry,msmsgs.inf,hide,7
‘msmsgs’ is the internal name which is used to refer to the component within the INF files. msgrocm.dll and OcEntry are the DLL file and entry point. The next item is the INF file (msmsgs.inf) which contains the component’s information and installation code. The hide entry means it will not show up in the Component Wizard. Finally, there is the number 7.
The Component INF Entries
If you open up one of the component INF files which is referenced in sysoc.inf, you will see INF code which describes the component or group, and the code which is used to install or remove the component.
The first section that is unique is [OptionalComponents]. This section contains all of the internal component names, with the first being the top level option, and all of it’s child components after. I believe this defines the items in a group, but have not confirmed it yet.
The component name used in the sysoc.inf line will be the name of the section which contains the component information. For example, the Windows Messenger line listed above specifies the component name as ‘msmsgs’, That means the messenger component’s information will be found under the [msmsgs] section in the msmsgs.inf file.
Under the component’s section will be several directives. The following directives control what is displayed under the Component Wizard:
OptionDesc |
Display name of the component. |
Tip |
Description of the component. |
Uninstall |
The INF section used to uninstall component. |
InstallType |
Number (Don’t know what it means) |
IconIndex |
Index of icon within a Windows DLL (shell32.dll?) |
Modes |
Comma separated numbers (don’t know) |
SizeApproximation |
Approximate size (in bytes) of installation. |
Parent |
Name of parent group. |
The remaining section lines are standard INF directives which are used for the component’s installation process.
After you look at a couple of the component INF’s you should get a decent idea of how they work. Now we move on to:
Adding Your Own Entries
In order to add your own components you will first need to add a new entry under the [Components] section of sysoc.inf.
WARNING: If you edit the sysoc.inf file incorrectly, it will cause the Windows Components Wizard to crash or close unexpectedly. Make sure you backup the sysoc.inf file (or any others) before you modify them.
You can add your entry anywhere under the [Components] section. Make sure your component name is unique. For the DLL name and entry point you can use “ocgen.dll” and “OcEntry”. Some of the others can cause crashes, but I have used OcEntry many times and have had no problems. It may even be a dummy function call, many other items in sysoc.inf use it. Enter the name of your component’s INF file. You can include your component section within an existing INF file, or create a new one. You can leave the next value empty, or put in “hide” if you want it to be hidden. For the final value put 7.
Here’s an example of a custom component sysoc entry to install the Visual Basic 1.0 runtime library:
[Components]
vbrun10=ogen.dll,OcEntry,vbrun10.inf,,7
After that you will need to create your component’s section in the specified INF file and set it’s options. If you are creating a new INF file for your component you will need to also have the [Versions] section with the Signature=”$WINDOWS NT$” directive as a minimum. You should be able to test it in the wizard at this point to see how it looks. The final steps will be to write the installation code and make sure it all works.
For our example component, here’s the INF:
[Version]
Signature = $WINDOWS NT$
[DestinationDirs]
1=
[vbrun10]
OptionDesc = %CAPTION%
Tip = %INFO%
Uninstall = vbrun10_uninstall
IconIndex = 34
Modes = 0,1,2,3
SizeApproximation = 151552
CopyFiles = vbrun10_copyfiles
[vbrun10_copyfiles]
vbrun10.dll,,,
[vbrun10_uninstall]
DelFiles
[Strings]
CAPTION = "Visual Basic 1.0 Runtime"
INFO = "Allows you to run Visual Basic 1.0 applications."