2 * internal pidl functions
3 * 1998 <juergen.schmied@metronet.de>
5 * DO NOT use this definitions outside the shell32.dll !
7 * The contents of a pidl should never used from a application
10 * This stuff is used from SHGetFileAttributes, ShellFolder
11 * EnumIDList and ShellView.
20 * the pidl does cache fileattributes to speed up SHGetAttributes when
21 * displaying a big number of files.
23 * a pidl of NULL means the desktop
25 * The structure of the pidl seems to be a union. The first byte of the
26 * PIDLDATA desribes the type of pidl.
28 * object ! first byte / ! format ! living space
30 * ----------------------------------------------------------------
31 * my computer 0x1F/20 mycomp (2) (usual)
32 * drive 0x23/25 drive (usual)
33 * drive 0x25/25 drive (lnk/persistant)
35 * control/printer 0x2E
36 * drive 0x2F drive (lnk/persistant)
37 * folder/file 0x30 folder/file (1) (lnk/persistant)
38 * folder 0x31 folder (usual)
39 * value 0x32 file (usual)
40 * workgroup 0x41 network (3)
41 * computer 0x42 network (4)
42 * whole network 0x47 network (5)
43 * history/favorites 0xb1 file
44 * share 0xc3 metwork (6)
46 * guess: the persistant elements are non tracking
48 * (1) dummy byte is used, attributes are empty
49 * (2) IID_MyComputer = 20D04FE0L-3AEA-1069-A2D8-08002B30309D
50 * (3) two strings "workgroup" "microsoft network"
51 * (4) one string "\\sirius"
52 * (5) one string "whole network"
53 * (6) one string "\\sirius\c"
56 #define PT_DESKTOP 0x00 /* internal */
57 #define PT_MYCOMP 0x1F
59 #define PT_DRIVE2 0x25
60 #define PT_DRIVE3 0x29
61 #define PT_SPECIAL 0x2E
62 #define PT_DRIVE1 0x2F
63 #define PT_FOLDER1 0x30
64 #define PT_FOLDER 0x31
66 #define PT_WORKGRP 0x41
68 #define PT_NETWORK 0x47
69 #define PT_IESPECIAL 0xb1
73 typedef BYTE PIDLTYPE
;
75 typedef struct tagPIDLDATA
76 { PIDLTYPE type
; /*00*/
83 { CHAR szDriveName
[20]; /*01*/
84 DWORD dwUnknown
; /*21*/
85 /* the drive seems to be 25 bytes every time */
88 { BYTE dummy
; /*01 is 0x00 for files or dirs */
89 DWORD dwFileSize
; /*02*/
90 WORD uFileDate
; /*06*/
91 WORD uFileTime
; /*08*/
92 WORD uFileAttribs
; /*10*/
93 CHAR szNames
[1]; /*12*/
94 /* Here are comming two strings. The first is the long name.
95 The second the dos name when needed or just 0x00 */
96 } file
, folder
, generic
;
99 CHAR szNames
[1]; /*03*/
102 } PIDLDATA
, *LPPIDLDATA
;
106 * getting string values from pidls
108 * return value is strlen()
110 DWORD WINAPI
_ILGetDrive(LPCITEMIDLIST
,LPSTR
,UINT16
);
111 DWORD WINAPI
_ILGetItemText(LPCITEMIDLIST
,LPSTR
,UINT16
);
112 DWORD WINAPI
_ILGetFolderText(LPCITEMIDLIST
,LPSTR
,DWORD
);
113 DWORD WINAPI
_ILGetValueText(LPCITEMIDLIST
,LPSTR
,DWORD
);
114 DWORD WINAPI
_ILGetPidlPath(LPCITEMIDLIST
,LPSTR
,DWORD
);
117 * getting special values from simple pidls
119 BOOL WINAPI
_ILGetFileDate (LPCITEMIDLIST pidl
, LPSTR pOut
, UINT uOutSize
);
120 BOOL WINAPI
_ILGetFileSize (LPCITEMIDLIST pidl
, LPSTR pOut
, UINT uOutSize
);
121 BOOL WINAPI
_ILGetExtension (LPCITEMIDLIST pidl
, LPSTR pOut
, UINT uOutSize
);
125 * testing simple pidls
127 BOOL WINAPI
_ILIsDesktop(LPCITEMIDLIST
);
128 BOOL WINAPI
_ILIsMyComputer(LPCITEMIDLIST
);
129 BOOL WINAPI
_ILIsDrive(LPCITEMIDLIST
);
130 BOOL WINAPI
_ILIsFolder(LPCITEMIDLIST
);
131 BOOL WINAPI
_ILIsValue(LPCITEMIDLIST
);
134 * simple pidls from strings
136 LPITEMIDLIST WINAPI
_ILCreateDesktop(void);
137 LPITEMIDLIST WINAPI
_ILCreateMyComputer(void);
138 LPITEMIDLIST WINAPI
_ILCreateDrive(LPCSTR
);
139 LPITEMIDLIST WINAPI
_ILCreateFolder(LPCSTR
, LPCSTR
);
140 LPITEMIDLIST WINAPI
_ILCreateValue(LPCSTR
, LPCSTR
);
143 * raw pidl handling (binary)
145 * data is binary / sizes are bytes
147 DWORD WINAPI
_ILGetData(PIDLTYPE
,LPCITEMIDLIST
,LPVOID
,UINT
);
148 LPITEMIDLIST WINAPI
_ILCreate(PIDLTYPE
,LPCVOID
,UINT16
);
151 * helper functions (getting struct-pointer)
153 LPPIDLDATA WINAPI
_ILGetDataPointer(LPCITEMIDLIST
);
154 LPSTR WINAPI
_ILGetTextPointer(PIDLTYPE type
, LPPIDLDATA pidldata
);
155 LPSTR WINAPI
_ILGetSTextPointer(PIDLTYPE type
, LPPIDLDATA pidldata
);
157 LPITEMIDLIST WINAPI
ILFindChild(LPCITEMIDLIST pidl1
,LPCITEMIDLIST pidl2
);
159 void pdump (LPCITEMIDLIST pidl
);
160 BOOL
pcheck (LPCITEMIDLIST pidl
);