Registering a Custom File Type
This article describes how the Filter Graph Manager locates a source filter, given a file name. You can use this mechanism to register your own custom file types. Once the file type is registered, DirectShow will automatically load the correct source filter whenever an application calls IGraphBuilder::RenderFile or IGraphBuilder::AddSourceFilter.
To locate a source filter from a given file name, the Filter Graph Manager attempts to do the following, in order:
Match the protocol, if any.
Match the file extension.
Match patterns of bytes within the file, called check bytes.
Protocols
Protocol names such as ftp or http are registered under the HKEY_CLASSES_ROOT key, with the following structure:
HKEY_CLASSES_ROOT
<protocol>
Source Filter = <Source filter CLSID>
Extensions
<.ext1> = <Source filter CLSID>
<.ext2> = <Source filter CLSID>
If the file name contains a colon (':'), the Filter Graph Manager attempts to use the portion before the ':' as a protocol name. For example, if the name is "myprot://myfile.ext", it searches for a registry key named myprot. If this key exists and contains a subkey named Extensions, the Filter Graph Manager searches within that subkey for entries that match the file extension. The value of the key must be a GUID in string form; for example, "{00000000-0000-0000-0000-000000000000}". If the Filter Graph Manager cannot match anything within the Extensions subkey, it looks for a subkey named Source Filter, which must also be a GUID in string form.
If the Filter Graph Manager finds a matching GUID, it uses this as the CLSID of the source filter, and attempts to load the filter. If it does not find a match, it uses the File Source (URL) filter, which treats the file name as a URL.
There are two exceptions to this algorithm:
To exclude driver letters, single-character strings are not considered protocols.
If the string is "file:" or "file://", it is not treated as a protocol.
File Extensions
If there is no protocol in the file name, the Filter Graph Manager looks in the registry for entries with the key HKEY_CLASSES_ROOT\Media Type\Extensions\.ext\, where .ext is the file extension. If this key exists, the value Source Filter contains the CLSID of the source filter, in string form. Optionally, the key can have values for Media Type and Subtype, which give the major type and subtype GUIDs.
Check Bytes
Some file types can be identified by specific patterns of bits occurring at specific byte offsets in the file. The Filter Graph Manager looks in the registry for keys with the following form:
HKEY_CLASSES_ROOT\MediaType\{major type}\{subtype}
where major type and subtype are GUIDs that define the media type for the byte stream. Each key contains one or more subkeys, usually named 1, 2, and so on, which define the check bytes; and a subkey named Source Filter that gives the CLSID of the source filter, in string form. The check-byte subkeys are strings that contain one or more quads of numbers:
offset,cb,mask,val
To match the file, the Filter Graph Manager reads cb bytes, starting from byte number offset. It then performs a bitwise-AND against the value in mask. If the result equals val, the file is a match for that quad. The values mask and val are given in hex. A blank entry for mask is treated as a string of 1s of length cb. A negative value for offset indicates an offset from the end of the file. In order to match the key, the file must match all of the quads in any of the subkeys.
For example, assume the registry contains the following keys under HKCR\Media Type:
{e436eb83-524f-11ce-9f53-0020af0ba770}
{7364696D-0000-0010-8000-00AA00389B71}
0 "0,4,,52494646,8,4,,524D4944"
1 "0,4,,4D546864"
Source Filter "{E436EBB5-524F-11CE-9F53-0020AF0BA770}"
The first key corresponds to the major type MEDIATYPE_Stream. The subkey below that corresponds to the subtype MEDIATYPE_Midi. The value for the Source Filter subkey is CLSID_AsyncReader, the CLSID of the File Source (Async) filter.
Each entry can have multiple quadruples; all of them must match. In the following example, the first 4 bytes of the file must be 0xAB, 0xCD, 0x12, 0x34; and the last 4 bytes of the file must be 0xAB, 0xAB, 0x00, 0xAB:
0, 4, , ABCD1234, -4, 4, , ABAB00AB
Also, there can be multiple entries listed under a single media type. A match to any of them is sufficient. This scheme allows for a set of alternative masks; for instance, .wav files that might or might not have a RIFF header.
Note This scheme is similar to the one used by the Microsoft® Win32® function GetClassFile.
Loading the Source Filter
Assuming that the Filter Graph Manager finds a matching source filter for the file, it adds that filter to the graph, queries the filter for the IFileSourceFilter interface, and calls IFileSourceFilter::Load. The arguments to the Load method are the file name and the media type, as determined from the registry.
If the Filter Graph Manager cannot find anything from the registry, it defaults to using the Async File Source filter. In that case, it sets the media type to MEDIATYPE_Stream, MEDIASUBTYPE_None.