Item Identifiers and Pointers to Item Identifier Lists
Objects in the shell's namespace are assigned item identifiers and item
identifier lists. An
item identifier uniquely identifies an item within its parent folder. An
item identifier list uniquely identifies an item within the shell's namespace by tracing a path to
the item from the desktop. A pointer to an item identifier list, which is
sometimes called a PIDL (pronounced
piddle), is used with many functions.
Item identifiers and PIDLs are much like the filenames and paths used in a
file system. However, they share this important difference: item identifiers and
PIDLs are binary data structures that never appear to the user. Item names that
can be shown to the user (called
display names) are described in
Display Names and Filenames.
An item identifier is defined by the variable-length
SHITEMID structure. The first two bytes of this structure specify its size, and the
format of the remaining bytes depends on the parent folder, or more precisely on
the software that implements the parent folder's
IShellFolder interface. Except for the first two bytes, item identifiers are not strictly
defined, and applications should make no assumptions about their format. To
determine whether two item identifiers are equal, an application can use the
IShellFolder::CompareIDs member function.
The
ITEMIDLIST structure defines an element in an item identifier list (the only member of
this structure is an
SHITEMID structure). An item identifier list consists of one or more consecutive
ITEMIDLIST structures packed on byte boundaries, followed by a 16-bit zero value. An
application can walk a list of item identifiers by examining the size specified in
each
SHITEMID structure and stopping when it finds a size of zero.
Item identifier lists are almost always allocated using the shell's allocator
(an
IMalloc interface that you can retrieve by using the
SHGetMalloc function). For example, some shell functions create an item identifier list
and return a PIDL to it. In such cases, it is usually the application's
responsibility to free the PIDL using the shell's allocator. Note that the
SHGetMalloc function retrieves the task allocator for OLE applications.
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
- Databases for Amazon shops developers
-
Amazon Categories Database
Browse Nodes Database