home *** CD-ROM | disk | FTP | other *** search
/ PC World Plus! (NZ) 2001 June / HDC50.iso / Runimage / Delphi50 / Source / Rtl / Win / SHLOBJ.PAS < prev    next >
Pascal/Delphi Source File  |  1999-08-11  |  135KB  |  3,328 lines

  1.  
  2. {*******************************************************}
  3. {                                                       }
  4. {       Borland Delphi Run-time Library                 }
  5. {       Win32 API Shell objects Interface Unit          }
  6. {                                                       }
  7. {       Copyright (c) 1985-1999, Microsoft Corporation  }
  8. {                                                       }
  9. {       Translator: Inprise Corporation                 }
  10. {                                                       }
  11. {*******************************************************}
  12.  
  13. unit ShlObj;
  14.  
  15. {$WEAKPACKAGEUNIT}
  16.  
  17. interface
  18.  
  19. uses Windows, ActiveX, CommCtrl, ShellAPI, RegStr, Messages, WinINet, URLMon;
  20.  
  21. {$HPPEMIT '#include <ole2.h>'}
  22. {$HPPEMIT '#include <prsht.h>'}
  23. {$HPPEMIT '#include <commctrl.h>   // for LPTBBUTTON'}
  24. {$HPPEMIT '#include <shlguid.h>'}
  25. {$HPPEMIT '#include <shlobj.h>'}
  26.  
  27. {$HPPEMIT 'typedef System::DelphiInterface<IAdviseSink> _di_IAdviseSink;'}
  28. {$HPPEMIT 'typedef System::DelphiInterface<IShellBrowser> _di_IShellBrowser;'}
  29. {$HPPEMIT 'typedef System::DelphiInterface<IShellView> _di_IShellView;'}
  30. {$HPPEMIT 'typedef System::DelphiInterface<IContextMenu> _di_IContextMenu;'}
  31. {$HPPEMIT 'typedef System::DelphiInterface<IShellIcon> _di_IShellIcon;'}
  32. {$HPPEMIT 'typedef System::DelphiInterface<IShellFolder> _di_IShellFolder;'}
  33. {$HPPEMIT 'typedef System::DelphiInterface<IShellExtInit> _di_IShellExtInit;'}
  34. {$HPPEMIT 'typedef System::DelphiInterface<IShellPropSheetExt> _di_IShellPropSheetExt;'}
  35. {$HPPEMIT 'typedef System::DelphiInterface<IPersistFolder> _di_IPersistFolder;'}
  36. {$HPPEMIT 'typedef System::DelphiInterface<ICommDlgBrowser> _di_ICommDlgBrowser;'}
  37. {$HPPEMIT 'typedef System::DelphiInterface<IEnumIDList> _di_IEnumIDList;'}
  38. {$HPPEMIT 'typedef System::DelphiInterface<IFileViewerSite> _di_IFileViewerSite;'}
  39. {$HPPEMIT 'typedef System::DelphiInterface<IContextMenu2> _di_IContextMenu2;'}
  40. {$HPPEMIT 'typedef System::DelphiInterface<IShellView2> _di_IShellView2;'}
  41. {$HPPEMIT 'typedef System::DelphiInterface<INewShortcutHookA> _di_INewShortcutHookA;'}
  42. {$HPPEMIT 'typedef System::DelphiInterface<INewShortcutHookW> _di_INewShortcutHookW;'}
  43. {$HPPEMIT 'typedef System::DelphiInterface<IFileViewerA> _di_IFileViewerA;'}
  44. {$HPPEMIT 'typedef System::DelphiInterface<IFileViewerW> _di_IFileViewerW;'}
  45. {$HPPEMIT 'typedef System::DelphiInterface<IShellLinkA> _di_IShellLinkA;'}
  46. {$HPPEMIT 'typedef System::DelphiInterface<IShellLinkW> _di_IShellLinkW;'}
  47. {$HPPEMIT 'typedef System::DelphiInterface<IExtractIconA> _di_IExtractIconA;'}
  48. {$HPPEMIT 'typedef System::DelphiInterface<IExtractIconW> _di_IExtractIconW;'}
  49. {$HPPEMIT 'typedef System::DelphiInterface<IShellExecuteHookA> _di_IShellExecuteHookA;'}
  50. {$HPPEMIT 'typedef System::DelphiInterface<IShellExecuteHookW> _di_IShellExecuteHookW;'}
  51. {$HPPEMIT 'typedef System::DelphiInterface<ICopyHookA> _di_ICopyHookA;'}
  52. {$HPPEMIT 'typedef System::DelphiInterface<ICopyHookW> _di_ICopyHookW;'}
  53.  
  54. {$HPPEMIT '#ifdef UNICODE'}
  55. {$HPPEMIT 'typedef _di_INewShortcutHookW _di_INewShortcutHook;'}
  56. {$HPPEMIT 'typedef _di_IFileViewerW _di_IFileViewer;'}
  57. {$HPPEMIT 'typedef _di_IShellLinkW _di_IShellLink;'}
  58. {$HPPEMIT 'typedef _di_IExtractIconW _di_IExtractIcon;'}
  59. {$HPPEMIT 'typedef _di_IShellExecuteHookW _di_IShellExecuteHook;'}
  60. {$HPPEMIT 'typedef _di_ICopyHookW _di_ICopyHook;'}
  61. {$HPPEMIT '#else'}
  62. {$HPPEMIT 'typedef _di_INewShortcutHookA _di_INewShortcutHook;'}
  63. {$HPPEMIT 'typedef _di_IFileViewerA _di_IFileViewer;'}
  64. {$HPPEMIT 'typedef _di_IShellLinkA _di_IShellLink;'}
  65. {$HPPEMIT 'typedef _di_IExtractIconA _di_IExtractIcon;'}
  66. {$HPPEMIT 'typedef _di_IShellExecuteHookA _di_IShellExecuteHook;'}
  67. {$HPPEMIT 'typedef _di_ICopyHookA _di_ICopyHook;'}
  68. {$HPPEMIT '#endif'}
  69.  
  70. { Object identifiers in the explorer's name space (ItemID and IDList)
  71.   All the items that the user can browse with the explorer (such as files,
  72.   directories, servers, work-groups, etc.) has an identifier which is unique
  73.   among items within the parent folder. Those identifiers are called item
  74.   IDs (SHITEMID). Since all its parent folders have their own item IDs,
  75.   any items can be uniquely identified by a list of item IDs, which is called
  76.   an ID list (ITEMIDLIST).
  77.  
  78.   ID lists are almost always allocated by the task allocator (see some
  79.   description below as well as OLE 2.0 SDK) and may be passed across
  80.   some of shell interfaces (such as IShellFolder). Each item ID in an ID list
  81.   is only meaningful to its parent folder (which has generated it), and all
  82.   the clients must treat it as an opaque binary data except the first two
  83.   bytes, which indicates the size of the item ID.
  84.  
  85.   When a shell extension -- which implements the IShellFolder interace --
  86.   generates an item ID, it may put any information in it, not only the data
  87.   with that it needs to identifies the item, but also some additional
  88.   information, which would help implementing some other functions efficiently.
  89.   For example, the shell's IShellFolder implementation of file system items
  90.   stores the primary (long) name of a file or a directory as the item
  91.   identifier, but it also stores its alternative (short) name, size and date
  92.   etc.
  93.  
  94.   When an ID list is passed to one of shell APIs (such as SHGetPathFromIDList),
  95.   it is always an absolute path -- relative from the root of the name space,
  96.   which is the desktop folder. When an ID list is passed to one of IShellFolder
  97.   member function, it is always a relative path from the folder (unless it
  98.   is explicitly specified). }
  99.  
  100. const
  101. // Class IDs        xx=00-9F
  102.   {$EXTERNALSYM CLSID_ShellDesktop}
  103.   CLSID_ShellDesktop: TGUID = (
  104.     D1:$00021400; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  105.   {$EXTERNALSYM CLSID_ShellLink}
  106.   CLSID_ShellLink: TGUID = (
  107.     D1:$00021401; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  108.   CLSID_ActiveDesktop: TGUID = '{75048700-EF1F-11D0-9888-006097DEACF9}';
  109.  
  110. // Format IDs       xx=A0-CF
  111.   {$EXTERNALSYM FMTID_Intshcut}
  112.   FMTID_Intshcut: TGUID = (
  113.     D1:$000214A0; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  114.   {$EXTERNALSYM FMTID_InternetSite}
  115.   FMTID_InternetSite: TGUID = (
  116.     D1:$000214A1; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  117.  
  118. // command group ids xx=D0-DF
  119.   {$EXTERNALSYM CGID_Explorer}
  120.   CGID_Explorer: TGUID = (
  121.     D1:$000214D0; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  122.   {$EXTERNALSYM CGID_ShellDocView}
  123.   CGID_ShellDocView: TGUID = (
  124.     D1:$000214D1; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  125.  
  126. // Interface IDs    xx=E0-FF
  127.   {$EXTERNALSYM IID_INewShortcutHookA}
  128.   IID_INewShortcutHookA: TGUID = (
  129.     D1:$000214E1; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  130.   {$EXTERNALSYM IID_IShellBrowser}
  131.   IID_IShellBrowser: TGUID = (
  132.     D1:$000214E2; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  133.   {$EXTERNALSYM IID_IShellView}
  134.   IID_IShellView: TGUID = (
  135.     D1:$000214E3; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  136.   {$EXTERNALSYM IID_IContextMenu}
  137.   IID_IContextMenu: TGUID = (
  138.     D1:$000214E4; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  139.   {$EXTERNALSYM IID_IShellIcon}
  140.   IID_IShellIcon: TGUID = (
  141.     D1:$000214E5; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  142.   {$EXTERNALSYM IID_IShellFolder}
  143.   IID_IShellFolder: TGUID = (
  144.     D1:$000214E6; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  145.   {$EXTERNALSYM IID_IShellExtInit}
  146.   IID_IShellExtInit: TGUID = (
  147.     D1:$000214E8; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  148.   {$EXTERNALSYM IID_IShellPropSheetExt}
  149.   IID_IShellPropSheetExt: TGUID = (
  150.     D1:$000214E9; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  151.   {$EXTERNALSYM IID_IPersistFolder}
  152.   IID_IPersistFolder: TGUID = (
  153.     D1:$000214EA; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  154.   {$EXTERNALSYM IID_IExtractIconA}
  155.   IID_IExtractIconA: TGUID = (
  156.     D1:$000214EB; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  157.   {$EXTERNALSYM IID_IShellLinkA}
  158.   IID_IShellLinkA: TGUID = (
  159.     D1:$000214EE; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  160.   {$EXTERNALSYM IID_IShellCopyHookA}
  161.   IID_IShellCopyHookA: TGUID = (
  162.     D1:$000214EF; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  163.   {$EXTERNALSYM IID_IFileViewerA}
  164.   IID_IFileViewerA: TGUID = (
  165.     D1:$000214F0; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  166.   {$EXTERNALSYM IID_ICommDlgBrowser}
  167.   IID_ICommDlgBrowser: TGUID = (
  168.     D1:$000214F1; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  169.   {$EXTERNALSYM IID_IEnumIDList}
  170.   IID_IEnumIDList: TGUID = (
  171.     D1:$000214F2; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  172.   {$EXTERNALSYM IID_IFileViewerSite}
  173.   IID_IFileViewerSite: TGUID = (
  174.     D1:$000214F3; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  175.   {$EXTERNALSYM IID_IContextMenu2}
  176.   IID_IContextMenu2: TGUID = (
  177.     D1:$000214F4; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  178.   {$EXTERNALSYM IID_IShellExecuteHook}
  179.   IID_IShellExecuteHook: TGUID = (
  180.     D1:$000214F5; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  181.   {$EXTERNALSYM IID_IPropSheetPage}
  182.   IID_IPropSheetPage: TGUID = (
  183.     D1:$000214F6; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  184.   {$EXTERNALSYM IID_INewShortcutHookW}
  185.   IID_INewShortcutHookW: TGUID = (
  186.     D1:$000214F7; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  187.   {$EXTERNALSYM IID_IFileViewerW}
  188.   IID_IFileViewerW: TGUID = (
  189.     D1:$000214F8; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  190.   {$EXTERNALSYM IID_IShellLinkW}
  191.   IID_IShellLinkW: TGUID = (
  192.     D1:$000214F9; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  193.   {$EXTERNALSYM IID_IExtractIconW}
  194.   IID_IExtractIconW: TGUID = (
  195.     D1:$000214FA; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  196.   {$EXTERNALSYM IID_IShellExecuteHookW}
  197.   IID_IShellExecuteHookW: TGUID = (
  198.     D1:$000214FB; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  199.   {$EXTERNALSYM IID_IShellCopyHookW}
  200.   IID_IShellCopyHookW: TGUID = (
  201.     D1:$000214FC; D2:$0000; D3:$0000; D4:($C0,$00,$00,$00,$00,$00,$00,$46));
  202.   {$EXTERNALSYM IID_IShellView2}
  203.   IID_IShellView2: TGUID = (
  204.     D1:$88E39E80; D2:$3578; D3:$11CF; D4:($AE,$69,$08,$00,$2B,$2E,$12,$62));
  205.  
  206. // String constants for Interface IDs
  207.   SID_INewShortcutHookA  = '{000214E1-0000-0000-C000-000000000046}';
  208.   SID_IShellBrowser      = '{000214E2-0000-0000-C000-000000000046}';
  209.   SID_IShellView         = '{000214E3-0000-0000-C000-000000000046}';
  210.   SID_IContextMenu       = '{000214E4-0000-0000-C000-000000000046}';
  211.   SID_IShellIcon         = '{000214E5-0000-0000-C000-000000000046}';
  212.   SID_IShellFolder       = '{000214E6-0000-0000-C000-000000000046}';
  213.   SID_IShellExtInit      = '{000214E8-0000-0000-C000-000000000046}';
  214.   SID_IShellPropSheetExt = '{000214E9-0000-0000-C000-000000000046}';
  215.   SID_IPersistFolder     = '{000214EA-0000-0000-C000-000000000046}';
  216.   SID_IExtractIconA      = '{000214EB-0000-0000-C000-000000000046}';
  217.   SID_IShellLinkA        = '{000214EE-0000-0000-C000-000000000046}';
  218.   SID_IShellCopyHookA    = '{000214EF-0000-0000-C000-000000000046}';
  219.   SID_IFileViewerA       = '{000214F0-0000-0000-C000-000000000046}';
  220.   SID_ICommDlgBrowser    = '{000214F1-0000-0000-C000-000000000046}';
  221.   SID_IEnumIDList        = '{000214F2-0000-0000-C000-000000000046}';
  222.   SID_IFileViewerSite    = '{000214F3-0000-0000-C000-000000000046}';
  223.   SID_IContextMenu2      = '{000214F4-0000-0000-C000-000000000046}';
  224.   SID_IShellExecuteHookA = '{000214F5-0000-0000-C000-000000000046}';
  225.   SID_IPropSheetPage     = '{000214F6-0000-0000-C000-000000000046}';
  226.   SID_INewShortcutHookW  = '{000214F7-0000-0000-C000-000000000046}';
  227.   SID_IFileViewerW       = '{000214F8-0000-0000-C000-000000000046}';
  228.   SID_IShellLinkW        = '{000214F9-0000-0000-C000-000000000046}';
  229.   SID_IExtractIconW      = '{000214FA-0000-0000-C000-000000000046}';
  230.   SID_IShellExecuteHookW = '{000214FB-0000-0000-C000-000000000046}';
  231.   SID_IShellCopyHookW    = '{000214FC-0000-0000-C000-000000000046}';
  232.   SID_IShellView2        = '{88E39E80-3578-11CF-AE69-08002B2E1262}';
  233.   SID_IContextMenu3      = '{BCFCE0A0-EC17-11d0-8D10-00A0C90F2719}';
  234.   SID_IPersistFolder2    = '{1AC3D9F0-175C-11d1-95BE-00609797EA4F}';
  235.   SID_IShellIconOverlayIdentifier = '{0C6C4200-C589-11D0-999A-00C04FD655E1}';
  236.   SID_IShellIconOverlay  = '{7D688A70-C613-11D0-999B-00C04FD655E1}';
  237.   SID_IURLSearchHook     = '{AC60F6A0-0FD9-11D0-99CB-00C04FD64497}';
  238.   SID_IInputObjectSite   = '{f1db8392-7331-11d0-8c99-00a0c92dbfe8}';
  239.   SID_IInputObject       = '{68284faa-6a48-11d0-8c78-00c04fd918b4}';
  240.   SID_IDockingWindowSite = '{2a342fc2-7b26-11d0-8ca9-00a0c92dbfe8}';
  241.   SID_IDockingWindowFrame = '{47d2657a-7b27-11d0-8ca9-00a0c92dbfe8}';
  242.   SID_IDockingWindow     = '{012dd920-7b26-11d0-8ca9-00a0c92dbfe8}';
  243.   SID_IDeskBand          = '{EB0FE172-1A3A-11D0-89B3-00A0C90A90AC}';
  244.   SID_IActiveDesktop     = '{F490EB00-1240-11D1-9888-006097DEACF9}';
  245.   SID_IShellChangeNotify = '{00000000-0000-0000-0000-000000000000}';  // !!
  246.   SID_IQueryInfo         = '{00021500-0000-0000-C000-000000000046}';
  247.  
  248. type
  249. { TSHItemID -- Item ID }
  250.   PSHItemID = ^TSHItemID;
  251.   {$EXTERNALSYM _SHITEMID}
  252.   _SHITEMID = record
  253.     cb: Word;                         { Size of the ID (including cb itself) }
  254.     abID: array[0..0] of Byte;        { The item ID (variable length) }
  255.   end;
  256.   TSHItemID = _SHITEMID;
  257.   {$EXTERNALSYM SHITEMID}
  258.   SHITEMID = _SHITEMID;
  259.  
  260.  
  261. { TItemIDList -- List if item IDs (combined with 0-terminator) }
  262.   PItemIDList = ^TItemIDList;
  263.   {$EXTERNALSYM _ITEMIDLIST}
  264.   _ITEMIDLIST = record
  265.      mkid: TSHItemID;
  266.    end;
  267.   TItemIDList = _ITEMIDLIST;
  268.   {$EXTERNALSYM ITEMIDLIST}
  269.   ITEMIDLIST = _ITEMIDLIST;
  270.  
  271.  
  272. { Task allocator API }
  273.  
  274. { All the shell extensions MUST use the task allocator (see OLE 2.0
  275.  programming guild for its definition) when they allocate or free
  276.  memory objects (mostly ITEMIDLIST) that are returned across any
  277.  shell interfaces. There are two ways to access the task allocator
  278.  from a shell extension depending on whether or not it is linked with
  279.  OLE32.DLL or not (virtual; stdcall; abstractly for efficiency).
  280.  
  281.  (1) A shell extension which calls any OLE API (i.e., linked with
  282.   OLE32.DLL) should call OLE's task allocator (by retrieving
  283.   the task allocator by calling CoGetMalloc API).
  284.  
  285.  (2) A shell extension which does not call any OLE API (i.e., not linked
  286.   with OLE32.DLL) should call the shell task allocator API (defined
  287.   below), so that the shell can quickly loads it when OLE32.DLL is not
  288.   loaded by any application at that point. }
  289.  
  290. { !!! Notes:
  291.   In next version of Windowso release, SHGetMalloc will be replaced by
  292.  the following macro.
  293.  
  294.  #define SHGetMalloc(ppmem)     CoGetMalloc(MEMCTX_TASK, ppmem) }
  295.  
  296. {$EXTERNALSYM SHGetMalloc}
  297. function SHGetMalloc(var ppMalloc: IMalloc): HResult; stdcall;
  298.  
  299. { IContextMenu interface }
  300.  
  301. { [OverView] }
  302.  
  303. { The shell uses the IContextMenu interface in following three cases.
  304.  
  305.  case-1: The shell is loading context menu extensions.
  306.    When the user clicks the right mouse button on an item within the shell's
  307.   name space (i.g., file, directory, server, work-group, etc.), it creates
  308.   the default context menu for its type, then loads context menu extensions
  309.   that are registered for that type (and its base type) so that they can
  310.   add extra menu items. Those context menu extensions are registered at
  311.   HKCR\beginProgIDend\shellex\ContextMenuHandlers.
  312.  
  313.  case-2: The shell is retrieving a context menu of sub-folders in extended
  314.    name-space.
  315.    When the explorer's name space is extended by name space extensions,
  316.   the shell calls their IShellFolder::GetUIObjectOf to get the IContextMenu
  317.   objects when it creates context menus for folders under those extended
  318.   name spaces.
  319.  
  320.  case-3: The shell is loading non-default drag and drop handler for directories.
  321.    When the user performed a non-default drag and drop onto one of file
  322.   system folders (i.e., directories), it loads shell extensions that are
  323.   registered at HKCR\beginProgIDend\DragDropHandlers. }
  324.  
  325. { [Member functions] }
  326.  
  327. { IContextMenu::QueryContextMenu }
  328.  
  329. { This member function may insert one or more menuitems to the specified
  330.   menu (hmenu) at the specified location (indexMenu which is never be -1).
  331.   The IDs of those menuitem must be in the specified range (idCmdFirst and
  332.   idCmdLast). It returns the maximum menuitem ID offset (ushort) in the
  333.   'code' field (low word) of the scode.
  334.  
  335.   The uFlags specify the context. It may have one or more of following
  336.   flags.
  337.  
  338.   CMF_DEFAULTONLY: This flag is passed if the user is invoking the default
  339.   action (typically by double-clicking, case 1 and 2 only). Context menu
  340.   extensions (case 1) should not add any menu items, and returns NOERROR.
  341.  
  342.   CMF_VERBSONLY: The explorer passes this flag if it is constructing
  343.   a context menu for a short-cut object (case 1 and case 2 only). If this
  344.   flag is passed, it should not add any menu-items that is not appropriate
  345.   from a short-cut.
  346.   A good example is the 'Delete' menuitem, which confuses the user
  347.   because it is not clear whether it deletes the link source item or the
  348.   link itself.
  349.  
  350.   CMF_EXPLORER: The explorer passes this flag if it has the left-side pane
  351.    (case 1 and 2 only). Context menu extensions should ignore this flag.
  352.  
  353.   High word (16-bit) are reserved for context specific communications
  354.   and the rest of flags (13-bit) are reserved by the system. }
  355.  
  356.  
  357. { IContextMenu::InvokeCommand }
  358.  
  359. { This member is called when the user has selected one of menuitems that
  360.   are inserted by previous QueryContextMenu member. In this case, the
  361.   LOWORD(lpici->lpVerb) contains the menuitem ID offset (menuitem ID -
  362.   idCmdFirst).
  363.  
  364.    This member function may also be called programmatically. In such a case,
  365.   lpici->lpVerb specifies the canonical name of the command to be invoked,
  366.   which is typically retrieved by GetCommandString member previously.
  367.  
  368.   Parameters in lpci:
  369.     cbSize -- Specifies the size of this structure (sizeof(*lpci))
  370.     hwnd   -- Specifies the owner window for any message/dialog box.
  371.     fMask  -- Specifies whether or not dwHotkey/hIcon paramter is valid.
  372.     lpVerb -- Specifies the command to be invoked.
  373.     lpParameters -- Parameters (optional)
  374.     lpDirectory  -- Working directory (optional)
  375.     nShow -- Specifies the flag to be passed to ShowWindow (SW_*).
  376.     dwHotKey -- Hot key to be assigned to the app after invoked (optional).
  377.     hIcon -- Specifies the icon (optional).
  378.     hMonitor -- Specifies the default monitor (optional). }
  379.  
  380.  
  381. { IContextMenu::GetCommandString }
  382.  
  383. { This member function is called by the explorer either to get the
  384.   canonical (language independent) command name (uFlags == GCS_VERB) or
  385.   the help text ((uFlags & GCS_HELPTEXT) != 0) for the specified command.
  386.   The retrieved canonical string may be passed to its InvokeCommand
  387.   member function to invoke a command programmatically. The explorer
  388.   displays the help texts in its status bar; therefore, the length of
  389.   the help text should be reasonably short (<40 characters).
  390.  
  391.   Parameters:
  392.    idCmd -- Specifies menuitem ID offset (from idCmdFirst)
  393.    uFlags -- Either GCS_VERB or GCS_HELPTEXT
  394.    pwReserved -- Reserved (must pass NULL when calling, must ignore when called)
  395.    pszName -- Specifies the string buffer.
  396.    cchMax -- Specifies the size of the string buffer. }
  397.  
  398.  
  399. const
  400. { QueryContextMenu uFlags }
  401.  
  402.   {$EXTERNALSYM CMF_NORMAL}
  403.   CMF_NORMAL             = $00000000;
  404.   {$EXTERNALSYM CMF_DEFAULTONLY}
  405.   CMF_DEFAULTONLY        = $00000001;
  406.   {$EXTERNALSYM CMF_VERBSONLY}
  407.   CMF_VERBSONLY          = $00000002;
  408.   {$EXTERNALSYM CMF_EXPLORE}
  409.   CMF_EXPLORE            = $00000004;
  410.   {$EXTERNALSYM CMF_NOVERBS}
  411.   CMF_NOVERBS            = $00000008;
  412.   {$EXTERNALSYM CMF_CANRENAME}
  413.   CMF_CANRENAME          = $00000010;
  414.   {$EXTERNALSYM CMF_NODEFAULT}
  415.   CMF_NODEFAULT          = $00000020;
  416.   {$EXTERNALSYM CMF_INCLUDESTATIC}
  417.   CMF_INCLUDESTATIC      = $00000040;
  418.   {$EXTERNALSYM CMF_RESERVED}
  419.   CMF_RESERVED           = $FFFF0000;      { View specific }
  420.  
  421. { GetCommandString uFlags }
  422.  
  423.   {$EXTERNALSYM GCS_VERBA}
  424.   GCS_VERBA            = $00000000;     { canonical verb }
  425.   {$EXTERNALSYM GCS_HELPTEXTA}
  426.   GCS_HELPTEXTA        = $00000001;     { help text (for status bar) }
  427.   {$EXTERNALSYM GCS_VALIDATEA}
  428.   GCS_VALIDATEA        = $00000002;     { validate command exists }
  429.   {$EXTERNALSYM GCS_VERBW}
  430.   GCS_VERBW            = $00000004;     { canonical verb (unicode) }
  431.   {$EXTERNALSYM GCS_HELPTEXTW}
  432.   GCS_HELPTEXTW        = $00000005;     { help text (unicode version) }
  433.   {$EXTERNALSYM GCS_VALIDATEW}
  434.   GCS_VALIDATEW        = $00000006;     { validate command exists (unicode) }
  435.   {$EXTERNALSYM GCS_UNICODE}
  436.   GCS_UNICODE          = $00000004;     { for bit testing - Unicode string }
  437.  
  438.  
  439.  
  440.  
  441.  
  442.  
  443.  
  444.  
  445.   {$EXTERNALSYM GCS_VERB}
  446.   GCS_VERB            = GCS_VERBA;
  447.   {$EXTERNALSYM GCS_HELPTEXT}
  448.   GCS_HELPTEXT        = GCS_HELPTEXTA;
  449.   {$EXTERNALSYM GCS_VALIDATE}
  450.   GCS_VALIDATE        = GCS_VALIDATEA;
  451.  
  452.   {$EXTERNALSYM CMDSTR_NEWFOLDERA}
  453.   CMDSTR_NEWFOLDERA       = 'NewFolder';
  454.   {$EXTERNALSYM CMDSTR_VIEWLISTA}
  455.   CMDSTR_VIEWLISTA        = 'ViewList';
  456.   {$EXTERNALSYM CMDSTR_VIEWDETAILSA}
  457.   CMDSTR_VIEWDETAILSA     = 'ViewDetails';
  458.   {$EXTERNALSYM CMDSTR_NEWFOLDERW}
  459.   CMDSTR_NEWFOLDERW       = 'NewFolder'; // !!! make WideString() ?
  460.   {$EXTERNALSYM CMDSTR_VIEWLISTW}
  461.   CMDSTR_VIEWLISTW        = 'ViewList';
  462.   {$EXTERNALSYM CMDSTR_VIEWDETAILSW}
  463.   CMDSTR_VIEWDETAILSW     = 'ViewDetails';
  464.  
  465.  
  466.  
  467.  
  468.  
  469.  
  470.  
  471.  
  472.   {$EXTERNALSYM CMDSTR_NEWFOLDER}
  473.   CMDSTR_NEWFOLDER        = CMDSTR_NEWFOLDERA;
  474.   {$EXTERNALSYM CMDSTR_VIEWLIST}
  475.   CMDSTR_VIEWLIST         = CMDSTR_VIEWLISTA;
  476.   {$EXTERNALSYM CMDSTR_VIEWDETAILS}
  477.   CMDSTR_VIEWDETAILS      = CMDSTR_VIEWDETAILSA;
  478.  
  479.   {$EXTERNALSYM CMIC_MASK_HOTKEY}
  480.   CMIC_MASK_HOTKEY            = SEE_MASK_HOTKEY;
  481.   {$EXTERNALSYM CMIC_MASK_ICON}
  482.   CMIC_MASK_ICON              = SEE_MASK_ICON;
  483.   {$EXTERNALSYM CMIC_MASK_FLAG_NO_UI}
  484.   CMIC_MASK_FLAG_NO_UI        = SEE_MASK_FLAG_NO_UI;
  485.   {$EXTERNALSYM CMIC_MASK_UNICODE}
  486.   CMIC_MASK_UNICODE           = SEE_MASK_UNICODE;
  487.   {$EXTERNALSYM CMIC_MASK_NO_CONSOLE}
  488.   CMIC_MASK_NO_CONSOLE        = SEE_MASK_NO_CONSOLE;
  489. //  CMIC_MASK_HASLINKNAME       = SEE_MASK_HASLINKNAME; - not defined in shellapi
  490. //  CMIC_MASK_FLAG_SEP_VDM      = SEE_MASK_FLAG_SEPVDM; - not defined in shellapi
  491. //  CMIC_MASK_HASTITLE          = SEE_MASK_HASTITLE; - not defined in shellapi
  492.   {$EXTERNALSYM CMIC_MASK_ASYNCOK}
  493.   CMIC_MASK_ASYNCOK           = SEE_MASK_ASYNCOK;
  494.  
  495.   {$EXTERNALSYM CMIC_MASK_PTINVOKE}
  496.   CMIC_MASK_PTINVOKE          = $20000000;
  497.  
  498. type
  499.   // NOTE: When SEE_MASK_HMONITOR is set, hIcon is treated as hMonitor
  500.   PCMInvokeCommandInfo = ^TCMInvokeCommandInfo;
  501.   {$EXTERNALSYM _CMINVOKECOMMANDINFO}
  502.   _CMINVOKECOMMANDINFO = record
  503.     cbSize: DWORD;        { must be sizeof(CMINVOKECOMMANDINFO) }
  504.     fMask: DWORD;         { any combination of CMIC_MASK_* }
  505.     hwnd: HWND;           { might be NULL (indicating no owner window) }
  506.     lpVerb: LPCSTR;       { either a string of MAKEINTRESOURCE(idOffset) }
  507.     lpParameters: LPCSTR; { might be NULL (indicating no parameter) }
  508.     lpDirectory: LPCSTR;  { might be NULL (indicating no specific directory) }
  509.     nShow: Integer;       { one of SW_ values for ShowWindow() API }
  510.     dwHotKey: DWORD;
  511.     hIcon: THandle;
  512.   end;
  513.   TCMInvokeCommandInfo = _CMINVOKECOMMANDINFO;
  514.   {$EXTERNALSYM CMINVOKECOMMANDINFO}
  515.   CMINVOKECOMMANDINFO = _CMINVOKECOMMANDINFO;
  516.  
  517.   PCMInvokeCommandInfoEx = ^TCMInvokeCommandInfoEx;
  518.   {$EXTERNALSYM _CMInvokeCommandInfoEx}
  519.   _CMInvokeCommandInfoEx = record
  520.     cbSize: DWORD;       { must be sizeof(CMINVOKECOMMANDINFOEX) }
  521.     fMask: DWORD;        { any combination of CMIC_MASK_* }
  522.     hwnd: HWND;          { might be NULL (indicating no owner window) }
  523.     lpVerb: LPCSTR;      { either a string or MAKEINTRESOURCE(idOffset) }
  524.     lpParameters: LPCSTR;{ might be NULL (indicating no parameter) }
  525.     lpDirectory: LPCSTR; { might be NULL (indicating no specific directory) }
  526.     nShow: Integer;      { one of SW_ values for ShowWindow() API }
  527.     dwHotKey: DWORD;
  528.     hIcon: THandle;
  529.     lpTitle: LPCSTR;        { For CreateProcess-StartupInfo.lpTitle }
  530.     lpVerbW: LPCWSTR;       { Unicode verb (for those who can use it) }
  531.     lpParametersW: LPCWSTR; { Unicode parameters (for those who can use it) }
  532.     lpDirectoryW: LPCWSTR;  { Unicode directory (for those who can use it) }
  533.     lpTitleW: LPCWSTR;      { Unicode title (for those who can use it) }
  534.     ptInvoke: TPoint;       { Point where it's invoked }
  535.   end;
  536.   TCMInvokeCommandInfoEx = _CMINVOKECOMMANDINFOEX;
  537.   {$EXTERNALSYM CMINVOKECOMMANDINFOEX}
  538.   CMINVOKECOMMANDINFOEX = _CMINVOKECOMMANDINFOEX;
  539.  
  540.  
  541.   {$EXTERNALSYM IContextMenu}
  542.   IContextMenu = interface(IUnknown)
  543.     [SID_IContextMenu]
  544.     function QueryContextMenu(Menu: HMENU;
  545.       indexMenu, idCmdFirst, idCmdLast, uFlags: UINT): HResult; stdcall;
  546.     function InvokeCommand(var lpici: TCMInvokeCommandInfo): HResult; stdcall;
  547.     function GetCommandString(idCmd, uType: UINT; pwReserved: PUINT;
  548.       pszName: LPSTR; cchMax: UINT): HResult; stdcall;
  549.   end;
  550.  
  551. { IContextMenu2 (IContextMenu with one new member) }
  552. { IContextMenu2.HandleMenuMsg }
  553.  
  554. {  This function is called, if the client of IContextMenu is aware of }
  555. { IContextMenu2 interface and receives one of following messages while }
  556. { it is calling TrackPopupMenu (in the window proc of hwndOwner): }
  557. {      WM_INITPOPUP, WM_DRAWITEM and WM_MEASUREITEM }
  558. {  The callee may handle these messages to draw owner draw menuitems. }
  559.  
  560.   {$EXTERNALSYM IContextMenu2}
  561.   IContextMenu2 = interface(IContextMenu)
  562.     [SID_IContextMenu2]
  563.     function HandleMenuMsg(uMsg: UINT; WParam, LParam: Integer): HResult; stdcall;
  564.   end;
  565.  
  566. { IContextMenu3 (IContextMenu2 with one new member }
  567. { IContextMenu3::HandleMenuMsg2 }
  568.  
  569. {  This function is called, if the client of IContextMenu is aware of }
  570. { IContextMenu3 interface and receives a menu message while }
  571. { it is calling TrackPopupMenu (in the window proc of hwndOwner): }
  572.  
  573.   {$EXTERNALSYM IContextMenu3}
  574.   IContextMenu3 = interface(IContextMenu2)
  575.     [SID_IContextMenu3]
  576.     function HandleMenuMsg2(uMsg: UINT; wParam, lParam: Integer;
  577.       var lpResult: Integer): HResult; stdcall;
  578.   end;
  579.  
  580. { Interface: IShellExtInit }
  581.  
  582. { The IShellExtInit interface is used by the explorer to initialize shell
  583.   extension objects. The explorer (1) calls CoCreateInstance (or equivalent)
  584.   with the registered CLSID and IID_IShellExtInit, (2) calls its Initialize
  585.   member, then (3) calls its QueryInterface to a particular interface (such
  586.   as IContextMenu or IPropSheetExt and (4) performs the rest of operation. }
  587.  
  588. { [Member functions] }
  589.  
  590. { IShellExtInit.Initialize }
  591.  
  592. { This member function is called when the explorer is initializing either
  593.   context menu extension, property sheet extension or non-default drag-drop
  594.   extension.
  595.  
  596.   Parameters: (context menu or property sheet extension)
  597.    pidlFolder -- Specifies the parent folder
  598.    lpdobj -- Spefifies the set of items selected in that folder.
  599.    hkeyProgID -- Specifies the type of the focused item in the selection.
  600.  
  601.   Parameters: (non-default drag-and-drop extension)
  602.    pidlFolder -- Specifies the target (destination) folder
  603.    lpdobj -- Specifies the items that are dropped (see the description
  604.     about shell's clipboard below for clipboard formats).
  605.    hkeyProgID -- Specifies the folder type. }
  606.  
  607. type
  608.   {$EXTERNALSYM IShellExtInit}
  609.   IShellExtInit = interface(IUnknown)
  610.     [SID_IShellExtInit]
  611.     function Initialize(pidlFolder: PItemIDList; lpdobj: IDataObject;
  612.       hKeyProgID: HKEY): HResult; stdcall;
  613.   end;
  614.  
  615. {=========================================================================== }
  616.  
  617. { Interface: IShellPropSheetExt }
  618.  
  619. { The explorer uses the IShellPropSheetExt to allow property sheet
  620.   extensions or control panel extensions to add additional property
  621.   sheet pages. }
  622.  
  623. { [Member functions] }
  624.  
  625. { IShellPropSheetExt.AddPages }
  626.  
  627. { The explorer calls this member function when it finds a registered
  628.   property sheet extension for a particular type of object. For each
  629.   additional page, the extension creates a page object by calling
  630.   CreatePropertySheetPage API and calls lpfnAddPage.
  631.  
  632.    Parameters:
  633.     lpfnAddPage -- Specifies the callback function.
  634.     lParam -- Specifies the opaque handle to be passed to the callback function. }
  635.  
  636.  
  637. { IShellPropSheetExt.ReplacePage }
  638.  
  639. { The explorer never calls this member of property sheet extensions. The
  640.   explorer calls this member of control panel extensions, so that they
  641.   can replace some of default control panel pages (such as a page of
  642.   mouse control panel).
  643.  
  644.    Parameters:
  645.     uPageID -- Specifies the page to be replaced.
  646.     lpfnReplace Specifies the callback function.
  647.     lParam -- Specifies the opaque handle to be passed to the callback function. }
  648.  
  649. type
  650.   {$EXTERNALSYM IShellPropSheetExt}
  651.   IShellPropSheetExt = interface(IUnknown)
  652.     [SID_IShellPropSheetExt]
  653.     function AddPages(lpfnAddPage: TFNAddPropSheetPage; lParam: LPARAM): HResult; stdcall;
  654.     function ReplacePage(uPageID: UINT; lpfnReplaceWith: TFNAddPropSheetPage;
  655.       lParam: LPARAM): HResult; stdcall;
  656.   end;
  657.  
  658. { IPersistFolder Interface }
  659. {  The IPersistFolder interface is used by the file system implementation of }
  660. { IShellFolder::BindToObject when it is initializing a shell folder object. }
  661.  
  662. { IPersistFolder::Initialize }
  663. {  This member function is called when the explorer is initializing a }
  664. { shell folder object. }
  665. {  Parameters: }
  666. {   pidl -- Specifies the absolute location of the folder. }
  667.  
  668.   {$EXTERNALSYM IPersistFolder}
  669.   IPersistFolder = interface(IPersist)
  670.     [SID_IPersistFolder]
  671.     function Initialize(pidl: PItemIDList): HResult; stdcall;
  672.   end;
  673.  
  674.   {$EXTERNALSYM IPersistFolder2}
  675.   IPersistFolder2 = interface(IPersistFolder)
  676.     [SID_IPersistFolder2]
  677.     function GetCurFolder(var pidl: PItemIDList): HResult; stdcall;
  678.   end;
  679.  
  680. { IExtractIcon interface }
  681.  
  682. { This interface is used in two different places in the shell.
  683.  
  684.   Case-1: Icons of sub-folders for the scope-pane of the explorer.
  685.  
  686.    It is used by the explorer to get the 'icon location' of
  687.   sub-folders from each shell folders. When the user expands a folder
  688.   in the scope pane of the explorer, the explorer does following:
  689.    (1) binds to the folder (gets IShellFolder),
  690.    (2) enumerates its sub-folders by calling its EnumObjects member,
  691.    (3) calls its GetUIObjectOf member to get IExtractIcon interface
  692.       for each sub-folders.
  693.    In this case, the explorer uses only IExtractIcon.GetIconLocation
  694.   member to get the location of the appropriate icon. An icon location
  695.   always consists of a file name (typically DLL or EXE) and either an icon
  696.   resource or an icon index.
  697.  
  698.  
  699.   Case-2: Extracting an icon image from a file
  700.  
  701.    It is used by the shell when it extracts an icon image
  702.   from a file. When the shell is extracting an icon from a file,
  703.   it does following:
  704.    (1) creates the icon extraction handler object (by getting its CLSID
  705.       under the beginProgIDend\shell\ExtractIconHanler key and calling
  706.       CoCreateInstance requesting for IExtractIcon interface).
  707.    (2) Calls IExtractIcon.GetIconLocation.
  708.    (3) Then, calls IExtractIcon.Extract with the location/index pair.
  709.    (4) If (3) returns NOERROR, it uses the returned icon.
  710.    (5) Otherwise, it recursively calls this logic with new location
  711.       assuming that the location string contains a fully qualified path name.
  712.  
  713.    From extension programmer's point of view, there are only two cases
  714.   where they provide implementations of IExtractIcon:
  715.    Case-1) providing explorer extensions (i.e., IShellFolder).
  716.    Case-2) providing per-instance icons for some types of files.
  717.  
  718.   Because Case-1 is described above, we'll explain only Case-2 here.
  719.  
  720.   When the shell is about display an icon for a file, it does following:
  721.    (1) Finds its ProgID and ClassID.
  722.    (2) If the file has a ClassID, it gets the icon location string from the
  723.      'DefaultIcon' key under it. The string indicates either per-class
  724.      icon (e.g., 'FOOBAR.DLL,2') or per-instance icon (e.g., '%1,1').
  725.    (3) If a per-instance icon is specified, the shell creates an icon
  726.      extraction handler object for it, and extracts the icon from it
  727.      (which is described above).
  728.  
  729.    It is important to note that the shell calls IExtractIcon.GetIconLocation
  730.   first, then calls IExtractIcon.Extract. Most application programs
  731.   that support per-instance icons will probably store an icon location
  732.   (DLL/EXE name and index/id) rather than an icon image in each file.
  733.   In those cases, a programmer needs to implement only the GetIconLocation
  734.   member and it Extract member simply returns S_FALSE. They need to
  735.   implement Extract member only if they decided to store the icon images
  736.   within files themselved or some other database (which is very rare). }
  737.  
  738. { [Member functions] }
  739.  
  740. { IExtractIcon.GetIconLocation }
  741.  
  742. { This function returns an icon location.
  743.  
  744.   Parameters:
  745.    uFlags     [in]  -- Specifies if it is opened or not (GIL_OPENICON or 0)
  746.    szIconFile [out] -- Specifies the string buffer buffer for a location name.
  747.    cchMax     [in]  -- Specifies the size of szIconFile (almost always MAX_PATH)
  748.    piIndex    [out] -- Sepcifies the address of UINT for the index.
  749.    pwFlags    [out] -- Returns GIL_* flags
  750.   Returns:
  751.    NOERROR, if it returns a valid location; S_FALSE, if the shell use a
  752.    default icon.
  753.  
  754.   Notes: The location may or may not be a path to a file. The caller can
  755.    not assume anything unless the subsequent Extract member call returns
  756.    S_FALSE.
  757.  
  758.    if the returned location is not a path to a file, GIL_NOTFILENAME should
  759.    be set in the returned flags. }
  760.  
  761. { IExtractIcon.Extract }
  762.  
  763. { This function extracts an icon image from a specified file.
  764.  
  765.   Parameters:
  766.    pszFile [in] -- Specifies the icon location (typically a path to a file).
  767.    nIconIndex [in] -- Specifies the icon index.
  768.    phiconLarge [out] -- Specifies the HICON variable for large icon.
  769.    phiconSmall [out] -- Specifies the HICON variable for small icon.
  770.    nIconSize [in] -- Specifies the size icon required (size of large icon)
  771.                      LOWORD is the requested large icon size
  772.                      HIWORD is the requested small icon size
  773.   Returns:
  774.    NOERROR, if it extracted the from the file.
  775.    S_FALSE, if the caller should extract from the file specified in the
  776.            location. }
  777.  
  778. const
  779.   {$EXTERNALSYM GIL_OPENICON}
  780.   GIL_OPENICON         = $0001;      { allows containers to specify an "open" look }
  781.   {$EXTERNALSYM GIL_FORSHELL}
  782.   GIL_FORSHELL         = $0002;      { icon is to be displayed in a ShellFolder }
  783.   {$EXTERNALSYM GIL_ASYNC}
  784.   GIL_ASYNC            = $0020;      { this is an async extract, return E_ASYNC }
  785.  
  786. { GetIconLocation() return flags }
  787.  
  788.   {$EXTERNALSYM GIL_SIMULATEDOC}
  789.   GIL_SIMULATEDOC      = $0001;      { simulate this document icon for this }
  790.   {$EXTERNALSYM GIL_PERINSTANCE}
  791.   GIL_PERINSTANCE      = $0002;      { icons from this class are per instance (each file has its own) }
  792.   {$EXTERNALSYM GIL_PERCLASS}
  793.   GIL_PERCLASS         = $0004;      { icons from this class per class (shared for all files of this type) }
  794.   {$EXTERNALSYM GIL_NOTFILENAME}
  795.   GIL_NOTFILENAME      = $0008;      { location is not a filename, must call ::ExtractIcon }
  796.   {$EXTERNALSYM GIL_DONTCACHE}
  797.   GIL_DONTCACHE        = $0010;      { this icon should not be cached }
  798.  
  799. type
  800.   {$EXTERNALSYM IExtractIconA}
  801.   IExtractIconA = interface(IUnknown)
  802.     [SID_IExtractIconA]
  803.     function GetIconLocation(uFlags: UINT; szIconFile: PAnsiChar; cchMax: UINT;
  804.       out piIndex: Integer; out pwFlags: UINT): HResult; stdcall;
  805.     function Extract(pszFile: PAnsiChar; nIconIndex: UINT;
  806.       out phiconLarge, phiconSmall: HICON; nIconSize: UINT): HResult; stdcall;
  807.   end;
  808.   {$EXTERNALSYM IExtractIconW}
  809.   IExtractIconW = interface(IUnknown)
  810.     [SID_IExtractIconW]
  811.     function GetIconLocation(uFlags: UINT; szIconFile: PWideChar; cchMax: UINT;
  812.       out piIndex: Integer; out pwFlags: UINT): HResult; stdcall;
  813.     function Extract(pszFile: PWideChar; nIconIndex: UINT;
  814.       out phiconLarge, phiconSmall: HICON; nIconSize: UINT): HResult; stdcall;
  815.   end;
  816.   {$EXTERNALSYM IExtractIcon}
  817.   IExtractIcon = IExtractIconA;
  818.  
  819.  
  820. { IShellIcon Interface }
  821. { Used to get a icon index for a IShellFolder object.
  822.  
  823.  This interface can be implemented by a IShellFolder, as a quick way to
  824.  return the icon for a object in the folder.
  825.  
  826.  An instance of this interface is only created once for the folder, unlike
  827.  IExtractIcon witch is created once for each object.
  828.  
  829.  If a ShellFolder does not implement this interface, the standard
  830.  GetUIObject(....IExtractIcon) method will be used to get a icon
  831.  for all objects.
  832.  
  833.  The following standard imagelist indexs can be returned:
  834.  
  835.       0   document (blank page) (not associated)
  836.       1   document (with stuff on the page)
  837.       2   application (exe, com, bat)
  838.       3   folder (plain)
  839.       4   folder (open)
  840.  
  841.  IShellIcon.GetIconOf(pidl, flags, lpIconIndex)
  842.  
  843.       pidl            object to get icon for.
  844.       flags           GIL_* input flags (GIL_OPEN, ...)
  845.       lpIconIndex     place to return icon index.
  846.  
  847.   returns:
  848.       NOERROR, if lpIconIndex contains the correct system imagelist index.
  849.       S_FALSE, if unable to get icon for this object, go through
  850.                GetUIObject, IExtractIcon, methods. }
  851.  
  852.   {$EXTERNALSYM IShellIcon}
  853.   IShellIcon = interface(IUnknown)
  854.     [SID_IShellIcon]
  855.     function GetIconOf(pidl: PItemIDList; flags: UINT;
  856.       out IconIndex: Integer): HResult; stdcall;
  857.   end;
  858.  
  859. { IShellIconOverlayIdentifier }
  860. {
  861.  Used to identify a file as a member of the group of files that have this specific
  862.  icon overlay
  863.  
  864.  Users can create new IconOverlayIdentifiers and place them in the following registry
  865.  location together with the Icon overlay image and their priority.
  866.  HKEY_LOCAL_MACHINE "Software\\Microsoft\\Windows\\CurrentVersion\\ShellIconOverlayIdentifiers"
  867.  
  868.  The shell will enumerate through all IconOverlayIdentifiers at start, and prioritize
  869.  them according to internal rules, in case the internal rules don't apply, we use their
  870.  input priority
  871.  
  872.  IShellIconOverlayIdentifier:IsMemberOf(LPCWSTR pwszPath, DWORD dwAttrib)
  873.       pwszPath        full path of the file
  874.       dwAttrib        attribute of this file
  875.  
  876.   returns:
  877.       S_OK,    if the file is a member
  878.       S_FALSE, if the file is not a member
  879.       E_FAIL,  if the operation failed due to bad WIN32_FIND_DATA
  880.  
  881.  IShellIconOverlayIdentifier::GetOverlayInfo(LPWSTR pwszIconFile, int * pIndex, DWORD * dwFlags) PURE;
  882.       pszIconFile    the path of the icon file
  883.       pIndex         Depend on the flags, this could contain the IconIndex or the Sytem Imagelist Index
  884.       dwFlags        defined below
  885.  
  886.  IShellIconOverlayIdentifier::GetPriority(int * pIPriority) PURE;
  887.       pIPriority     the priority of this Overlay Identifier
  888. }
  889.  
  890.   {$EXTERNALSYM IShellIconOverlayIdentifier}
  891.   IShellIconOverlayIdentifier = interface(IUnknown)
  892.     [SID_IShellIconOverlayIdentifier]
  893.     function IsMemberOf(pwszPath: PWideChar; dwAttrib: DWORD): HResult; stdcall;
  894.     function GetOverlayInfo(pwszIconFile: PWideChar; cchMax: Integer;
  895.       var pIndex: Integer; var pdwFlags: DWORD): HResult; stdcall;
  896.     function GetPriority(out pIPriority: Integer): HResult; stdcall;
  897.   end;
  898.  
  899. const
  900.   {$EXTERNALSYM ISIOI_ICONFILE}
  901.   ISIOI_ICONFILE            = $00000001;  // path is returned through pwszIconFile
  902.   {$EXTERNALSYM ISIOI_ICONINDEX}
  903.   ISIOI_ICONINDEX           = $00000002;  // icon index in pwszIconFile is returned through pIndex
  904.   {$EXTERNALSYM ISIOI_SYSIMAGELISTINDEX}
  905.   ISIOI_SYSIMAGELISTINDEX   = $00000004;  // system imagelist icon index is returned through pIndex
  906.  
  907. { IShellIconOverlay }
  908. {
  909.  Used to return the icon overlay index or its icon index for an IShellFolder object,
  910.  this is always implemented with IShellFolder
  911.  
  912.  IShellIconOverlay:GetOverlayIndex(LPCITEMIDLIST pidl, DWORD * pdwIndex)
  913.       pidl            object to identify icon overlay for.
  914.       pdwIndex        the Overlay Index in the system image list
  915.  
  916.  IShellIconOverlay:GetOverlayIconIndex(LPCITEMIDLIST pidl, DWORD * pdwIndex)
  917.       pdwIconIndex    the Overlay Icon index in the system image list
  918.  This method is only used for those who are interested in seeing the real bits
  919.  of the Overlay Icon
  920.  
  921.   returns:
  922.       S_OK,  if the index of an Overlay is found
  923.       S_FALSE, if no Overlay exists for this file
  924.       E_FAIL, if pidl is bad
  925. }
  926. type
  927.   {$EXTERNALSYM IShellIconOverlay}
  928.   IShellIconOverlay = interface(IUnknown)
  929.     [SID_IShellIconOverlay]
  930.     function GetOverlayIndex(pidl: PItemIDList; out pIndex: Integer): HResult; stdcall;
  931.     function GetOverlayIconIndex(pidl: PItemIDList; out pIconIndex: Integer): HResult; stdcall;
  932.   end;
  933.  
  934. { IShellLink Interface }
  935. const
  936.   { IShellLink.Resolve fFlags }
  937.   {$EXTERNALSYM SLR_NO_UI}
  938.   SLR_NO_UI           = $0001;
  939.   {$EXTERNALSYM SLR_ANY_MATCH}
  940.   SLR_ANY_MATCH       = $0002;
  941.   {$EXTERNALSYM SLR_UPDATE}
  942.   SLR_UPDATE          = $0004;
  943.   {$EXTERNALSYM SLR_NOUPDATE}
  944.   SLR_NOUPDATE        = $0008;
  945.  
  946.   { IShellLink.GetPath fFlags }
  947.   {$EXTERNALSYM SLGP_SHORTPATH}
  948.   SLGP_SHORTPATH      = $0001;
  949.   {$EXTERNALSYM SLGP_UNCPRIORITY}
  950.   SLGP_UNCPRIORITY    = $0002;
  951.   {$EXTERNALSYM SLGP_RAWPATH}
  952.   SLGP_RAWPATH        = $0004;
  953.  
  954. type
  955.   {$EXTERNALSYM IShellLinkA}
  956.   IShellLinkA = interface(IUnknown) { sl }
  957.     [SID_IShellLinkA]
  958.     function GetPath(pszFile: PAnsiChar; cchMaxPath: Integer;
  959.       var pfd: TWin32FindData; fFlags: DWORD): HResult; stdcall;
  960.     function GetIDList(var ppidl: PItemIDList): HResult; stdcall;
  961.     function SetIDList(pidl: PItemIDList): HResult; stdcall;
  962.     function GetDescription(pszName: PAnsiChar; cchMaxName: Integer): HResult; stdcall;
  963.     function SetDescription(pszName: PAnsiChar): HResult; stdcall;
  964.     function GetWorkingDirectory(pszDir: PAnsiChar; cchMaxPath: Integer): HResult; stdcall;
  965.     function SetWorkingDirectory(pszDir: PAnsiChar): HResult; stdcall;
  966.     function GetArguments(pszArgs: PAnsiChar; cchMaxPath: Integer): HResult; stdcall;
  967.     function SetArguments(pszArgs: PAnsiChar): HResult; stdcall;
  968.     function GetHotkey(var pwHotkey: Word): HResult; stdcall;
  969.     function SetHotkey(wHotkey: Word): HResult; stdcall;
  970.     function GetShowCmd(out piShowCmd: Integer): HResult; stdcall;
  971.     function SetShowCmd(iShowCmd: Integer): HResult; stdcall;
  972.     function GetIconLocation(pszIconPath: PAnsiChar; cchIconPath: Integer;
  973.       out piIcon: Integer): HResult; stdcall;
  974.     function SetIconLocation(pszIconPath: PAnsiChar; iIcon: Integer): HResult; stdcall;
  975.     function SetRelativePath(pszPathRel: PAnsiChar; dwReserved: DWORD): HResult; stdcall;
  976.     function Resolve(Wnd: HWND; fFlags: DWORD): HResult; stdcall;
  977.     function SetPath(pszFile: PAnsiChar): HResult; stdcall;
  978.   end;
  979.   {$EXTERNALSYM IShellLinkW}
  980.   IShellLinkW = interface(IUnknown) { sl }
  981.     [SID_IShellLinkW]
  982.     function GetPath(pszFile: PWideChar; cchMaxPath: Integer;
  983.       var pfd: TWin32FindData; fFlags: DWORD): HResult; stdcall;
  984.     function GetIDList(var ppidl: PItemIDList): HResult; stdcall;
  985.     function SetIDList(pidl: PItemIDList): HResult; stdcall;
  986.     function GetDescription(pszName: PWideChar; cchMaxName: Integer): HResult; stdcall;
  987.     function SetDescription(pszName: PWideChar): HResult; stdcall;
  988.     function GetWorkingDirectory(pszDir: PWideChar; cchMaxPath: Integer): HResult; stdcall;
  989.     function SetWorkingDirectory(pszDir: PWideChar): HResult; stdcall;
  990.     function GetArguments(pszArgs: PWideChar; cchMaxPath: Integer): HResult; stdcall;
  991.     function SetArguments(pszArgs: PWideChar): HResult; stdcall;
  992.     function GetHotkey(var pwHotkey: Word): HResult; stdcall;
  993.     function SetHotkey(wHotkey: Word): HResult; stdcall;
  994.     function GetShowCmd(out piShowCmd: Integer): HResult; stdcall;
  995.     function SetShowCmd(iShowCmd: Integer): HResult; stdcall;
  996.     function GetIconLocation(pszIconPath: PWideChar; cchIconPath: Integer;
  997.       out piIcon: Integer): HResult; stdcall;
  998.     function SetIconLocation(pszIconPath: PWideChar; iIcon: Integer): HResult; stdcall;
  999.     function SetRelativePath(pszPathRel: PWideChar; dwReserved: DWORD): HResult; stdcall;
  1000.     function Resolve(Wnd: HWND; fFlags: DWORD): HResult; stdcall;
  1001.     function SetPath(pszFile: PWideChar): HResult; stdcall;
  1002.   end;
  1003.   {$EXTERNALSYM IShellLink}
  1004.   IShellLink = IShellLinkA;
  1005.  
  1006. { IShellExecuteHook Interface }
  1007.  
  1008.   {$EXTERNALSYM IShellExecuteHookA}
  1009.   IShellExecuteHookA = interface(IUnknown) { sl }
  1010.     [SID_IShellExecuteHookA]
  1011.     function Execute(var ShellExecuteInfo: TShellExecuteInfo): HResult; stdcall;
  1012.   end;
  1013.   {$EXTERNALSYM IShellExecuteHookW}
  1014.   IShellExecuteHookW = interface(IUnknown) { sl }
  1015.     [SID_IShellExecuteHookW]
  1016.     function Execute(var ShellExecuteInfo: TShellExecuteInfo): HResult; stdcall;
  1017.   end;
  1018.   {$EXTERNALSYM IShellExecuteHook}
  1019.   IShellExecuteHook = IShellExecuteHookA;
  1020.  
  1021. { IURLSearchHook Interface }
  1022.  
  1023.   {$EXTERNALSYM IURLSearchHook}
  1024.   IURLSearchHook = interface(IUnknown)
  1025.     [SID_IURLSearchHook]
  1026.     function Translate(lpwszSearchURL: PWideChar; cchBufferSize: DWORD): HResult; stdcall;
  1027.   end;
  1028.  
  1029. { INewShortcutHook Interface }
  1030.  
  1031.   {$EXTERNALSYM INewShortcutHookA}
  1032.   INewShortcutHookA = interface(IUnknown) { sl }
  1033.     [SID_INewShortcutHookA]
  1034.     function SetReferent(pcszReferent: PAnsiChar; Wnd: HWND): HResult; stdcall;
  1035.     function GetReferent(pcszReferent: PAnsiChar; cchReferent: Integer): HResult; stdcall;
  1036.     function SetFolder(pcszFolder: PAnsiChar; Wnd: HWND): HResult; stdcall;
  1037.     function GetFolder(pcszFolder: PAnsiChar; cchFolder: Integer): HResult; stdcall;
  1038.     function GetName(pcszName: PAnsiChar; cchName: Integer): HResult; stdcall;
  1039.     function GetExtension(pcszExtension: PAnsiChar; cchExtension: Integer): HResult; stdcall;
  1040.   end;
  1041.   {$EXTERNALSYM INewShortcutHookW}
  1042.   INewShortcutHookW = interface(IUnknown) { sl }
  1043.     [SID_INewShortcutHookW]
  1044.     function SetReferent(pcszReferent: PWideChar; Wnd: HWND): HResult; stdcall;
  1045.     function GetReferent(pcszReferent: PWideChar; cchReferent: Integer): HResult; stdcall;
  1046.     function SetFolder(pcszFolder: PWideChar; Wnd: HWND): HResult; stdcall;
  1047.     function GetFolder(pcszFolder: PWideChar; cchFolder: Integer): HResult; stdcall;
  1048.     function GetName(pcszName: PWideChar; cchName: Integer): HResult; stdcall;
  1049.     function GetExtension(pcszExtension: PWideChar; cchExtension: Integer): HResult; stdcall;
  1050.   end;
  1051.   {$EXTERNALSYM INewShortcutHook}
  1052.   INewShortcutHook = INewShortcutHookA;
  1053.  
  1054. { ICopyHook Interface }
  1055.  
  1056. { The copy hook is called whenever file system directories are
  1057.   copy/moved/deleted/renamed via the shell.  It is also called by the shell
  1058.   on changes of status of printers.
  1059.   Clients register their id under STRREG_SHEX_COPYHOOK for file system hooks
  1060.   and STRREG_SHEx_PRNCOPYHOOK for printer hooks.
  1061.   the CopyCallback is called prior to the action, so the hook has the chance
  1062.   to allow, deny or cancel the operation by returning the falues:
  1063.      IDYES  -  means allow the operation
  1064.      IDNO   -  means disallow the operation on this file, but continue with
  1065.               any other operations (eg. batch copy)
  1066.      IDCANCEL - means disallow the current operation and cancel any pending
  1067.               operations
  1068.    arguments to the CopyCallback
  1069.       hwnd - window to use for any UI
  1070.       wFunc - what operation is being done
  1071.       wFlags - and flags (FOF_*) set in the initial call to the file operation
  1072.       pszSrcFile - name of the source file
  1073.       dwSrcAttribs - file attributes of the source file
  1074.       pszDestFile - name of the destiation file (for move and renames)
  1075.       dwDestAttribs - file attributes of the destination file }
  1076.  
  1077. type
  1078.   {$EXTERNALSYM ICopyHookA}
  1079.   ICopyHookA = interface(IUnknown) { sl }
  1080.     [SID_IShellCopyHookA]
  1081.     function CopyCallback(Wnd: HWND; wFunc, wFlags: UINT; pszSrcFile: PAnsiChar;
  1082.       dwSrcAttribs: DWORD; pszDestFile: PAnsiChar; dwDestAttribs: DWORD): UINT; stdcall;
  1083.   end;
  1084.   {$EXTERNALSYM ICopyHookW}
  1085.   ICopyHookW = interface(IUnknown) { sl }
  1086.     [SID_IShellCopyHookW]
  1087.     function CopyCallback(Wnd: HWND; wFunc, wFlags: UINT; pszSrcFile: PWideChar;
  1088.       dwSrcAttribs: DWORD; pszDestFile: PWideChar; dwDestAttribs: DWORD): UINT; stdcall;
  1089.   end;
  1090.   {$EXTERNALSYM ICopyHook}
  1091.   ICopyHook = ICopyHookA;
  1092.  
  1093. { IFileViewerSite Interface }
  1094.  
  1095. type
  1096.   {$EXTERNALSYM IFileViewerSite}
  1097.   IFileViewerSite = interface(IUnknown)
  1098.     [SID_IFileViewerSite]
  1099.     function SetPinnedWindow(Wnd: HWND): HResult; stdcall;
  1100.     function GetPinnedWindow(var Wnd: HWND): HResult; stdcall;
  1101.   end;
  1102.  
  1103. { IFileViewer Interface }
  1104.  
  1105. { Implemented in a FileViewer component object.  Used to tell a
  1106.   FileViewer to PrintTo or to view, the latter happening though
  1107.   ShowInitialize and Show.  The filename is always given to the
  1108.   viewer through IPersistFile. }
  1109.  
  1110. type
  1111.   // !!! unnamed struct
  1112.   PFVShowInfo = ^FVSHOWINFO;
  1113.   FVSHOWINFO = packed record
  1114.     { Stuff passed into viewer (in) }
  1115.     cbSize: DWORD;           { Size of structure for future expansion... }
  1116.     hwndOwner: HWND;         { who is the owner window. }
  1117.     iShow: Integer;          { The show command }
  1118.  
  1119.     { Passed in and updated  (in/Out) }
  1120.     dwFlags: DWORD;          { flags }
  1121.     rect: TRECT;             { Where to create the window may have defaults }
  1122.     punkRel: IUNKNOWN;       { Relese this interface when window is visible }
  1123.  
  1124.     { Stuff that might be returned from viewer (out) }
  1125.     strNewFile: array[0..MAX_PATH-1] of TOleChar;   { New File to view. }
  1126.   end;
  1127.   {$EXTERNALSYM FVSHOWINFO}
  1128.   TFVShowInfo = FVSHOWINFO;
  1129.   LPFVSHOWINFO = PFVShowInfo;
  1130.   {$EXTERNALSYM LPFVSHOWINFO}
  1131.   
  1132. const
  1133. { Define File View Show Info Flags. }
  1134.  
  1135.   {$EXTERNALSYM FVSIF_RECT}
  1136.   FVSIF_RECT      = $00000001;      { The rect variable has valid data. }
  1137.   {$EXTERNALSYM FVSIF_PINNED}
  1138.   FVSIF_PINNED    = $00000002;      { We should Initialize pinned }
  1139.  
  1140.   {$EXTERNALSYM FVSIF_NEWFAILED}
  1141.   FVSIF_NEWFAILED = $08000000;      { The new file passed back failed
  1142.                                        to be viewed. }
  1143.  
  1144.   {$EXTERNALSYM FVSIF_NEWFILE}
  1145.   FVSIF_NEWFILE   = $80000000;      { A new file to view has been returned }
  1146.   {$EXTERNALSYM FVSIF_CANVIEWIT}
  1147.   FVSIF_CANVIEWIT = $40000000;      { The viewer can view it. }
  1148.  
  1149. type
  1150.   {$EXTERNALSYM IFileViewerA}
  1151.   IFileViewerA = interface(IUnknown)
  1152.     [SID_IFileViewerA]
  1153.     function ShowInitialize(fsi: IFileViewerSite): HResult; stdcall;
  1154.     function Show(var pvsi: TFVShowInfo): HResult; stdcall;
  1155.     function PrintTo(pszDriver: PAnsiChar; fSuppressUI: BOOL): HResult; stdcall;
  1156.   end;
  1157.   {$EXTERNALSYM IFileViewerW}
  1158.   IFileViewerW = interface(IUnknown)
  1159.     [SID_IFileViewerW]
  1160.     function ShowInitialize(fsi: IFileViewerSite): HResult; stdcall;
  1161.     function Show(var pvsi: TFVShowInfo): HResult; stdcall;
  1162.     function PrintTo(pszDriver: PWideChar; fSuppressUI: BOOL): HResult; stdcall;
  1163.   end;
  1164.   {$EXTERNALSYM IFileViewer}
  1165.   IFileViewer = IFileViewerA;
  1166.  
  1167. { CommandTarget ids. for shell doc view wedge }
  1168.  
  1169.   {$EXTERNALSYM TSHDVIDEnums}
  1170.   TSHDVIDEnums = (
  1171.     SHDVID_SETPROGRESSPOS,
  1172.     SHDVID_SETPROGRESSRANGE,
  1173.     SHDVID_SETSTATUSTEXT,        { variantIn  bstr }
  1174.     SHDVID_REFRESH,
  1175.     SHDVID_STOP,
  1176.     SHDVID_UPDATECOMMANDS, { / this forces a re-querystatus of the command targets. }
  1177.                            { / the arg in can specify a specific one to update or NIL for evrything }
  1178.     SHDVID_SETTITLE,            { variantIn bstr }
  1179.     SHDVID_FINALTITLEAVAIL,     { variantIn bstr - sent after final SETTITLE is sent }
  1180.     SHDVID_STARTLOAD,           { NIL for everything }
  1181.     SHDVID_STOPLOAD,            { NIL for everything }
  1182.     SHDVID_CCALLBACK,           { callback to arbitrary C func }
  1183.     SHDVID_MENUEXEC,            { do menu command }
  1184.     SHDVID_MENUQS               { query menu commands }
  1185.   );
  1186.  
  1187. { IShellBrowser/IShellView/IShellFolder interface }
  1188.  
  1189. {  These three interfaces are used when the shell communicates with }
  1190. { name space extensions. The shell (explorer) provides IShellBrowser }
  1191. { interface, and extensions implements IShellFolder and IShellView }
  1192. { interfaces. }
  1193.  
  1194. { ========================================================================== }
  1195.  
  1196.  
  1197. { -------------------------------------------------------------------------- }
  1198.  
  1199. { Command/menuitem IDs }
  1200.  
  1201. {  The explorer dispatches WM_COMMAND messages based on the range of }
  1202. { command/menuitem IDs. All the IDs of menuitems that the view (right }
  1203. { pane) inserts must be in FCIDM_SHVIEWFIRST/LAST (otherwise, the explorer }
  1204. { won't dispatch them). The view should not deal with any menuitems }
  1205. { in FCIDM_BROWSERFIRST/LAST (otherwise, it won't work with the future }
  1206. { version of the shell). }
  1207.  
  1208. {  FCIDM_SHVIEWFIRST/LAST      for the right pane (IShellView) }
  1209. {  FCIDM_BROWSERFIRST/LAST     for the explorer frame (IShellBrowser) }
  1210. {  FCIDM_GLOBAL/LAST           for the explorer's submenu IDs }
  1211.  
  1212. const
  1213.   {$EXTERNALSYM FCIDM_SHVIEWFIRST}
  1214.   FCIDM_SHVIEWFIRST               = $0000;
  1215.   {$EXTERNALSYM FCIDM_SHVIEWLAST}
  1216.   FCIDM_SHVIEWLAST                = $7fff;
  1217.   {$EXTERNALSYM FCIDM_BROWSERFIRST}
  1218.   FCIDM_BROWSERFIRST              = $a000;
  1219.   {$EXTERNALSYM FCIDM_BROWSERLAST}
  1220.   FCIDM_BROWSERLAST               = $bf00;
  1221.   {$EXTERNALSYM FCIDM_GLOBALFIRST}
  1222.   FCIDM_GLOBALFIRST               = $8000;
  1223.   {$EXTERNALSYM FCIDM_GLOBALLAST}
  1224.   FCIDM_GLOBALLAST                = $9fff;
  1225.  
  1226.  
  1227. { Global submenu IDs and separator IDs }
  1228.  
  1229.   {$EXTERNALSYM FCIDM_MENU_FILE}
  1230.   FCIDM_MENU_FILE                 = FCIDM_GLOBALFIRST+$0000;
  1231.   {$EXTERNALSYM FCIDM_MENU_EDIT}
  1232.   FCIDM_MENU_EDIT                 = FCIDM_GLOBALFIRST+$0040;
  1233.   {$EXTERNALSYM FCIDM_MENU_VIEW}
  1234.   FCIDM_MENU_VIEW                 = FCIDM_GLOBALFIRST+$0080;
  1235.   {$EXTERNALSYM FCIDM_MENU_VIEW_SEP_OPTIONS}
  1236.   FCIDM_MENU_VIEW_SEP_OPTIONS     = FCIDM_GLOBALFIRST+$0081;
  1237.   {$EXTERNALSYM FCIDM_MENU_TOOLS}
  1238.   FCIDM_MENU_TOOLS                = FCIDM_GLOBALFIRST+$00c0;
  1239.   {$EXTERNALSYM FCIDM_MENU_TOOLS_SEP_GOTO}
  1240.   FCIDM_MENU_TOOLS_SEP_GOTO       = FCIDM_GLOBALFIRST+$00c1;
  1241.   {$EXTERNALSYM FCIDM_MENU_HELP}
  1242.   FCIDM_MENU_HELP                 = FCIDM_GLOBALFIRST+$0100;
  1243.   {$EXTERNALSYM FCIDM_MENU_FIND}
  1244.   FCIDM_MENU_FIND                 = FCIDM_GLOBALFIRST+$0140;
  1245.   {$EXTERNALSYM FCIDM_MENU_EXPLORE}
  1246.   FCIDM_MENU_EXPLORE              = FCIDM_GLOBALFIRST+$0150;
  1247.   {$EXTERNALSYM FCIDM_MENU_FAVORITES}
  1248.   FCIDM_MENU_FAVORITES            = FCIDM_GLOBALFIRST+$0170;
  1249.  
  1250. { -------------------------------------------------------------------------- }
  1251. { control IDs known to the view }
  1252. { -------------------------------------------------------------------------- }
  1253.  
  1254.   {$EXTERNALSYM FCIDM_TOOLBAR}
  1255.   FCIDM_TOOLBAR          = FCIDM_BROWSERFIRST + 0;
  1256.   {$EXTERNALSYM FCIDM_STATUS}
  1257.   FCIDM_STATUS           = FCIDM_BROWSERFIRST + 1;
  1258.  
  1259.   { The resource id of the offline cursor }
  1260.   { This cursor is avaialble in shdocvw.dll }
  1261.   {$EXTERNALSYM IDC_OFFLINE_HAND}
  1262.   IDC_OFFLINE_HAND       = 103;
  1263.  
  1264. { -------------------------------------------------------------------------- }
  1265.  
  1266. { FOLDERSETTINGS }
  1267.  
  1268. {  FOLDERSETTINGS is a data structure that explorer passes from one folder }
  1269. { view to another, when the user is browsing. It calls ISV::GetCurrentInfo }
  1270. { member to get the current settings and pass it to ISV::CreateViewWindow }
  1271. { to allow the next folder view "inherit" it. These settings assumes a }
  1272. { particular UI (which the shell's folder view has), and shell extensions }
  1273. { may or may not use those settings. }
  1274.  
  1275. { -------------------------------------------------------------------------- }
  1276.  
  1277. { NB Bitfields. }
  1278. { FWF_DESKTOP implies FWF_TRANSPARENT/NOCLIENTEDGE/NOSCROLL }
  1279. const
  1280.   {$EXTERNALSYM FWF_AUTOARRANGE}
  1281.   FWF_AUTOARRANGE = $0001;
  1282.   {$EXTERNALSYM FWF_ABBREVIATEDNAMES}
  1283.   FWF_ABBREVIATEDNAMES = $0002;
  1284.   {$EXTERNALSYM FWF_SNAPTOGRID}
  1285.   FWF_SNAPTOGRID = $0004;
  1286.   {$EXTERNALSYM FWF_OWNERDATA}
  1287.   FWF_OWNERDATA = $0008;
  1288.   {$EXTERNALSYM FWF_BESTFITWINDOW}
  1289.   FWF_BESTFITWINDOW = $0010;
  1290.   {$EXTERNALSYM FWF_DESKTOP}
  1291.   FWF_DESKTOP = $0020;
  1292.   {$EXTERNALSYM FWF_SINGLESEL}
  1293.   FWF_SINGLESEL = $0040;
  1294.   {$EXTERNALSYM FWF_NOSUBFOLDERS}
  1295.   FWF_NOSUBFOLDERS = $0080;
  1296.   {$EXTERNALSYM FWF_TRANSPARENT}
  1297.   FWF_TRANSPARENT = $0100;
  1298.   {$EXTERNALSYM FWF_NOCLIENTEDGE}
  1299.   FWF_NOCLIENTEDGE = $0200;
  1300.   {$EXTERNALSYM FWF_NOSCROLL}
  1301.   FWF_NOSCROLL    = $0400;
  1302.   {$EXTERNALSYM FWF_ALIGNLEFT}
  1303.   FWF_ALIGNLEFT   = $0800;
  1304.   {$EXTERNALSYM FWF_NOICONS}
  1305.   FWF_NOICONS     = $1000;
  1306.   {$EXTERNALSYM FWF_SINGLECLICKACTIVATE}
  1307.   FWF_SINGLECLICKACTIVATE = $8000; { TEMPORARY -- NO UI FOR THIS }
  1308.  
  1309.   {$EXTERNALSYM FVM_ICON}
  1310.   FVM_ICON = 1;
  1311.   {$EXTERNALSYM FVM_SMALLICON}
  1312.   FVM_SMALLICON = 2;
  1313.   {$EXTERNALSYM FVM_LIST}
  1314.   FVM_LIST = 3;
  1315.   {$EXTERNALSYM FVM_DETAILS}
  1316.   FVM_DETAILS = 4;
  1317.  
  1318. type
  1319.   // !!! unnamed struct
  1320.   PFolderSettings = ^FOLDERSETTINGS;
  1321.   FOLDERSETTINGS = packed record
  1322.     ViewMode: UINT;      { View mode (FOLDERVIEWMODE values) }
  1323.     fFlags: UINT;        { View options (FOLDERFLAGS bits) }
  1324.   end;
  1325.   {$EXTERNALSYM FOLDERSETTINGS}
  1326.   TFolderSettings = FOLDERSETTINGS;
  1327.   LPFOLDERSETTINGS = PFolderSettings;
  1328.   {$EXTERNALSYM LPFOLDERSETTINGS} 
  1329.  
  1330. { -------------------------------------------------------------------------- }
  1331.  
  1332. { Interface:   IShellBrowser }
  1333.  
  1334. {  IShellBrowser interface is the interface that is provided by the shell }
  1335. { explorer/folder frame window. When it creates the "contents pane" of }
  1336. { a shell folder (which provides IShellFolder interface), it calls its }
  1337. { CreateViewObject member function to create an IShellView object. Then, }
  1338. { it calls its CreateViewWindow member to create the "contents pane" }
  1339. { window. The pointer to the IShellBrowser interface is passed to }
  1340. { the IShellView object as a parameter to this CreateViewWindow member }
  1341. { function call. }
  1342.  
  1343. {    +--------------------------+  <-- Explorer window }
  1344. {    | [] Explorer              | }
  1345. {    |--------------------------+       IShellBrowser }
  1346. {    | File Edit View ..        | }
  1347. {    |--------------------------| }
  1348. {    |        |                 | }
  1349. {    |        |              <-------- Content pane }
  1350. {    |        |                 | }
  1351. {    |        |                 |       IShellView }
  1352. {    |        |                 | }
  1353. {    |        |                 | }
  1354. {    +--------------------------+ }
  1355.  
  1356.  
  1357.  
  1358. { [Member functions] }
  1359.  
  1360.  
  1361. { IShellBrowser.GetWindow(phwnd) }
  1362.  
  1363. {   Inherited from IOleWindow.GetWindow. }
  1364.  
  1365.  
  1366. { IShellBrowser.ContextSensitiveHelp(fEnterMode) }
  1367.  
  1368. {   Inherited from IOleWindow.ContextSensitiveHelp. }
  1369.  
  1370.  
  1371. { IShellBrowser.InsertMenusSB(hmenuShared, lpMenuWidths) }
  1372.  
  1373. {   Similar to the IOleInPlaceFrame.InsertMenus. The explorer will put }
  1374. {  "File" and "Edit" pulldown in the File menu group, "View" and "Tools" }
  1375. {  in the Container menu group and "Help" in the Window menu group. Each }
  1376. {  pulldown menu will have a uniqu ID, FCIDM_MENU_FILE/EDIT/VIEW/TOOLS/HELP. }
  1377. {  The view is allowed to insert menuitems into those sub-menus by those }
  1378. {  IDs must be between FCIDM_SHVIEWFIRST and FCIDM_SHVIEWLAST. }
  1379.  
  1380.  
  1381. { IShellBrowser.SetMenuSB(hmenuShared, holemenu, hwndActiveObject) }
  1382.  
  1383. {   Similar to the IOleInPlaceFrame.SetMenu. The explorer ignores the }
  1384. {  holemenu parameter (reserved for future enhancement)  and performs }
  1385. {  menu-dispatch based on the menuitem IDs (see the description above). }
  1386. {  It is important to note that the explorer will add different }
  1387. {  set of menuitems depending on whether the view has a focus or not. }
  1388. {  Therefore, it is very important to call ISB.OnViewWindowActivate }
  1389. {  whenever the view window (or its children) gets the focus. }
  1390.  
  1391.  
  1392. { IShellBrowser.RemoveMenusSB(hmenuShared) }
  1393.  
  1394. {   Same as the IOleInPlaceFrame.RemoveMenus. }
  1395.  
  1396.  
  1397. { IShellBrowser.SetStatusTextSB(lpszStatusText) }
  1398.  
  1399. {   Same as the IOleInPlaceFrame.SetStatusText. It is also possible to }
  1400. {  send messages directly to the status window via SendControlMsg. }
  1401.  
  1402.  
  1403. { IShellBrowser.EnableModelessSB(fEnable) }
  1404.  
  1405. {   Same as the IOleInPlaceFrame.EnableModeless. }
  1406.  
  1407. { IShellBrowser.TranslateAcceleratorSB(lpmsg, wID) }
  1408.  
  1409. {   Same as the IOleInPlaceFrame.TranslateAccelerator, but will be }
  1410. {  never called because we don't support EXEs (i.e., the explorer has }
  1411. {  the message loop). This member function is defined here for possible }
  1412. {  future enhancement. }
  1413.  
  1414.  
  1415. { IShellBrowser.BrowseObject(pidl, wFlags) }
  1416.  
  1417. {   The view calls this member to let shell explorer browse to another }
  1418. {  folder. The pidl and wFlags specifies the folder to be browsed. }
  1419.  
  1420. {  Following three flags specifies whether it creates another window or not. }
  1421. {   SBSP_SAMEBROWSER  -- Browse to another folder with the same window. }
  1422. {   SBSP_NEWBROWSER   -- Creates another window for the specified folder. }
  1423. {   SBSP_DEFBROWSER   -- Default behavior (respects the view option). }
  1424.  
  1425. {  Following three flags specifies open, explore, or default mode. These   . }
  1426. {  are ignored if SBSP_SAMEBROWSER or (SBSP_DEFBROWSER && (single window   . }
  1427. {  browser || explorer)).                                                  . }
  1428. {   SBSP_OPENMODE     -- Use a normal folder window }
  1429. {   SBSP_EXPLOREMODE  -- Use an explorer window }
  1430. {   SBSP_DEFMODE      -- Use the same as the current window }
  1431.  
  1432. {  Following three flags specifies the pidl. }
  1433. {   SBSP_ABSOLUTE -- pidl is an absolute pidl (relative from desktop) }
  1434. {   SBSP_RELATIVE -- pidl is relative from the current folder. }
  1435. {   SBSP_PARENT   -- Browse the parent folder (ignores the pidl) }
  1436. {   SBSP_NAVIGATEBACK    -- Navigate back (ignores the pidl) }
  1437. {   SBSP_NAVIGATEFORWARD -- Navigate forward (ignores the pidl) }
  1438.  
  1439. {  Following two flags control history manipulation as result of navigate }
  1440. {   SBSP_WRITENOHISTORY -- write no history (shell folder) entry }
  1441. {   SBSP_NOAUTOSELECT -- suppress selection in history pane }
  1442.  
  1443.  
  1444. { IShellBrowser.GetViewStateStream(grfMode, ppstm) }
  1445.  
  1446. {   The browser returns an IStream interface as the storage for view }
  1447. {  specific state information. }
  1448.  
  1449. {   grfMode -- Specifies the read/write access (STGM_READ/WRITE/READWRITE) }
  1450. {   ppstm   -- Specifies the LPSTREAM variable to be filled. }
  1451.  
  1452.  
  1453. { IShellBrowser.GetControlWindow(id, phwnd) }
  1454.  
  1455. {   The shell view may call this member function to get the window handle }
  1456. {  of Explorer controls (toolbar or status winodw -- FCW_TOOLBAR or }
  1457. {  FCW_STATUS). }
  1458.  
  1459.  
  1460. { IShellBrowser.SendControlMsg(id, uMsg, wParam, lParam, pret) }
  1461.  
  1462. {   The shell view calls this member function to send control messages to }
  1463. {  one of Explorer controls (toolbar or status window -- FCW_TOOLBAR or }
  1464. {  FCW_STATUS). }
  1465.  
  1466.  
  1467. { IShellBrowser.QueryActiveShellView(IShellView * ppshv) }
  1468.  
  1469. {   This member returns currently activated (displayed) shellview object. }
  1470. {  A shellview never need to call this member function. }
  1471.  
  1472.  
  1473. { IShellBrowser.OnViewWindowActive(pshv) }
  1474.  
  1475. {   The shell view window calls this member function when the view window }
  1476. {  (or one of its children) got the focus. It MUST call this member before }
  1477. {  calling IShellBrowser.InsertMenus, because it will insert different }
  1478. {  set of menu items depending on whether the view has the focus or not. }
  1479.  
  1480.  
  1481. { IShellBrowser.SetToolbarItems(lpButtons, nButtons, uFlags) }
  1482.  
  1483. {   The view calls this function to add toolbar items to the exporer's }
  1484. {  toolbar. "lpButtons" and "nButtons" specifies the array of toolbar }
  1485. {  items. "uFlags" must be one of FCT_MERGE, FCT_CONFIGABLE, FCT_ADDTOEND. }
  1486.  
  1487. { ------------------------------------------------------------------------- }
  1488.  
  1489.  
  1490. { Values for wFlags parameter of ISB.BrowseObject() member. }
  1491. const
  1492.   {$EXTERNALSYM SBSP_DEFBROWSER}
  1493.   SBSP_DEFBROWSER      = $0000;
  1494.   {$EXTERNALSYM SBSP_SAMEBROWSER}
  1495.   SBSP_SAMEBROWSER     = $0001;
  1496.   {$EXTERNALSYM SBSP_NEWBROWSER}
  1497.   SBSP_NEWBROWSER      = $0002;
  1498.  
  1499.   {$EXTERNALSYM SBSP_DEFMODE}
  1500.   SBSP_DEFMODE         = $0000;
  1501.   {$EXTERNALSYM SBSP_OPENMODE}
  1502.   SBSP_OPENMODE        = $0010;
  1503.   {$EXTERNALSYM SBSP_EXPLOREMODE}
  1504.   SBSP_EXPLOREMODE     = $0020;
  1505.  
  1506.   {$EXTERNALSYM SBSP_ABSOLUTE}
  1507.   SBSP_ABSOLUTE        = $0000;
  1508.   {$EXTERNALSYM SBSP_RELATIVE}
  1509.   SBSP_RELATIVE        = $1000;
  1510.   {$EXTERNALSYM SBSP_PARENT}
  1511.   SBSP_PARENT          = $2000;
  1512.   {$EXTERNALSYM SBSP_NAVIGATEBACK}
  1513.   SBSP_NAVIGATEBACK    = $4000;
  1514.   {$EXTERNALSYM SBSP_NAVIGATEFORWARD}
  1515.   SBSP_NAVIGATEFORWARD = $8000;
  1516.  
  1517.   {$EXTERNALSYM SBSP_ALLOW_AUTONAVIGATE}
  1518.   SBSP_ALLOW_AUTONAVIGATE = $10000;
  1519.  
  1520.   {$EXTERNALSYM SBSP_INITIATEDBYHLINKFRAME}
  1521.   SBSP_INITIATEDBYHLINKFRAME            = $80000000;
  1522.   {$EXTERNALSYM SBSP_REDIRECT}
  1523.   SBSP_REDIRECT                         = $40000000;
  1524.  
  1525.   {$EXTERNALSYM SBSP_WRITENOHISTORY}
  1526.   SBSP_WRITENOHISTORY     = $08000000;
  1527.   {$EXTERNALSYM SBSP_NOAUTOSELECT}
  1528.   SBSP_NOAUTOSELECT       = $04000000;
  1529.  
  1530. { Values for id parameter of ISB.GetWindow/SendControlMsg members. }
  1531.  
  1532. { WARNING: }
  1533. {  Any shell extensions which sends messages to those control windows }
  1534. { might not work in the future version of windows. If you really need }
  1535. { to send messages to them, (1) don't assume that those control window }
  1536. { always exist (i.e. GetControlWindow may fail) and (2) verify the window }
  1537. { class of the window before sending any messages. }
  1538.  
  1539.   {$EXTERNALSYM FCW_STATUS}
  1540.   FCW_STATUS          = $0001;
  1541.   {$EXTERNALSYM FCW_TOOLBAR}
  1542.   FCW_TOOLBAR         = $0002;
  1543.   {$EXTERNALSYM FCW_TREE}
  1544.   FCW_TREE            = $0003;
  1545.   {$EXTERNALSYM FCW_INTERNETBAR}
  1546.   FCW_INTERNETBAR     = $0006;
  1547.   {$EXTERNALSYM FCW_PROGRESS}
  1548.   FCW_PROGRESS        = $0008;
  1549.  
  1550.  
  1551. { Values for uFlags paremeter of ISB.SetToolbarItems member. }
  1552.  
  1553.   {$EXTERNALSYM FCT_MERGE}
  1554.   FCT_MERGE           = $0001;
  1555.   {$EXTERNALSYM FCT_CONFIGABLE}
  1556.   FCT_CONFIGABLE      = $0002;
  1557.   {$EXTERNALSYM FCT_ADDTOEND}
  1558.   FCT_ADDTOEND        = $0004;
  1559.  
  1560. { ICommDlgBrowser.OnStateChange values }
  1561.  
  1562.   {$EXTERNALSYM CDBOSC_SETFOCUS}
  1563.   CDBOSC_SETFOCUS         = $00000000;
  1564.   {$EXTERNALSYM CDBOSC_KILLFOCUS}
  1565.   CDBOSC_KILLFOCUS        = $00000001;
  1566.   {$EXTERNALSYM CDBOSC_SELCHANGE}
  1567.   CDBOSC_SELCHANGE        = $00000002;
  1568.   {$EXTERNALSYM CDBOSC_RENAME}
  1569.   CDBOSC_RENAME           = $00000003;
  1570.  
  1571. { shellview select item flags }
  1572.  
  1573.   {$EXTERNALSYM SVSI_DESELECT}
  1574.   SVSI_DESELECT           = $0000;
  1575.   {$EXTERNALSYM SVSI_SELECT}
  1576.   SVSI_SELECT             = $0001;
  1577.   {$EXTERNALSYM SVSI_EDIT}
  1578.   SVSI_EDIT               = $0003;  { includes select }
  1579.   {$EXTERNALSYM SVSI_DESELECTOTHERS}
  1580.   SVSI_DESELECTOTHERS     = $0004;
  1581.   {$EXTERNALSYM SVSI_ENSUREVISIBLE}
  1582.   SVSI_ENSUREVISIBLE      = $0008;
  1583.   {$EXTERNALSYM SVSI_FOCUSED}
  1584.   SVSI_FOCUSED            = $0010;
  1585.   {$EXTERNALSYM SVSI_TRANSLATEPT}
  1586.   SVSI_TRANSLATEPT        = $0020;
  1587.  
  1588. { shellview get item object flags }
  1589.  
  1590.   {$EXTERNALSYM SVGIO_BACKGROUND}
  1591.   SVGIO_BACKGROUND        = $00000000;
  1592.   {$EXTERNALSYM SVGIO_SELECTION}
  1593.   SVGIO_SELECTION         = $00000001;
  1594.   {$EXTERNALSYM SVGIO_ALLVIEW}
  1595.   SVGIO_ALLVIEW           = $00000002;
  1596.  
  1597. type
  1598.   {$EXTERNALSYM HOLEMENU}
  1599.   HOLEMENU = HGLOBAL; // !!! should this be in ole2.pas?
  1600.  
  1601.   IShellView = interface;
  1602.  
  1603.   {$EXTERNALSYM IShellBrowser}
  1604.   IShellBrowser = interface(IOleWindow)
  1605.     [SID_IShellBrowser]
  1606.     function InsertMenusSB(hMenuShared: HMENU;
  1607.       out MenuWidths: TOleMenuGroupWidths): HResult; stdcall;
  1608.     function SetMenuSB(hMenuShared: HMENU;
  1609.       hOleMenuReserved: HOLEMENU; hwndActiveObject: HWND): HResult; stdcall;
  1610.     function RemoveMenusSB(hMenuShared: HMENU): HResult; stdcall;
  1611.     function SetStatusTextSB(StatusText: POleStr): HResult; stdcall;
  1612.     function EnableModelessSB(Enable: BOOL): HResult; stdcall;
  1613.     function TranslateAcceleratorSB(Msg: PMsg; ID: Word): HResult; stdcall;
  1614.     function BrowseObject(pidl: PItemIDList; flags: UINT): HResult; stdcall;
  1615.     function GetViewStateStream(Mode: DWORD; out Stream: IStream): HResult; stdcall;
  1616.     function GetControlWindow(ID: UINT; out Wnd: HWND): HResult; stdcall;
  1617.     function SendControlMsg(ID, Msg: UINT; wParm: WPARAM; lParm: LPARAM;
  1618.       var Rslt: LResult): HResult; stdcall;
  1619.     function QueryActiveShellView(var ShellView: IShellView): HResult; stdcall;
  1620.     function OnViewWindowActive(var ShellView: IShellView): HResult; stdcall;
  1621.     function SetToolbarItems(TBButton: PTBButton;
  1622.       nButtons, uFlags: UINT): HResult; stdcall;
  1623.   end;
  1624.  
  1625.   {$EXTERNALSYM TSBSCEnums}
  1626.   TSBSCEnums = (SBSC_HIDE, SBSC_SHOW, SBSC_TOGGLE, SBSC_QUERY);
  1627.  
  1628.   {$EXTERNALSYM TSBOEnums}
  1629.   TSBOEnums = (SBO_DEFAULT, SBO_NOBROWSERPAGES);
  1630.  
  1631.  
  1632. { CommandTarget ids. }
  1633.   {$EXTERNALSYM TSBCMDIDEnums}
  1634.   TSBCMDIDEnums = (
  1635.     SBCMDID_ENABLESHOWTREE,
  1636.     SBCMDID_SHOWCONTROL,                { variant vt_i4 = loword = FCW_* hiword = SBSC_* }
  1637.     SBCMDID_CANCELNAVIGATION,           { cancel last navigation }
  1638.     SBCMDID_MAYSAVECHANGES,             { about to close and may save changes }
  1639.     SBCMDID_SETHLINKFRAME,              { variant vt_i4 = phlinkframe }
  1640.     SBCMDID_ENABLESTOP,                 { variant vt_bool = fEnable }
  1641.     SBCMDID_OPTIONS                     { the view.options page }
  1642.   );
  1643.  
  1644.  
  1645. { ICommDlgBrowser interface }
  1646.  
  1647. {  ICommDlgBrowser interface is the interface that is provided by the new }
  1648. { common dialog window to hook and modify the behavior of IShellView.  When }
  1649. { a default view is created, it queries its parent IShellBrowser for the }
  1650. { ICommDlgBrowser interface.  If supported, it calls out to that interface }
  1651. { in several cases that need to behave differently in a dialog. }
  1652.  
  1653. { Member functions: }
  1654.  
  1655. {  ICommDlgBrowser.OnDefaultCommand() }
  1656. {    Called when the user double-clicks in the view or presses Enter.  The }
  1657. {   browser should return S_OK if it processed the action itself, S_FALSE }
  1658. {   to let the view perform the default action. }
  1659.  
  1660. {  ICommDlgBrowser.OnStateChange(ULONG uChange) }
  1661. {    Called when some states in the view change.  'uChange' is one of the }
  1662. {   CDBOSC_* values.  This call is made after the state (selection, focus, }
  1663. {   etc) has changed.  There is no return value. }
  1664.  
  1665. {  ICommDlgBrowser.IncludeObject(LPCITEMIDLIST pidl) }
  1666. {    Called when the view is enumerating objects.  'pidl' is a relative }
  1667. {   IDLIST.  The browser should return S_OK to include the object in the }
  1668. {   view, S_FALSE to hide it }
  1669.  
  1670. { ------------------------------------------------------------------------- }
  1671.  
  1672.   {$EXTERNALSYM ICommDlgBrowser}
  1673.   ICommDlgBrowser = interface(IUnknown)
  1674.     [SID_ICommDlgBrowser]
  1675.     function OnDefaultCommand(const ppshv: IShellView): HResult; stdcall;
  1676.     function OnStateChange(const ppshv: IShellView; Change: ULONG): HResult; stdcall;
  1677.     function IncludeObject(const ppshv: IShellView; pidl: PItemIDList): HResult; stdcall;
  1678.   end;
  1679.  
  1680.  
  1681. { Interface:   IShellView }
  1682.  
  1683. { IShellView.ContextSensitiveHelp(fEnterMode) }
  1684.  
  1685. {   Inherited from IOleWindow.ContextSensitiveHelp. }
  1686.  
  1687.  
  1688. { IShellView.TranslateAccelerator(lpmsg) }
  1689.  
  1690. {   Similar to IOleInPlaceActiveObject.TranlateAccelerator. The explorer }
  1691. {  calls this function BEFORE any other translation. Returning S_OK }
  1692. {  indicates that the message was translated (eaten) and should not be }
  1693. {  translated or dispatched by the explorer. }
  1694.  
  1695.  
  1696. { IShellView.EnableModeless(fEnable) }
  1697.  
  1698. {   Similar to IOleInPlaceActiveObject.EnableModeless. }
  1699.  
  1700.  
  1701. { IShellView.UIActivate(uState) }
  1702.  
  1703. {   The explorer calls this member function whenever the activation }
  1704. {  state of the view window is changed by a certain event that is }
  1705. {  NOT caused by the shell view itself. }
  1706.  
  1707. {   SVUIA_DEACTIVATE will be passed when the explorer is about to }
  1708. {  destroy the shell view window; the shell view is supposed to remove }
  1709. {  all the extended UIs (typically merged menu and modeless popup windows). }
  1710.  
  1711. {   SVUIA_ACTIVATE_NOFOCUS will be passsed when the shell view is losing }
  1712. {  the input focus or the shell view has been just created without the }
  1713. {  input focus; the shell view is supposed to set menuitems appropriate }
  1714. {  for non-focused state (no selection specific items should be added). }
  1715.  
  1716. {   SVUIA_ACTIVATE_FOCUS will be passed when the explorer has just }
  1717. {  created the view window with the input focus; the shell view is }
  1718. {  supposed to set menuitems appropriate for focused state. }
  1719.  
  1720. {   SVUIA_INPLACEACTIVATE(new) will be passed when the shell view is opened }
  1721. {  within an ActiveX control, which is not a UI active. In this case, }
  1722. {  the shell view should not merge menus or put toolbas. To be compatible }
  1723. {  with Win95 client, we don't pass this value unless the view supports }
  1724. {  IShellView2. }
  1725.  
  1726. {   The shell view should not change focus within this member function. }
  1727. {  The shell view should not hook the WM_KILLFOCUS message to remerge }
  1728. {  menuitems. However, the shell view typically hook the WM_SETFOCUS }
  1729. {  message, and re-merge the menu after calling IShellBrowser. }
  1730. {  OnViewWindowActivated. }
  1731.  
  1732.  
  1733. { IShellView.Refresh() }
  1734.  
  1735. {   The explorer calls this member when the view needs to refresh its }
  1736. {  contents (such as when the user hits F5 key). }
  1737.  
  1738.  
  1739. { IShellView.CreateViewWindow }
  1740.  
  1741. {   This member creates the view window (right-pane of the explorer or the }
  1742. {  client window of the folder window). }
  1743.  
  1744.  
  1745. { IShellView.DestroyViewWindow }
  1746.  
  1747. {   This member destroys the view window. }
  1748.  
  1749.  
  1750. { IShellView.GetCurrentInfo }
  1751.  
  1752. {   This member returns the folder settings. }
  1753.  
  1754.  
  1755. { IShellView.AddPropertySHeetPages }
  1756.  
  1757. {   The explorer calls this member when it is opening the option property }
  1758. {  sheet. This allows the view to add additional pages to it. }
  1759.  
  1760.  
  1761. { IShellView.SaveViewState() }
  1762.  
  1763. {   The explorer calls this member when the shell view is supposed to }
  1764. {  store its view settings. The shell view is supposed to get a view }
  1765. {  stream by calling IShellBrowser.GetViewStateStream and store the }
  1766. {  current view state into that stream. }
  1767.  
  1768.  
  1769. { IShellView.SelectItem(pidlItem, uFlags) }
  1770.  
  1771. {   The explorer calls this member to change the selection state of }
  1772. {  item(s) within the shell view window.  If pidlItem is NULL and uFlags }
  1773. {  is SVSI_DESELECTOTHERS, all items should be deselected. }
  1774.  
  1775. { ------------------------------------------------------------------------- }
  1776.  
  1777. { uState values for IShellView.UIActivate }
  1778.  
  1779.   {$EXTERNALSYM TSVUIAEnums}
  1780.   TSVUIAEnums = (
  1781.     SVUIA_DEACTIVATE,
  1782.     SVUIA_ACTIVATE_NOFOCUS,
  1783.     SVUIA_ACTIVATE_FOCUS,
  1784.     SVUIA_INPLACEACTIVATE               { new flag for IShellView2 }
  1785.   );
  1786.  
  1787.   {$EXTERNALSYM IShellView}
  1788.   IShellView = interface(IOleWindow)
  1789.     [SID_IShellView]
  1790.     function TranslateAccelerator(var Msg: TMsg): HResult; stdcall;
  1791.     function EnableModeless(Enable: Boolean): HResult; stdcall;
  1792.     function UIActivate(State: UINT): HResult; stdcall;
  1793.     function Refresh: HResult; stdcall;
  1794.     function CreateViewWindow(PrevView: IShellView;
  1795.       var FolderSettings: TFolderSettings; ShellBrowser: IShellBrowser;
  1796.       var Rect: TRect; out Wnd: HWND): HResult; stdcall;
  1797.     function DestroyViewWindow: HResult; stdcall;
  1798.     function GetCurrentInfo(out FolderSettings: TFolderSettings): HResult; stdcall;
  1799.     function AddPropertySheetPages(Reseved: DWORD;
  1800.       var lpfnAddPage: TFNAddPropSheetPage; lParam: LPARAM): HResult; stdcall;
  1801.     function SaveViewState: HResult; stdcall;
  1802.     function SelectItem(pidl: PItemIDList; flags: UINT): HResult; stdcall;
  1803.     function GetItemObject(Item: UINT; const iid: TIID; var IPtr: Pointer): HResult; stdcall;
  1804.   end;
  1805.  
  1806. const
  1807.   {$EXTERNALSYM SV2GV_CURRENTVIEW}
  1808.   SV2GV_CURRENTVIEW     = -1;
  1809.   {$EXTERNALSYM SV2GV_DEFAULTVIEW}
  1810.   SV2GV_DEFAULTVIEW     = -2;
  1811.  
  1812. type
  1813.   {$EXTERNALSYM SHELLVIEWID}
  1814.   SHELLVIEWID = TGUID;
  1815.   TShellViewID = SHELLVIEWID;
  1816.   PShellViewID = ^TShellViewID;
  1817.  
  1818.   PSV2CreateParams = ^TSV2CreateParams;
  1819.   {$EXTERNALSYM _SV2CVW2_PARAMS}
  1820.   _SV2CVW2_PARAMS = record
  1821.     cbSize: DWORD;
  1822.     psvPrev: IShellView;
  1823.     pfs: PFolderSettings;
  1824.     psbOwner: IShellBrowser;
  1825.     prcView: PRect;
  1826.     pvid: PShellViewID;
  1827.     hwndView: HWND;
  1828.   end;
  1829.   TSV2CreateParams = _SV2CVW2_PARAMS;
  1830.   {$EXTERNALSYM SV2CVW2_PARAMS}
  1831.   SV2CVW2_PARAMS = _SV2CVW2_PARAMS;
  1832.  
  1833.  
  1834.   {$EXTERNALSYM IShellView2}
  1835.   IShellView2 = interface(IShellView)
  1836.     [SID_IShellView2]
  1837.     function GetView(pvid: PShellViewID; uView: ULONG): HResult; stdcall;
  1838.     function CreateViewWindow2(SV2CreateParams: PSV2CreateParams): HResult; stdcall;
  1839.     function HandleRename(pidlNew: PItemIDList): HResult; stdcall;
  1840.     function SelectAndPositionItem(pidlItem: PItemIDList; uFlags: UINT;
  1841.       var Point: TPoint): HResult; stdcall;
  1842.   end;
  1843.  
  1844. { ------------------------------------------------------------------------- }
  1845.  
  1846. const
  1847.   {$EXTERNALSYM STRRET_WSTR}
  1848.   STRRET_WSTR         = $0000;          { Use STRRET.pOleStr }
  1849.   {$EXTERNALSYM STRRET_OFFSET}
  1850.   STRRET_OFFSET       = $0001;          { Use STRRET.uOffset to Ansi }
  1851.   {$EXTERNALSYM STRRET_CSTR}
  1852.   STRRET_CSTR         = $0002;          { Use STRRET.cStr }
  1853.  
  1854. type
  1855. { record for returning strings from IShellFolder member functions }
  1856.  
  1857.   PSTRRet = ^TStrRet;
  1858.   {$EXTERNALSYM _STRRET}
  1859.   _STRRET = record
  1860.      uType: UINT;              { One of the STRRET_* values }
  1861.      case Integer of
  1862.        0: (pOleStr: LPWSTR);                    { must be freed by caller of GetDisplayNameOf }
  1863.        1: (pStr: LPSTR);                        { NOT USED }
  1864.        2: (uOffset: UINT);                      { Offset into SHITEMID (ANSI) }
  1865.        3: (cStr: array[0..MAX_PATH-1] of Char); { Buffer to fill in }
  1866.     end;
  1867.   TStrRet = _STRRET;
  1868.   {$EXTERNALSYM STRRET}
  1869.   STRRET = _STRRET;
  1870.  
  1871.  
  1872. { SHGetPathFromIDList }
  1873.  
  1874. { This function assumes the size of the buffer (MAX_PATH). The pidl
  1875.   should point to a file system object. }
  1876.  
  1877. {$EXTERNALSYM SHGetPathFromIDListA}
  1878. function SHGetPathFromIDListA(pidl: PItemIDList; pszPath: PAnsiChar): BOOL; stdcall;
  1879. {$EXTERNALSYM SHGetPathFromIDListW}
  1880. function SHGetPathFromIDListW(pidl: PItemIDList; pszPath: PWideChar): BOOL; stdcall;
  1881. {$EXTERNALSYM SHGetPathFromIDList}
  1882. function SHGetPathFromIDList(pidl: PItemIDList; pszPath: PChar): BOOL; stdcall;
  1883.  
  1884. { SHGetSpecialFolderLocation }
  1885.  
  1886. { Caller should use SHGetMalloc to obtain an allocator that can free the pidl }
  1887.  
  1888. const
  1889. { registry entries for special paths are kept in : }
  1890.  
  1891.   {$EXTERNALSYM REGSTR_PATH_SPECIAL_FOLDERS}
  1892.   REGSTR_PATH_SPECIAL_FOLDERS   = REGSTR_PATH_EXPLORER + '\Shell Folders';
  1893.   {$EXTERNALSYM CSIDL_DESKTOP}
  1894.   CSIDL_DESKTOP                       = $0000;
  1895.   {$EXTERNALSYM CSIDL_INTERNET}
  1896.   CSIDL_INTERNET                      = $0001;
  1897.   {$EXTERNALSYM CSIDL_PROGRAMS}
  1898.   CSIDL_PROGRAMS                      = $0002;
  1899.   {$EXTERNALSYM CSIDL_CONTROLS}
  1900.   CSIDL_CONTROLS                      = $0003;
  1901.   {$EXTERNALSYM CSIDL_PRINTERS}
  1902.   CSIDL_PRINTERS                      = $0004;
  1903.   {$EXTERNALSYM CSIDL_PERSONAL}
  1904.   CSIDL_PERSONAL                      = $0005;
  1905.   {$EXTERNALSYM CSIDL_FAVORITES}
  1906.   CSIDL_FAVORITES                     = $0006;
  1907.   {$EXTERNALSYM CSIDL_STARTUP}
  1908.   CSIDL_STARTUP                       = $0007;
  1909.   {$EXTERNALSYM CSIDL_RECENT}
  1910.   CSIDL_RECENT                        = $0008;
  1911.   {$EXTERNALSYM CSIDL_SENDTO}
  1912.   CSIDL_SENDTO                        = $0009;
  1913.   {$EXTERNALSYM CSIDL_BITBUCKET}
  1914.   CSIDL_BITBUCKET                     = $000a;
  1915.   {$EXTERNALSYM CSIDL_STARTMENU}
  1916.   CSIDL_STARTMENU                     = $000b;
  1917.   {$EXTERNALSYM CSIDL_DESKTOPDIRECTORY}
  1918.   CSIDL_DESKTOPDIRECTORY              = $0010;
  1919.   {$EXTERNALSYM CSIDL_DRIVES}
  1920.   CSIDL_DRIVES                        = $0011;
  1921.   {$EXTERNALSYM CSIDL_NETWORK}
  1922.   CSIDL_NETWORK                       = $0012;
  1923.   {$EXTERNALSYM CSIDL_NETHOOD}
  1924.   CSIDL_NETHOOD                       = $0013;
  1925.   {$EXTERNALSYM CSIDL_FONTS}
  1926.   CSIDL_FONTS                         = $0014;
  1927.   {$EXTERNALSYM CSIDL_TEMPLATES}
  1928.   CSIDL_TEMPLATES                     = $0015;
  1929.   {$EXTERNALSYM CSIDL_COMMON_STARTMENU}
  1930.   CSIDL_COMMON_STARTMENU              = $0016;
  1931.   {$EXTERNALSYM CSIDL_COMMON_PROGRAMS}
  1932.   CSIDL_COMMON_PROGRAMS               = $0017;
  1933.   {$EXTERNALSYM CSIDL_COMMON_STARTUP}
  1934.   CSIDL_COMMON_STARTUP                = $0018;
  1935.   {$EXTERNALSYM CSIDL_COMMON_DESKTOPDIRECTORY}
  1936.   CSIDL_COMMON_DESKTOPDIRECTORY       = $0019;
  1937.   {$EXTERNALSYM CSIDL_APPDATA}
  1938.   CSIDL_APPDATA                       = $001a;
  1939.   {$EXTERNALSYM CSIDL_PRINTHOOD}
  1940.   CSIDL_PRINTHOOD                     = $001b;
  1941.   {$EXTERNALSYM CSIDL_ALTSTARTUP}
  1942.   CSIDL_ALTSTARTUP                = $001d;         // DBCS
  1943.   {$EXTERNALSYM CSIDL_COMMON_ALTSTARTUP}
  1944.   CSIDL_COMMON_ALTSTARTUP         = $001e;         // DBCS
  1945.   {$EXTERNALSYM CSIDL_COMMON_FAVORITES}
  1946.   CSIDL_COMMON_FAVORITES          = $001f;
  1947.   {$EXTERNALSYM CSIDL_INTERNET_CACHE}
  1948.   CSIDL_INTERNET_CACHE            = $0020;
  1949.   {$EXTERNALSYM CSIDL_COOKIES}
  1950.   CSIDL_COOKIES                   = $0021;
  1951.   {$EXTERNALSYM CSIDL_HISTORY}
  1952.   CSIDL_HISTORY                   = $0022;
  1953.  
  1954. {$EXTERNALSYM SHGetSpecialFolderLocation}
  1955. function SHGetSpecialFolderLocation(hwndOwner: HWND; nFolder: Integer;
  1956.   var ppidl: PItemIDList): HResult; stdcall;
  1957.  
  1958. function SHGetSpecialFolderPathA(hwndOwner: HWND; lpszPath: PAnsiChar;
  1959.   nFolder: Integer; fCreate: BOOL): BOOL; stdcall;
  1960. {$EXTERNALSYM SHGetSpecialFolderPathA}
  1961. function SHGetSpecialFolderPathW(hwndOwner: HWND; lpszPath: PWideChar;
  1962.   nFolder: Integer; fCreate: BOOL): BOOL; stdcall;
  1963. {$EXTERNALSYM SHGetSpecialFolderPathW}
  1964. function SHGetSpecialFolderPath(hwndOwner: HWND; lpszPath: PChar;
  1965.   nFolder: Integer; fCreate: BOOL): BOOL; stdcall;
  1966. {$EXTERNALSYM SHGetSpecialFolderPath}
  1967.  
  1968. { SHBrowseForFolder API }
  1969.  
  1970. type
  1971.   {$EXTERNALSYM BFFCALLBACK}
  1972.   BFFCALLBACK = function(Wnd: HWND; uMsg: UINT; lParam, lpData: LPARAM): Integer stdcall;
  1973.   TFNBFFCallBack = type BFFCALLBACK;
  1974.  
  1975.   PBrowseInfoA = ^TBrowseInfoA;
  1976.   PBrowseInfoW = ^TBrowseInfoW;
  1977.   PBrowseInfo = PBrowseInfoA;
  1978.   {$EXTERNALSYM _browseinfoA}
  1979.   _browseinfoA = record
  1980.     hwndOwner: HWND;
  1981.     pidlRoot: PItemIDList;
  1982.     pszDisplayName: PAnsiChar;  { Return display name of item selected. }
  1983.     lpszTitle: PAnsiChar;      { text to go in the banner over the tree. }
  1984.     ulFlags: UINT;           { Flags that control the return stuff }
  1985.     lpfn: TFNBFFCallBack;
  1986.     lParam: LPARAM;          { extra info that's passed back in callbacks }
  1987.     iImage: Integer;         { output var: where to return the Image index. }
  1988.   end;
  1989.   {$EXTERNALSYM _browseinfoW}
  1990.   _browseinfoW = record
  1991.     hwndOwner: HWND;
  1992.     pidlRoot: PItemIDList;
  1993.     pszDisplayName: PWideChar;  { Return display name of item selected. }
  1994.     lpszTitle: PWideChar;      { text to go in the banner over the tree. }
  1995.     ulFlags: UINT;           { Flags that control the return stuff }
  1996.     lpfn: TFNBFFCallBack;
  1997.     lParam: LPARAM;          { extra info that's passed back in callbacks }
  1998.     iImage: Integer;         { output var: where to return the Image index. }
  1999.   end;
  2000.   {$EXTERNALSYM _browseinfo}
  2001.   _browseinfo = _browseinfoA;
  2002.   TBrowseInfoA = _browseinfoA;
  2003.   TBrowseInfoW = _browseinfoW;
  2004.   TBrowseInfo = TBrowseInfoA;
  2005.   {$EXTERNALSYM BROWSEINFOA}
  2006.   BROWSEINFOA = _browseinfoA;
  2007.   {$EXTERNALSYM BROWSEINFOW}
  2008.   BROWSEINFOW = _browseinfoW;
  2009.   {$EXTERNALSYM BROWSEINFO}
  2010.   BROWSEINFO = BROWSEINFOA;
  2011.  
  2012. const
  2013. { Browsing for directory. }
  2014.  
  2015.   {$EXTERNALSYM BIF_RETURNONLYFSDIRS}
  2016.   BIF_RETURNONLYFSDIRS   = $0001;  { For finding a folder to start document searching }
  2017.   {$EXTERNALSYM BIF_DONTGOBELOWDOMAIN}
  2018.   BIF_DONTGOBELOWDOMAIN  = $0002;  { For starting the Find Computer }
  2019.   {$EXTERNALSYM BIF_STATUSTEXT}
  2020.   BIF_STATUSTEXT         = $0004;
  2021.   {$EXTERNALSYM BIF_RETURNFSANCESTORS}
  2022.   BIF_RETURNFSANCESTORS  = $0008;
  2023.   {$EXTERNALSYM BIF_EDITBOX}
  2024.   BIF_EDITBOX            = $0010;
  2025.   {$EXTERNALSYM BIF_VALIDATE}
  2026.   BIF_VALIDATE           = $0020;  { insist on valid result (or CANCEL) }
  2027.  
  2028.   {$EXTERNALSYM BIF_BROWSEFORCOMPUTER}
  2029.   BIF_BROWSEFORCOMPUTER  = $1000;  { Browsing for Computers. }
  2030.   {$EXTERNALSYM BIF_BROWSEFORPRINTER}
  2031.   BIF_BROWSEFORPRINTER   = $2000;  { Browsing for Printers }
  2032.   {$EXTERNALSYM BIF_BROWSEINCLUDEFILES}
  2033.   BIF_BROWSEINCLUDEFILES = $4000;  { Browsing for Everything }
  2034.  
  2035. { message from browser }
  2036.  
  2037.   {$EXTERNALSYM BFFM_INITIALIZED}
  2038.   BFFM_INITIALIZED       = 1;
  2039.   {$EXTERNALSYM BFFM_SELCHANGED}
  2040.   BFFM_SELCHANGED        = 2;
  2041.   {$EXTERNALSYM BFFM_VALIDATEFAILEDA}
  2042.   BFFM_VALIDATEFAILEDA   = 3;   { lParam:szPath ret:1(cont),0(EndDialog) }
  2043.   {$EXTERNALSYM BFFM_VALIDATEFAILEDW}
  2044.   BFFM_VALIDATEFAILEDW   = 4;   { lParam:wzPath ret:1(cont),0(EndDialog) }
  2045.  
  2046. { messages to browser }
  2047.  
  2048.   {$EXTERNALSYM BFFM_SETSTATUSTEXTA}
  2049.   BFFM_SETSTATUSTEXTA         = WM_USER + 100;
  2050.   {$EXTERNALSYM BFFM_ENABLEOK}
  2051.   BFFM_ENABLEOK               = WM_USER + 101;
  2052.   {$EXTERNALSYM BFFM_SETSELECTIONA}
  2053.   BFFM_SETSELECTIONA          = WM_USER + 102;
  2054.   {$EXTERNALSYM BFFM_SETSELECTIONW}
  2055.   BFFM_SETSELECTIONW          = WM_USER + 103;
  2056.   {$EXTERNALSYM BFFM_SETSTATUSTEXTW}
  2057.   BFFM_SETSTATUSTEXTW         = WM_USER + 104;
  2058.  
  2059.  
  2060.  
  2061.  
  2062.  
  2063.  
  2064.  
  2065.  
  2066.   {$EXTERNALSYM BFFM_VALIDATEFAILED}
  2067.   BFFM_VALIDATEFAILED     = BFFM_VALIDATEFAILEDA;
  2068.   {$EXTERNALSYM BFFM_SETSTATUSTEXT}
  2069.   BFFM_SETSTATUSTEXT      = BFFM_SETSTATUSTEXTA;
  2070.   {$EXTERNALSYM BFFM_SETSELECTION}
  2071.   BFFM_SETSELECTION       = BFFM_SETSELECTIONA;
  2072.  
  2073. {$EXTERNALSYM SHBrowseForFolderA}
  2074. function SHBrowseForFolderA(var lpbi: TBrowseInfoA): PItemIDList; stdcall;
  2075. {$EXTERNALSYM SHBrowseForFolderW}
  2076. function SHBrowseForFolderW(var lpbi: TBrowseInfoW): PItemIDList; stdcall;
  2077. {$EXTERNALSYM SHBrowseForFolder}
  2078. function SHBrowseForFolder(var lpbi: TBrowseInfo): PItemIDList; stdcall;
  2079.  
  2080. { SHLoadInProc }
  2081.  
  2082. { When this function is called, the shell calls CoCreateInstance
  2083.   (or equivalent) with CLSCTX_INPROC_SERVER and the specified CLSID
  2084.   from within the shell's process and release it immediately. }
  2085.  
  2086. {$EXTERNALSYM SHLoadInProc}
  2087. function SHLoadInProc(rclsid: TCLSID): HRESULT; stdcall;
  2088.  
  2089. { IEnumIDList interface }
  2090.  
  2091. { IShellFolder.EnumObjects member returns an IEnumIDList object. }
  2092.  
  2093. type
  2094.   {$EXTERNALSYM IEnumIDList}
  2095.   IEnumIDList = interface(IUnknown)
  2096.     [SID_IEnumIDList]
  2097.     function Next(celt: ULONG; out rgelt: PItemIDList;
  2098.       var pceltFetched: ULONG): HResult; stdcall;
  2099.     function Skip(celt: ULONG): HResult; stdcall;
  2100.     function Reset: HResult; stdcall;
  2101.     function Clone(out ppenum: IEnumIDList): HResult; stdcall;
  2102.   end;
  2103.  
  2104. { IShellFolder interface }
  2105.  
  2106. { [Member functions] }
  2107.  
  2108. { IShellFolder.BindToObject(pidl, pbc, riid, ppvOut)
  2109.   This function returns an instance of a sub-folder which is specified
  2110.   by the IDList (pidl).
  2111.  IShellFolder.BindToStorage(pidl, pbc, riid, ppvObj)
  2112.    This function returns a storage instance of a sub-folder which is
  2113.    specified by the IDList (pidl). The shell never calls this member
  2114.    function in the first release of Win95.
  2115.  IShellFolder.CompareIDs(lParam, pidl1, pidl2)
  2116.    This function compares two IDLists and returns the result. The shell
  2117.    explorer always passes 0 as lParam, which indicates 'sort by name'.
  2118.    It should return 0 (as CODE of the scode), if two id indicates the
  2119.    same object; negative value if pidl1 should be placed before pidl2;
  2120.    positive value if pidl2 should be placed before pidl1.
  2121.  IShellFolder.CreateViewObject(hwndOwner, riid, ppvOut)
  2122.    This function creates a view object of the folder itself. The view
  2123.    object is a difference instance from the shell folder object.
  2124.    "hwndOwner" can be used  as the owner window of its dialog box or
  2125.       menu during the lifetime of the view object.
  2126.    instance which has only one reference count. The explorer may create
  2127.    more than one instances of view object from one shell folder object
  2128.    and treat them as separate instances.
  2129.  IShellFolder.GetAttributesOf(cidl, apidl, prgfInOut)
  2130.    This function returns the attributes of specified objects in that
  2131.    folder. 'cidl' and 'apidl' specifies objects. 'apidl' contains only
  2132.    simple IDLists. The explorer initializes *prgfInOut with a set of
  2133.    flags to be evaluated. The shell folder may optimize the operation
  2134.    by not returning unspecified flags.
  2135.  IShellFolder.GetUIObjectOf(hwndOwner, cidl, apidl, riid, prgfInOut, ppvOut)
  2136.    This function creates a UI object to be used for specified objects.
  2137.    The shell explorer passes either IID_IDataObject (for transfer operation)
  2138.    or IID_IContextMenu (for context menu operation) as riid.
  2139.  IShellFolder.GetDisplayNameOf
  2140.    This function returns the display name of the specified object.
  2141.    If the ID contains the display name (in the locale character set),
  2142.    it returns the offset to the name. Otherwise, it returns a pointer
  2143.    to the display name string (UNICODE), which is allocated by the
  2144.    task allocator, or fills in a buffer.
  2145.  IShellFolder.SetNameOf
  2146.    This function sets the display name of the specified object.
  2147.    If it changes the ID as well, it returns the new ID which is
  2148.    alocated by the task allocator. }
  2149.  
  2150. const
  2151. { IShellFolder.GetDisplayNameOf/SetNameOf uFlags }
  2152.  
  2153.   {$EXTERNALSYM SHGDN_NORMAL}
  2154.   SHGDN_NORMAL           = 0;         { default (display purpose) }
  2155.   {$EXTERNALSYM SHGDN_INFOLDER}
  2156.   SHGDN_INFOLDER         = 1;         { displayed under a folder (relative) }
  2157.   {$EXTERNALSYM SHGDN_INCLUDE_NONFILESYS}
  2158.   SHGDN_INCLUDE_NONFILESYS = $2000;   { if not set, display names for shell
  2159.                                         name space items that are not in the
  2160.                                         file system will fail. }
  2161.   {$EXTERNALSYM SHGDN_FORADDRESSBAR}
  2162.   SHGDN_FORADDRESSBAR      = $4000;     { for displaying in the address (drives dropdown) bar }
  2163.   {$EXTERNALSYM SHGDN_FORPARSING}
  2164.   SHGDN_FORPARSING         = $8000;     { for ParseDisplayName or path }
  2165.  
  2166. { IShellFolder.EnumObjects }
  2167.  
  2168.   {$EXTERNALSYM SHCONTF_FOLDERS}
  2169.   SHCONTF_FOLDERS         = 32;       { for shell browser }
  2170.   {$EXTERNALSYM SHCONTF_NONFOLDERS}
  2171.   SHCONTF_NONFOLDERS      = 64;       { for default view }
  2172.   {$EXTERNALSYM SHCONTF_INCLUDEHIDDEN}
  2173.   SHCONTF_INCLUDEHIDDEN   = 128;      { for hidden/system objects }
  2174.  
  2175. { IShellFolder.GetAttributesOf flags }
  2176.  
  2177.   {$EXTERNALSYM SFGAO_CANCOPY}
  2178.   SFGAO_CANCOPY           = DROPEFFECT_COPY; { Objects can be copied }
  2179.   {$EXTERNALSYM SFGAO_CANMOVE}
  2180.   SFGAO_CANMOVE           = DROPEFFECT_MOVE; { Objects can be moved }
  2181.   {$EXTERNALSYM SFGAO_CANLINK}
  2182.   SFGAO_CANLINK           = DROPEFFECT_LINK; { Objects can be linked }
  2183.   {$EXTERNALSYM SFGAO_CANRENAME}
  2184.   SFGAO_CANRENAME         = $00000010;       { Objects can be renamed }
  2185.   {$EXTERNALSYM SFGAO_CANDELETE}
  2186.   SFGAO_CANDELETE         = $00000020;       { Objects can be deleted }
  2187.   {$EXTERNALSYM SFGAO_HASPROPSHEET}
  2188.   SFGAO_HASPROPSHEET      = $00000040;       { Objects have property sheets }
  2189.   {$EXTERNALSYM SFGAO_DROPTARGET}
  2190.   SFGAO_DROPTARGET        = $00000100;       { Objects are drop target }
  2191.   {$EXTERNALSYM SFGAO_CAPABILITYMASK}
  2192.   SFGAO_CAPABILITYMASK    = $00000177;
  2193.   {$EXTERNALSYM SFGAO_LINK}
  2194.   SFGAO_LINK              = $00010000;       { Shortcut (link) }
  2195.   {$EXTERNALSYM SFGAO_SHARE}
  2196.   SFGAO_SHARE             = $00020000;       { shared }
  2197.   {$EXTERNALSYM SFGAO_READONLY}
  2198.   SFGAO_READONLY          = $00040000;       { read-only }
  2199.   {$EXTERNALSYM SFGAO_GHOSTED}
  2200.   SFGAO_GHOSTED           = $00080000;       { ghosted icon }
  2201.   {$EXTERNALSYM SFGAO_HIDDEN}
  2202.   SFGAO_HIDDEN            = $00080000;       { hidden object }
  2203.   {$EXTERNALSYM SFGAO_DISPLAYATTRMASK}
  2204.   SFGAO_DISPLAYATTRMASK   = $000F0000;
  2205.   {$EXTERNALSYM SFGAO_FILESYSANCESTOR}
  2206.   SFGAO_FILESYSANCESTOR   = $10000000;       { It contains file system folder }
  2207.   {$EXTERNALSYM SFGAO_FOLDER}
  2208.   SFGAO_FOLDER            = $20000000;       { It's a folder. }
  2209.   {$EXTERNALSYM SFGAO_FILESYSTEM}
  2210.   SFGAO_FILESYSTEM        = $40000000;       { is a file system thing (file/folder/root) }
  2211.   {$EXTERNALSYM SFGAO_HASSUBFOLDER}
  2212.   SFGAO_HASSUBFOLDER      = $80000000;       { Expandable in the map pane }
  2213.   {$EXTERNALSYM SFGAO_CONTENTSMASK}
  2214.   SFGAO_CONTENTSMASK      = $80000000;
  2215.   {$EXTERNALSYM SFGAO_VALIDATE}
  2216.   SFGAO_VALIDATE          = $01000000;       { invalidate cached information }
  2217.   {$EXTERNALSYM SFGAO_REMOVABLE}
  2218.   SFGAO_REMOVABLE         = $02000000;       { is this removeable media? }
  2219.   {$EXTERNALSYM SFGAO_COMPRESSED}
  2220.   SFGAO_COMPRESSED        = $04000000;       { Object is compressed (use alt color) }
  2221.   {$EXTERNALSYM SFGAO_BROWSABLE}
  2222.   SFGAO_BROWSABLE         = $08000000;       { is in-place browsable }
  2223.   {$EXTERNALSYM SFGAO_NONENUMERATED}
  2224.   SFGAO_NONENUMERATED     = $00100000;       { is a non-enumerated object }
  2225.   {$EXTERNALSYM SFGAO_NEWCONTENT}
  2226.   SFGAO_NEWCONTENT        = $00200000;       { should show bold in explorer tree }
  2227.  
  2228. type
  2229.   {$EXTERNALSYM IShellFolder}
  2230.   IShellFolder = interface(IUnknown)
  2231.     [SID_IShellFolder]
  2232.     function ParseDisplayName(hwndOwner: HWND;
  2233.       pbcReserved: Pointer; lpszDisplayName: POLESTR; out pchEaten: ULONG;
  2234.       out ppidl: PItemIDList; var dwAttributes: ULONG): HResult; stdcall;
  2235.     function EnumObjects(hwndOwner: HWND; grfFlags: DWORD;
  2236.       out EnumIDList: IEnumIDList): HResult; stdcall;
  2237.     function BindToObject(pidl: PItemIDList; pbcReserved: Pointer;
  2238.       const riid: TIID; out ppvOut): HResult; stdcall;
  2239.     function BindToStorage(pidl: PItemIDList; pbcReserved: Pointer;
  2240.       const riid: TIID; out ppvObj): HResult; stdcall;
  2241.     function CompareIDs(lParam: LPARAM;
  2242.       pidl1, pidl2: PItemIDList): HResult; stdcall;
  2243.     function CreateViewObject(hwndOwner: HWND; const riid: TIID;
  2244.       out ppvOut): HResult; stdcall;
  2245.     function GetAttributesOf(cidl: UINT; var apidl: PItemIDList;
  2246.       var rgfInOut: UINT): HResult; stdcall;
  2247.     function GetUIObjectOf(hwndOwner: HWND; cidl: UINT; var apidl: PItemIDList;
  2248.       const riid: TIID; prgfInOut: Pointer; out ppvOut): HResult; stdcall;
  2249.     function GetDisplayNameOf(pidl: PItemIDList; uFlags: DWORD;
  2250.       var lpName: TStrRet): HResult; stdcall;
  2251.     function SetNameOf(hwndOwner: HWND; pidl: PItemIDList; lpszName: POLEStr;
  2252.       uFlags: DWORD; var ppidlOut: PItemIDList): HResult; stdcall;
  2253.   end;
  2254.  
  2255. { Helper function which returns a IShellFolder interface to the desktop
  2256.   folder. This is equivalent to call CoCreateInstance with CLSID_ShellDesktop. }
  2257.  
  2258. {$EXTERNALSYM SHGetDesktopFolder}
  2259. function SHGetDesktopFolder(var ppshf: IShellFolder): HResult; stdcall;
  2260.  
  2261. { IInputObjectSite/IInputObject interfaces
  2262.  
  2263.  These interfaces allow us (or ISVs) to install/update external Internet
  2264.  Toolbar for IE and the shell. The frame will simply get the CLSID from
  2265.  registry (to be defined) and CoCreateInstance it. }
  2266.  
  2267. { IInputObjectSite interface }
  2268. {
  2269.  A site implements this interface so the object can communicate
  2270.  focus change to it.
  2271.  
  2272.  [Member functions]
  2273.  
  2274.  IInputObjectSite::OnFocusChangeIS(punkObj, fSetFocus)
  2275.    Object (punkObj) is getting or losing the focus.
  2276. }
  2277. type
  2278.   {$EXTERNALSYM IInputObjectSite}
  2279.   IInputObjectSite = interface(IUnknown)
  2280.     [SID_IInputObjectSite]
  2281.     function OnFocusChangeIS(punkObj: IUnknown; fSetFocus: BOOL): HResult; stdcall;
  2282.   end;
  2283.  
  2284. { IInputObject interface }
  2285. {
  2286.    An object implements this interface so the site can communicate
  2287.  activation and accelerator events to it.
  2288.  
  2289.  [Member functions]
  2290.  
  2291.  IInputObject::UIActivateIO(fActivate, lpMsg)
  2292.    Activates or deactivates the object.  lpMsg may be NULL.  Returns
  2293.    S_OK if the activation succeeded.
  2294.  
  2295.  IInputObject::HasFocusIO()
  2296.    Returns S_OK if the object has the focus, S_FALSE if not.
  2297.  
  2298.  IInputObject::TranslateAcceleratorIO(lpMsg)
  2299.    Allow the object to process the message.  Returns S_OK if the
  2300.    message was processed (eaten).
  2301. }
  2302.   {$EXTERNALSYM IInputObject}
  2303.   IInputObject = interface(IUnknown)
  2304.     [SID_IInputObject]
  2305.     function UIActivateIO(fActivate: BOOL; var lpMsg: TMsg): HResult; stdcall;
  2306.     function HasFocusIO: HResult; stdcall;
  2307.     function TranslateAcceleratorIO(var lpMsg: TMsg): HResult; stdcall;
  2308.   end;
  2309.  
  2310.  
  2311. { ========================================================================== }
  2312. { IDockingWindowSite/IDockingWindow/IDockingWindowFrame interfaces }
  2313. {
  2314.  These interfaces allow us (or ISVs) to install/update external Internet
  2315.  Toolbar for IE and the shell. The frame will simply get the CLSID from
  2316.  registry (to be defined) and CoCreateInstance it.
  2317.  
  2318. { IDockingWindowSite interface }
  2319. {
  2320.   A site implements this interface so the object can negotiate for
  2321.  and inquire about real estate on the site.
  2322.  
  2323.  [Member functions]
  2324.  
  2325.  IDockingWindowSite::GetBorderDW(punkObj, prcBorder)
  2326.    Site returns the bounding rectangle of the given source object
  2327.    (punkObj).
  2328.  
  2329.  IDockingWindowSite::RequestBorderSpaceDW(punkObj, pbw)
  2330.    Object requests that the site makes room for it, as specified in
  2331.    *pbw.
  2332.  
  2333.  IDockingWindowSite::SetBorderSpaceDW(punkObj, pbw)
  2334.    Object requests that the site set the border spacing to the size
  2335.    specified in *pbw.
  2336. }
  2337.   {$EXTERNALSYM IDockingWindowSite}
  2338.   IDockingWindowSite = interface(IOleWindow)
  2339.     [SID_IDockingWindowSite]
  2340.     function GetBorderDW(punkObj: IUnknown; var prcBorder: TRect): HResult; stdcall;
  2341.     function RequestBorderSpaceDW(punkObj: IUnknown; var pbw: TBorderWidths): HResult; stdcall;
  2342.     function SetBorderSpaceDW(punkObj: IUnknown; var pbw: TBorderWidths): HResult; stdcall;
  2343.   end;
  2344.  
  2345. { IDockingWindowFrame interface }
  2346. {
  2347.  [Member functions]
  2348.  
  2349.  IDockingWindowFrame::AddToolbar(punkSrc, pwszItem, dwReserved)
  2350.  
  2351.  IDockingWindowFrame::RemoveToolbar(punkSrc, dwRemoveFlags)
  2352.  
  2353.  IDockingWindowFrame::FindToolbar(pwszItem, riid, ppvObj)
  2354. }
  2355. const
  2356.   // flags for RemoveToolbar
  2357.   {$EXTERNALSYM DWFRF_NORMAL}
  2358.   DWFRF_NORMAL            = $0000;
  2359.   {$EXTERNALSYM DWFRF_DELETECONFIGDATA}
  2360.   DWFRF_DELETECONFIGDATA  = $0001;
  2361.  
  2362.   // flags for AddToolbar
  2363.   {$EXTERNALSYM DWFAF_HIDDEN}
  2364.   DWFAF_HIDDEN            = $0001;   { add hidden }
  2365.  
  2366. type
  2367.   {$EXTERNALSYM IDockingWindowFrame}
  2368.   IDockingWindowFrame = interface(IOleWindow)
  2369.     [SID_IDockingWindowFrame]
  2370.     function AddToolbar(punkSrc: IUnknown; pwszItem: PWideChar;
  2371.       dwAddFlags: DWORD): HResult; stdcall;
  2372.     function RemoveToolbar(punkSrc: IUnknown; dwRemoveFlags: DWORD): HResult; stdcall;
  2373.     function FindToolbar(pwszItem: PWideChar; const riid: TIID;
  2374.       var ppvObj: Pointer): HResult; stdcall;
  2375.   end;
  2376.  
  2377. { IDockingWindow interface }
  2378. {
  2379.  An object (docking window) implements this interface so the site can
  2380.  communicate with it.  An example of a docking window is a toolbar.
  2381.  
  2382.  [Member functions]
  2383.  
  2384.  IDockingWindow::ShowDW(fShow)
  2385.    Shows or hides the docking window.
  2386.  
  2387.  IDockingWindow::CloseDW(dwReserved)
  2388.    Closes the docking window.  dwReserved must be 0.
  2389.  
  2390.  IDockingWindow::ResizeBorderDW(prcBorder, punkToolbarSite, fReserved)
  2391.    Resizes the docking window's border to *prcBorder.  fReserved must
  2392.    be 0.
  2393.  IObjectWithSite::SetSite(punkSite)
  2394.    IDockingWindow usually paired with IObjectWithSite.
  2395.    Provides the IUnknown pointer of the site to the docking window.
  2396. }
  2397.   {$EXTERNALSYM IDockingWindow}
  2398.   IDockingWindow = interface(IOleWindow)
  2399.     [SID_IDockingWindow]
  2400.     function ShowDW(fShow: BOOL): HResult; stdcall;
  2401.     function CloseDW(dwReserved: DWORD): HResult; stdcall;
  2402.     function ResizeBorderDW(var prcBorder: TRect; punkToolbarSite: IUnknown;
  2403.       fReserved: BOOL): HResult; stdcall;
  2404.   end;
  2405.  
  2406. { IDeskBand interface }
  2407. {
  2408.  [Member functions]
  2409.  
  2410.  IDeskBand::GetBandInfo(dwBandID, dwViewMode, pdbi)
  2411.    Returns info on the given band in *pdbi, according to the mask
  2412.    field in the DESKBANDINFO structure and the given viewmode.
  2413. }
  2414. const
  2415.   // Mask values for DESKBANDINFO
  2416.   {$EXTERNALSYM DBIM_MINSIZE}
  2417.   DBIM_MINSIZE    = $0001;
  2418.   {$EXTERNALSYM DBIM_MAXSIZE}
  2419.   DBIM_MAXSIZE    = $0002;
  2420.   {$EXTERNALSYM DBIM_INTEGRAL}
  2421.   DBIM_INTEGRAL   = $0004;
  2422.   {$EXTERNALSYM DBIM_ACTUAL}
  2423.   DBIM_ACTUAL     = $0008;
  2424.   {$EXTERNALSYM DBIM_TITLE}
  2425.   DBIM_TITLE      = $0010;
  2426.   {$EXTERNALSYM DBIM_MODEFLAGS}
  2427.   DBIM_MODEFLAGS  = $0020;
  2428.   {$EXTERNALSYM DBIM_BKCOLOR}
  2429.   DBIM_BKCOLOR    = $0040;
  2430.  
  2431. type
  2432.   {$EXTERNALSYM DESKBANDINFO}
  2433.   DESKBANDINFO = packed record
  2434.     dwMask: DWORD;
  2435.     ptMinSize: TPointL;
  2436.     ptMaxSize: TPointL;
  2437.     ptIntegral: TPointL;
  2438.     ptActual: TPointL;
  2439.     wszTitle: array[0..255] of WideChar;
  2440.     dwModeFlags: DWORD;
  2441.     crBkgnd: COLORREF;
  2442.   end;
  2443.   PDeskBandInfo = ^TDeskBandInfo;
  2444.   TDeskBandInfo = DESKBANDINFO;
  2445.  
  2446. const
  2447.   // DESKBANDINFO dwModeFlags values
  2448.   {$EXTERNALSYM DBIMF_NORMAL}
  2449.   DBIMF_NORMAL            = $0000;
  2450.   {$EXTERNALSYM DBIMF_VARIABLEHEIGHT}
  2451.   DBIMF_VARIABLEHEIGHT    = $0008;
  2452.   {$EXTERNALSYM DBIMF_DEBOSSED}
  2453.   DBIMF_DEBOSSED          = $0020;
  2454.   {$EXTERNALSYM DBIMF_BKCOLOR}
  2455.   DBIMF_BKCOLOR           = $0040;
  2456.  
  2457.   // GetBandInfo view mode values
  2458.   {$EXTERNALSYM DBIF_VIEWMODE_NORMAL}
  2459.   DBIF_VIEWMODE_NORMAL         = $0000;
  2460.   {$EXTERNALSYM DBIF_VIEWMODE_VERTICAL}
  2461.   DBIF_VIEWMODE_VERTICAL       = $0001;
  2462.   {$EXTERNALSYM DBIF_VIEWMODE_FLOATING}
  2463.   DBIF_VIEWMODE_FLOATING       = $0002;
  2464.   {$EXTERNALSYM DBIF_VIEWMODE_TRANSPARENT}
  2465.   DBIF_VIEWMODE_TRANSPARENT    = $0004;
  2466.  
  2467. type
  2468.   {$EXTERNALSYM IDeskBand}
  2469.   IDeskBand = interface(IDockingWindow)
  2470.     [SID_IDeskBand]
  2471.     function GetBandInfo(dwBandID, dwViewMode: DWORD; var pdbi: TDeskBandInfo):
  2472.       HResult; stdcall;
  2473.   end;
  2474.  
  2475. const
  2476.   // Command Target IDs
  2477.   {$EXTERNALSYM DBID_BANDINFOCHANGED}
  2478.   DBID_BANDINFOCHANGED = 0;
  2479.     //  tmp! replace w/ cbs::Select
  2480.   {$EXTERNALSYM DBID_SHOWONLY}
  2481.   DBID_SHOWONLY        = 1;
  2482.   {$EXTERNALSYM DBID_MAXIMIZEBAND}
  2483.   DBID_MAXIMIZEBAND    = 2;  // Maximize the specified band (VT_UI4 == dwID)
  2484.  
  2485. type
  2486.   //  Flags and structures used by IActiveDesktop
  2487.  
  2488.   {$EXTERNALSYM _tagWALLPAPEROPT}
  2489.   _tagWALLPAPEROPT = packed record
  2490.     dwSize: DWORD;     // size of this Structure.
  2491.     dwStyle: DWORD;    // WPSTYLE_* mentioned above
  2492.   end;
  2493.   PWallPaperOpt = ^TWallPaperOpt;
  2494.   {$EXTERNALSYM PWallPaperOpt }
  2495.   TWallPaperOpt = _tagWALLPAPEROPT;
  2496.   {$EXTERNALSYM TWallPaperOpt }
  2497.  
  2498.   {$EXTERNALSYM _tagCOMPONENTSOPT}
  2499.   _tagCOMPONENTSOPT = packed record
  2500.     dwSize: DWORD;             // Size of this structure
  2501.     fEnableComponents: BOOL;   // Enable components?
  2502.     fActiveDesktop: BOOL;      // Active desktop enabled ?
  2503.   end;
  2504.   PComponentsOpt = ^TComponentsOpt;
  2505.   {$EXTERNALSYM PComponentsOpt }
  2506.   TComponentsOpt = _tagCOMPONENTSOPT;
  2507.   {$EXTERNALSYM TComponentsOpt }
  2508.  
  2509.   {$EXTERNALSYM _tagCOMPPOS}
  2510.   _tagCOMPPOS = packed record
  2511.     dwSize: DWORD;             //Size of this structure
  2512.     iLeft: Integer;            //Left of top-left corner in screen co-ordinates.
  2513.     iTop: Integer;             //Top of top-left corner in screen co-ordinates.
  2514.     dwWidth: DWORD;            // Width in pixels.
  2515.     dwHeight: DWORD;           // Height in pixels.
  2516.     izIndex: Integer;          // Indicates the Z-order of the component.
  2517.     fCanResize: BOOL;          // Is the component resizeable?
  2518.     fCanResizeX: BOOL;         // Resizeable in X-direction?
  2519.     fCanResizeY: BOOL;         // Resizeable in Y-direction?
  2520.     iPreferredLeftPercent: Integer;  //Left of top-left corner as percent of screen width
  2521.     iPreferredTopPercent: Integer;   //Top of top-left corner as percent of screen height
  2522.   end;
  2523.   PCompPos = ^TCompPos;
  2524.   {$EXTERNALSYM PCompPos }
  2525.   TCompPos = _tagCOMPPOS;
  2526.   {$EXTERNALSYM TCompPos }
  2527.  
  2528. const
  2529.   {$EXTERNALSYM COMPONENT_TOP}
  2530.   COMPONENT_TOP = $7fffffff;  // izOrder value meaning component is at the top
  2531.  
  2532.   // iCompType values
  2533.   {$EXTERNALSYM COMP_TYPE_HTMLDOC}
  2534.   COMP_TYPE_HTMLDOC       = 0;
  2535.   {$EXTERNALSYM COMP_TYPE_PICTURE}
  2536.   COMP_TYPE_PICTURE       = 1;
  2537.   {$EXTERNALSYM COMP_TYPE_WEBSITE}
  2538.   COMP_TYPE_WEBSITE       = 2;
  2539.   {$EXTERNALSYM COMP_TYPE_CONTROL}
  2540.   COMP_TYPE_CONTROL       = 3;
  2541.   {$EXTERNALSYM COMP_TYPE_CFHTML}
  2542.   COMP_TYPE_CFHTML        = 4;
  2543.   {$EXTERNALSYM COMP_TYPE_MAX}
  2544.   COMP_TYPE_MAX           = 4;
  2545.  
  2546. type
  2547.   {$EXTERNALSYM _tagCOMPONENT}
  2548.   _tagCOMPONENT = packed record
  2549.     dwSize: DWORD;            // Size of this structure
  2550.     dwID: DWORD;              // Reserved: Set it always to zero.
  2551.     iComponentType: Integer;  // One of COMP_TYPE_*
  2552.     fChecked: BOOL;           // Is this component enabled?
  2553.     fDirty: BOOL;             // Had the component been modified and not yet saved to disk?
  2554.     fNoScroll: BOOL;          // Is the component scrollable?
  2555.     cpPos: TCompPos;          // Width, height etc.,
  2556.     wszFriendlyName: array[0..MAX_PATH - 1] of WideChar;  // Friendly name of component.
  2557.     wszSource: array[0..INTERNET_MAX_URL_LENGTH - 1] of WideChar; //URL of the component.
  2558.     wszSubscribedURL: array[0..INTERNET_MAX_URL_LENGTH - 1] of WideChar; //Subscrined URL
  2559.   end;
  2560.   PShComponent = ^TShComponent;
  2561.   {$EXTERNALSYM PShComponent }
  2562.   TShComponent = _tagCOMPONENT;
  2563.   {$EXTERNALSYM TShComponent }
  2564.  
  2565. const
  2566.   // Flags for IActiveDesktop::ApplyChanges()
  2567.   {$EXTERNALSYM AD_APPLY_SAVE}
  2568.   AD_APPLY_SAVE         = $00000001;
  2569.   {$EXTERNALSYM AD_APPLY_HTMLGEN}
  2570.   AD_APPLY_HTMLGEN      = $00000002;
  2571.   {$EXTERNALSYM AD_APPLY_REFRESH}
  2572.   AD_APPLY_REFRESH      = $00000004;
  2573.   {$EXTERNALSYM AD_APPLY_ALL}
  2574.   AD_APPLY_ALL          = AD_APPLY_SAVE or AD_APPLY_HTMLGEN or AD_APPLY_REFRESH;
  2575.   {$EXTERNALSYM AD_APPLY_FORCE}
  2576.   AD_APPLY_FORCE        = $00000008;
  2577.   {$EXTERNALSYM AD_APPLY_BUFFERED_REFRESH}
  2578.   AD_APPLY_BUFFERED_REFRESH = $00000010;
  2579.  
  2580.   // Flags for IActiveDesktop::GetWallpaperOptions()
  2581.   //           IActiveDesktop::SetWallpaperOptions()
  2582.   {$EXTERNALSYM WPSTYLE_CENTER}
  2583.   WPSTYLE_CENTER      = 0;
  2584.   {$EXTERNALSYM WPSTYLE_TILE}
  2585.   WPSTYLE_TILE        = 1;
  2586.   {$EXTERNALSYM WPSTYLE_STRETCH}
  2587.   WPSTYLE_STRETCH     = 2;
  2588.   {$EXTERNALSYM WPSTYLE_MAX}
  2589.   WPSTYLE_MAX         = 3;
  2590.  
  2591.   // Flags for IActiveDesktop::ModifyComponent()
  2592.   {$EXTERNALSYM COMP_ELEM_TYPE}
  2593.   COMP_ELEM_TYPE          = $00000001;
  2594.   {$EXTERNALSYM COMP_ELEM_CHECKED}
  2595.   COMP_ELEM_CHECKED       = $00000002;
  2596.   {$EXTERNALSYM COMP_ELEM_DIRTY}
  2597.   COMP_ELEM_DIRTY         = $00000004;
  2598.   {$EXTERNALSYM COMP_ELEM_NOSCROLL}
  2599.   COMP_ELEM_NOSCROLL      = $00000008;
  2600.   {$EXTERNALSYM COMP_ELEM_POS_LEFT}
  2601.   COMP_ELEM_POS_LEFT      = $00000010;
  2602.   {$EXTERNALSYM COMP_ELEM_POS_TOP}
  2603.   COMP_ELEM_POS_TOP       = $00000020;
  2604.   {$EXTERNALSYM COMP_ELEM_SIZE_WIDTH}
  2605.   COMP_ELEM_SIZE_WIDTH    = $00000040;
  2606.   {$EXTERNALSYM COMP_ELEM_SIZE_HEIGHT}
  2607.   COMP_ELEM_SIZE_HEIGHT   = $00000080;
  2608.   {$EXTERNALSYM COMP_ELEM_POS_ZINDEX}
  2609.   COMP_ELEM_POS_ZINDEX    = $00000100;
  2610.   {$EXTERNALSYM COMP_ELEM_SOURCE}
  2611.   COMP_ELEM_SOURCE        = $00000200;
  2612.   {$EXTERNALSYM COMP_ELEM_FRIENDLYNAME}
  2613.   COMP_ELEM_FRIENDLYNAME  = $00000400;
  2614.   {$EXTERNALSYM COMP_ELEM_SUBSCRIBEDURL}
  2615.   COMP_ELEM_SUBSCRIBEDURL = $00000800;
  2616.  
  2617.   {$EXTERNALSYM COMP_ELEM_ALL}
  2618.   COMP_ELEM_ALL           = COMP_ELEM_TYPE or COMP_ELEM_CHECKED or
  2619.                             COMP_ELEM_DIRTY or COMP_ELEM_NOSCROLL or
  2620.                             COMP_ELEM_POS_LEFT or COMP_ELEM_SIZE_WIDTH  or
  2621.                             COMP_ELEM_SIZE_HEIGHT or COMP_ELEM_POS_ZINDEX or
  2622.                             COMP_ELEM_SOURCE or COMP_ELEM_FRIENDLYNAME;
  2623.  
  2624.   // Flags for IActiveDesktop::AddUrl()
  2625.   {$EXTERNALSYM ADDURL_SILENT}
  2626.   ADDURL_SILENT           = $0001;
  2627.  
  2628. type
  2629.   // Flags for IActiveDesktop::AddDesktopItemWithUI()
  2630.   {$EXTERNALSYM tagDTI_ADTIWUI}
  2631.   tagDTI_ADTIWUI = (DTI_ADDUI_DEFAULT, DTI_ADDUI_DISPSUBWIZARD);
  2632.  
  2633. { Interface for manipulating the Active Desktop. }
  2634.  
  2635.   {$EXTERNALSYM IActiveDesktop}
  2636.   IActiveDesktop = interface(IUnknown)
  2637.     [SID_IActiveDesktop]
  2638.     function ApplyChanges(dwFlags: DWORD): HResult; stdcall;
  2639.     function GetWallpaper(pwszWallpaper: PWideChar; cchWallpaper: UINT;
  2640.       dwReserved: DWORD): HResult; stdcall;
  2641.     function SetWallpaper(pwszWallpaper: PWideChar; dwReserved: DWORD): HResult; stdcall;
  2642.     function GetWallpaperOptions(var pwpo: TWallPaperOpt; dwReserved: DWORD): HResult; stdcall;
  2643.     function SetWallpaperOptions(var pwpo: TWallPaperOpt; dwReserved: DWORD): HResult; stdcall;
  2644.     function GetPattern(pwszPattern: PWideChar; cchPattern: UINT;
  2645.       dwReserved: DWORD): HResult; stdcall;
  2646.     function SetPattern(pwszPattern: PWideChar; dwReserved: DWORD): HResult; stdcall;
  2647.     function GetDesktopItemOptions(var pco: TComponentsOpt; dwReserved: DWORD):
  2648.       HResult; stdcall;
  2649.     function SetDesktopItemOptions(var pco: TComponentsOpt; dwReserved: DWORD):
  2650.       HResult; stdcall;
  2651.     function AddDesktopItem(var pcomp: TShComponent; dwReserved: DWORD): HResult; stdcall;
  2652.     function AddDesktopItemWithUI(hwnd: HWND; var pcomp: TShComponent;
  2653.       dwReserved: DWORD): HResult; stdcall;
  2654.     function ModifyDesktopItem(var pcomp: TShComponent; dwReserved: DWORD): HResult; stdcall;
  2655.     function RemoveDesktopItem(var pcomp: TShComponent; dwReserved: DWORD): HResult; stdcall;
  2656.     function GetDesktopItemCount(var lpiCount: Integer; dwReserved: DWORD): HResult; stdcall;
  2657.     function GetDesktopItem(nComponent: Integer; var pcomp: TShComponent;
  2658.       dwReserved: DWORD): HResult; stdcall;
  2659.     function GetDesktopItemByID(dwID: DWORD; var pcomp: TShComponent;
  2660.       dwReserved: DWORD): HResult; stdcall;
  2661.     function GenerateDesktopItemHtml(pwszFileName: PWideChar;
  2662.       var pcomp: TShComponent; dwReserved: DWORD): HResult; stdcall;
  2663.     function AddUrl(hwnd: HWND; pszSource: PWideChar; var pcomp: TShComponent;
  2664.       dwFlags: DWORD): HResult; stdcall;
  2665.     function GetDesktopItemBySource(pwszSource: PWideChar; var pcomp: TShComponent;
  2666.       dwReserved: DWORD): HResult; stdcall;
  2667.   end;
  2668.  
  2669. const
  2670. { Clipboard format which may be supported by IDataObject from system
  2671.   defined shell folders (such as directories, network, ...). }
  2672.  
  2673.   {$EXTERNALSYM CFSTR_SHELLIDLIST}
  2674.   CFSTR_SHELLIDLIST           = 'Shell IDList Array';     { CF_IDLIST }
  2675.   {$EXTERNALSYM CFSTR_SHELLIDLISTOFFSET}
  2676.   CFSTR_SHELLIDLISTOFFSET     = 'Shell Object Offsets';   { CF_OBJECTPOSITIONS }
  2677.   {$EXTERNALSYM CFSTR_NETRESOURCES}
  2678.   CFSTR_NETRESOURCES          = 'Net Resource';           { CF_NETRESOURCE }
  2679.   {$EXTERNALSYM CFSTR_FILEDESCRIPTORA}
  2680.   CFSTR_FILEDESCRIPTORA       = 'FileGroupDescriptor';    { CF_FILEGROUPDESCRIPTORA }
  2681.   {$EXTERNALSYM CFSTR_FILEDESCRIPTORW}
  2682.   CFSTR_FILEDESCRIPTORW       = 'FileGroupDescriptorW';   { CF_FILEGROUPDESCRIPTORW }
  2683.   {$EXTERNALSYM CFSTR_FILECONTENTS}
  2684.   CFSTR_FILECONTENTS          = 'FileContents';           { CF_FILECONTENTS }
  2685.   {$EXTERNALSYM CFSTR_FILENAMEA}
  2686.   CFSTR_FILENAMEA             = 'FileName';               { CF_FILENAMEA }
  2687.   {$EXTERNALSYM CFSTR_FILENAMEW}
  2688.   CFSTR_FILENAMEW             = 'FileNameW';              { CF_FILENAMEW }
  2689.   {$EXTERNALSYM CFSTR_PRINTERGROUP}
  2690.   CFSTR_PRINTERGROUP          = 'PrinterFriendlyName';    { CF_PRINTERS }
  2691.   {$EXTERNALSYM CFSTR_FILENAMEMAPA}
  2692.   CFSTR_FILENAMEMAPA          = 'FileNameMap';            { CF_FILENAMEMAPA }
  2693.   {$EXTERNALSYM CFSTR_FILENAMEMAPW}
  2694.   CFSTR_FILENAMEMAPW          = 'FileNameMapW';           { CF_FILENAMEMAPW }
  2695.   {$EXTERNALSYM CFSTR_SHELLURL}
  2696.   CFSTR_SHELLURL              = 'UniformResourceLocator';
  2697.   {$EXTERNALSYM CFSTR_PREFERREDDROPEFFECT}
  2698.   CFSTR_PREFERREDDROPEFFECT   = 'Preferred DropEffect';
  2699.   {$EXTERNALSYM CFSTR_PERFORMEDDROPEFFECT}
  2700.   CFSTR_PERFORMEDDROPEFFECT   = 'Performed DropEffect';
  2701.   {$EXTERNALSYM CFSTR_PASTESUCCEEDED}
  2702.   CFSTR_PASTESUCCEEDED        = 'Paste Succeeded';
  2703.   {$EXTERNALSYM CFSTR_INDRAGLOOP}
  2704.   CFSTR_INDRAGLOOP            = 'InShellDragLoop';
  2705.  
  2706.  
  2707.  
  2708.  
  2709.  
  2710.  
  2711.  
  2712.  
  2713.   {$EXTERNALSYM CFSTR_FILEDESCRIPTOR}
  2714.   CFSTR_FILEDESCRIPTOR        = CFSTR_FILEDESCRIPTORA;
  2715.   {$EXTERNALSYM CFSTR_FILENAME}
  2716.   CFSTR_FILENAME              = CFSTR_FILENAMEA;
  2717.   {$EXTERNALSYM CFSTR_FILENAMEMAP}
  2718.   CFSTR_FILENAMEMAP           = CFSTR_FILENAMEMAPA;
  2719.  
  2720.  
  2721. { CF_OBJECTPOSITIONS }
  2722.  
  2723.   {$EXTERNALSYM DVASPECT_SHORTNAME}
  2724.   DVASPECT_SHORTNAME     = 2; { use for CF_HDROP to get short name version }
  2725.  
  2726.  
  2727. type
  2728. { format of CF_NETRESOURCE }
  2729.  
  2730.   PNResArray = ^TNResArray;
  2731.   {$EXTERNALSYM _NRESARRAY}
  2732.   _NRESARRAY = record
  2733.     cItems: UINT;
  2734.     nr: array[0..0] of TNetResource;
  2735.   end;
  2736.   TNResArray = _NRESARRAY;
  2737.   {$EXTERNALSYM NRESARRAY}
  2738.   NRESARRAY = _NRESARRAY;
  2739.  
  2740.  
  2741. { format of CF_IDLIST }
  2742.  
  2743.   PIDA = ^TIDA;
  2744.   {$EXTERNALSYM _IDA}
  2745.   _IDA = record
  2746.     cidl: UINT;                      { number of relative IDList }
  2747.     aoffset: array[0..0] of UINT;    { [0]: folder IDList, [1]-[cidl]: item IDList }
  2748.   end;
  2749.   TIDA = _IDA;
  2750.   {$EXTERNALSYM CIDA}
  2751.   CIDA = _IDA;
  2752.  
  2753.  
  2754.  
  2755. const
  2756. { FILEDESCRIPTOR.dwFlags field indicate which fields are to be used }
  2757.  
  2758.   {$EXTERNALSYM FD_CLSID}
  2759.   FD_CLSID            = $0001;
  2760.   {$EXTERNALSYM FD_SIZEPOINT}
  2761.   FD_SIZEPOINT        = $0002;
  2762.   {$EXTERNALSYM FD_ATTRIBUTES}
  2763.   FD_ATTRIBUTES       = $0004;
  2764.   {$EXTERNALSYM FD_CREATETIME}
  2765.   FD_CREATETIME       = $0008;
  2766.   {$EXTERNALSYM FD_ACCESSTIME}
  2767.   FD_ACCESSTIME       = $0010;
  2768.   {$EXTERNALSYM FD_WRITESTIME}
  2769.   FD_WRITESTIME       = $0020;
  2770.   {$EXTERNALSYM FD_FILESIZE}
  2771.   FD_FILESIZE         = $0040;
  2772.   {$EXTERNALSYM FD_LINKUI}
  2773.   FD_LINKUI           = $8000;       { 'link' UI is prefered }
  2774.  
  2775. type
  2776.   PFileDescriptorA = ^TFileDescriptorA;
  2777.   PFileDescriptorW = ^TFileDescriptorW;
  2778.   PFileDescriptor = PFileDescriptorA;
  2779.   {$EXTERNALSYM _FILEDESCRIPTORA}
  2780.   _FILEDESCRIPTORA = record
  2781.     dwFlags: DWORD;
  2782.     clsid: TCLSID;
  2783.     sizel: TSize;
  2784.     pointl: TPoint;
  2785.     dwFileAttributes: DWORD;
  2786.     ftCreationTime: TFileTime;
  2787.     ftLastAccessTime: TFileTime;
  2788.     ftLastWriteTime: TFileTime;
  2789.     nFileSizeHigh: DWORD;
  2790.     nFileSizeLow: DWORD;
  2791.     cFileName: array[0..MAX_PATH-1] of AnsiChar;
  2792.   end;
  2793.   {$EXTERNALSYM _FILEDESCRIPTORW}
  2794.   _FILEDESCRIPTORW = record
  2795.     dwFlags: DWORD;
  2796.     clsid: TCLSID;
  2797.     sizel: TSize;
  2798.     pointl: TPoint;
  2799.     dwFileAttributes: DWORD;
  2800.     ftCreationTime: TFileTime;
  2801.     ftLastAccessTime: TFileTime;
  2802.     ftLastWriteTime: TFileTime;
  2803.     nFileSizeHigh: DWORD;
  2804.     nFileSizeLow: DWORD;
  2805.     cFileName: array[0..MAX_PATH-1] of WideChar;
  2806.   end;
  2807.   {$EXTERNALSYM _FILEDESCRIPTOR}
  2808.   _FILEDESCRIPTOR = _FILEDESCRIPTORA;
  2809.   TFileDescriptorA = _FILEDESCRIPTORA;
  2810.   TFileDescriptorW = _FILEDESCRIPTORW;
  2811.   TFileDescriptor = TFileDescriptorA;
  2812.   {$EXTERNALSYM FILEDESCRIPTORA}
  2813.   FILEDESCRIPTORA = _FILEDESCRIPTORA;
  2814.   {$EXTERNALSYM FILEDESCRIPTORW}
  2815.   FILEDESCRIPTORW = _FILEDESCRIPTORW;
  2816.   {$EXTERNALSYM FILEDESCRIPTOR}
  2817.   FILEDESCRIPTOR = FILEDESCRIPTORA;
  2818.  
  2819. { format of CF_FILEGROUPDESCRIPTOR }
  2820.  
  2821.   PFileGroupDescriptorA = ^TFileGroupDescriptorA;
  2822.   PFileGroupDescriptorW = ^TFileGroupDescriptorW;
  2823.   PFileGroupDescriptor = PFileGroupDescriptorA;
  2824.   {$EXTERNALSYM _FILEGROUPDESCRIPTORA}
  2825.   _FILEGROUPDESCRIPTORA = record
  2826.     cItems: UINT;
  2827.     fgd: array[0..0] of TFileDescriptor;
  2828.   end;
  2829.   {$EXTERNALSYM _FILEGROUPDESCRIPTORW}
  2830.   _FILEGROUPDESCRIPTORW = record
  2831.     cItems: UINT;
  2832.     fgd: array[0..0] of TFileDescriptor;
  2833.   end;
  2834.   {$EXTERNALSYM _FILEGROUPDESCRIPTOR}
  2835.   _FILEGROUPDESCRIPTOR = _FILEGROUPDESCRIPTORA;
  2836.   TFileGroupDescriptorA = _FILEGROUPDESCRIPTORA;
  2837.   TFileGroupDescriptorW = _FILEGROUPDESCRIPTORW;
  2838.   TFileGroupDescriptor = TFileGroupDescriptorA;
  2839.   {$EXTERNALSYM FILEGROUPDESCRIPTORA}
  2840.   FILEGROUPDESCRIPTORA = _FILEGROUPDESCRIPTORA;
  2841.   {$EXTERNALSYM FILEGROUPDESCRIPTORW}
  2842.   FILEGROUPDESCRIPTORW = _FILEGROUPDESCRIPTORW;
  2843.   {$EXTERNALSYM FILEGROUPDESCRIPTOR}
  2844.   FILEGROUPDESCRIPTOR = FILEGROUPDESCRIPTORA;
  2845.  
  2846. { format of CF_HDROP and CF_PRINTERS, in the HDROP case the data that follows
  2847.   is a double null terinated list of file names, for printers they are printer
  2848.   friendly names }
  2849.  
  2850.   PDropFiles = ^TDropFiles;
  2851.   {$EXTERNALSYM _DROPFILES}
  2852.   _DROPFILES = record
  2853.     pFiles: DWORD;                       { offset of file list }
  2854.     pt: TPoint;                          { drop point (client coords) }
  2855.     fNC: BOOL;                           { is it on NonClient area }
  2856.                                          { and pt is in screen coords }
  2857.     fWide: BOOL;                         { WIDE character switch }
  2858.   end;
  2859.   TDropFiles = _DROPFILES;
  2860.   {$EXTERNALSYM DROPFILES}
  2861.   DROPFILES = _DROPFILES;
  2862.  
  2863.  
  2864. { File System Notification APIs }
  2865.  
  2866. const
  2867. { File System Notification flags }
  2868.  
  2869.   {$EXTERNALSYM SHCNE_RENAMEITEM}
  2870.   SHCNE_RENAMEITEM          = $00000001;
  2871.   {$EXTERNALSYM SHCNE_CREATE}
  2872.   SHCNE_CREATE              = $00000002;
  2873.   {$EXTERNALSYM SHCNE_DELETE}
  2874.   SHCNE_DELETE              = $00000004;
  2875.   {$EXTERNALSYM SHCNE_MKDIR}
  2876.   SHCNE_MKDIR               = $00000008;
  2877.   {$EXTERNALSYM SHCNE_RMDIR}
  2878.   SHCNE_RMDIR               = $00000010;
  2879.   {$EXTERNALSYM SHCNE_MEDIAINSERTED}
  2880.   SHCNE_MEDIAINSERTED       = $00000020;
  2881.   {$EXTERNALSYM SHCNE_MEDIAREMOVED}
  2882.   SHCNE_MEDIAREMOVED        = $00000040;
  2883.   {$EXTERNALSYM SHCNE_DRIVEREMOVED}
  2884.   SHCNE_DRIVEREMOVED        = $00000080;
  2885.   {$EXTERNALSYM SHCNE_DRIVEADD}
  2886.   SHCNE_DRIVEADD            = $00000100;
  2887.   {$EXTERNALSYM SHCNE_NETSHARE}
  2888.   SHCNE_NETSHARE            = $00000200;
  2889.   {$EXTERNALSYM SHCNE_NETUNSHARE}
  2890.   SHCNE_NETUNSHARE          = $00000400;
  2891.   {$EXTERNALSYM SHCNE_ATTRIBUTES}
  2892.   SHCNE_ATTRIBUTES          = $00000800;
  2893.   {$EXTERNALSYM SHCNE_UPDATEDIR}
  2894.   SHCNE_UPDATEDIR           = $00001000;
  2895.   {$EXTERNALSYM SHCNE_UPDATEITEM}
  2896.   SHCNE_UPDATEITEM          = $00002000;
  2897.   {$EXTERNALSYM SHCNE_SERVERDISCONNECT}
  2898.   SHCNE_SERVERDISCONNECT    = $00004000;
  2899.   {$EXTERNALSYM SHCNE_UPDATEIMAGE}
  2900.   SHCNE_UPDATEIMAGE         = $00008000;
  2901.   {$EXTERNALSYM SHCNE_DRIVEADDGUI}
  2902.   SHCNE_DRIVEADDGUI         = $00010000;
  2903.   {$EXTERNALSYM SHCNE_RENAMEFOLDER}
  2904.   SHCNE_RENAMEFOLDER        = $00020000;
  2905.   {$EXTERNALSYM SHCNE_FREESPACE}
  2906.   SHCNE_FREESPACE           = $00040000;
  2907.   {$EXTERNALSYM SHCNE_EXTENDED_EVENT}
  2908.   SHCNE_EXTENDED_EVENT      = $04000000;
  2909.   SHCNE_EXTENDED_EVENT_PRE_IE4 = $00080000;
  2910.  
  2911.   {$EXTERNALSYM SHCNE_ASSOCCHANGED}
  2912.   SHCNE_ASSOCCHANGED        = $08000000;
  2913.  
  2914.   {$EXTERNALSYM SHCNE_DISKEVENTS}
  2915.   SHCNE_DISKEVENTS          = $0002381F;
  2916.   {$EXTERNALSYM SHCNE_GLOBALEVENTS}
  2917.   SHCNE_GLOBALEVENTS        = $0C0581E0; { Events that dont match pidls first }
  2918.   {$EXTERNALSYM SHCNE_ALLEVENTS}
  2919.   SHCNE_ALLEVENTS           = $7FFFFFFF;
  2920.   {$EXTERNALSYM SHCNE_INTERRUPT}
  2921.   SHCNE_INTERRUPT           = $80000000; { The presence of this flag indicates }
  2922.                                          { that the event was generated by an }
  2923.                                          { interrupt.  It is stripped out before }
  2924.                                          { the clients of SHCNNotify_ see it. }
  2925.   {$EXTERNALSYM SHCNEE_THEMECHANGED}
  2926.   SHCNEE_THEMECHANGED       = $00000001;
  2927.   {$EXTERNALSYM SHCNEE_ORDERCHANGED}
  2928.   SHCNEE_ORDERCHANGED       = $00000002; { dwItem2 is the pidl of the changed folder }
  2929.  
  2930.  
  2931. { uFlags & SHCNF_TYPE is an ID which indicates what dwItem1 and dwItem2 mean }
  2932.  
  2933.   {$EXTERNALSYM SHCNF_IDLIST}
  2934.   SHCNF_IDLIST          = $0000;        { LPITEMIDLIST }
  2935.   {$EXTERNALSYM SHCNF_PATHA}
  2936.   SHCNF_PATHA           = $0001;        { path name }
  2937.   {$EXTERNALSYM SHCNF_PRINTERA}
  2938.   SHCNF_PRINTERA        = $0002;        { printer friendly name }
  2939.   {$EXTERNALSYM SHCNF_DWORD}
  2940.   SHCNF_DWORD           = $0003;        { DWORD }
  2941.   {$EXTERNALSYM SHCNF_PATHW}
  2942.   SHCNF_PATHW           = $0005;        { path name }
  2943.   {$EXTERNALSYM SHCNF_PRINTERW}
  2944.   SHCNF_PRINTERW        = $0006;        { printer friendly name }
  2945.   {$EXTERNALSYM SHCNF_TYPE}
  2946.   SHCNF_TYPE            = $00FF;
  2947.   {$EXTERNALSYM SHCNF_FLUSH}
  2948.   SHCNF_FLUSH           = $1000;
  2949.   {$EXTERNALSYM SHCNF_FLUSHNOWAIT}
  2950.   SHCNF_FLUSHNOWAIT     = $2000;
  2951.  
  2952.  
  2953.  
  2954.  
  2955.  
  2956.  
  2957.   {$EXTERNALSYM SHCNF_PATH}
  2958.   SHCNF_PATH          = SHCNF_PATHA;
  2959.   {$EXTERNALSYM SHCNF_PRINTER}
  2960.   SHCNF_PRINTER       = SHCNF_PRINTERA;
  2961.  
  2962. { APIs }
  2963.  
  2964. {$EXTERNALSYM SHChangeNotify}
  2965. procedure SHChangeNotify(wEventId: Longint; uFlags: UINT;
  2966.   dwItem1, dwItem2: Pointer); stdcall;
  2967.  
  2968. { IShellChangeNotify }
  2969.  
  2970. type
  2971.   {$EXTERNALSYM IShellChangeNotify}
  2972.   IShellChangeNotify = interface(IUnknown)
  2973.     [SID_IShellChangeNotify]
  2974.     function OnChange(lEvent: Longint; var pidl1, pidl2: TItemIDList): HResult; stdcall;
  2975.   end;
  2976.  
  2977. { IQueryInfo }
  2978.  
  2979.   {$EXTERNALSYM IQueryInfo}
  2980.   IQueryInfo = interface(IUnknown)
  2981.     [SID_IQueryInfo]
  2982.     function GetInfoTip(dwFlags: DWORD; var ppwszTip: PWideChar): HResult; stdcall;
  2983.     function GetInfoFlags(out pdwFlags: DWORD): HResult; stdcall;
  2984.   end;
  2985.  
  2986. const
  2987.   {$EXTERNALSYM QIF_CACHED}
  2988.   QIF_CACHED           = $00000001;
  2989.   {$EXTERNALSYM QIF_DONTEXPANDFOLDER}
  2990.   QIF_DONTEXPANDFOLDER = $00000002;
  2991.  
  2992. {$EXTERNALSYM SHAddToRecentDocs}
  2993. procedure SHAddToRecentDocs(uFlags: UINT; pv: Pointer); stdcall;
  2994. {$EXTERNALSYM SHGetInstanceExplorer}
  2995. function SHGetInstanceExplorer(var ppUnk: IUnknown): HResult; stdcall;
  2996.  
  2997. { SHAddToRecentDocs }
  2998.  
  2999. const
  3000.   {$EXTERNALSYM SHARD_PIDL}
  3001.   SHARD_PIDL          = $00000001;
  3002.   {$EXTERNALSYM SHARD_PATHA}
  3003.   SHARD_PATHA         = $00000002;
  3004.   {$EXTERNALSYM SHARD_PATHW}
  3005.   SHARD_PATHW         = $00000003;
  3006.  
  3007.  
  3008.  
  3009.  
  3010.   {$EXTERNALSYM SHARD_PATH}
  3011.   SHARD_PATH      = SHARD_PATHA;
  3012.  
  3013.  
  3014. { SHGetDataFromIDList}
  3015.  
  3016. const
  3017.   {$EXTERNALSYM SHGDFIL_FINDDATA}
  3018.   SHGDFIL_FINDDATA            = 1;
  3019.   {$EXTERNALSYM SHGDFIL_NETRESOURCE}
  3020.   SHGDFIL_NETRESOURCE         = 2;
  3021.   {$EXTERNALSYM SHGDFIL_DESCRIPTIONID}
  3022.   SHGDFIL_DESCRIPTIONID       = 3;
  3023.  
  3024.   {$EXTERNALSYM SHDID_ROOT_REGITEM}
  3025.   SHDID_ROOT_REGITEM              = 1;
  3026.   {$EXTERNALSYM SHDID_FS_FILE}
  3027.   SHDID_FS_FILE                   = 2;
  3028.   {$EXTERNALSYM SHDID_FS_DIRECTORY}
  3029.   SHDID_FS_DIRECTORY              = 3;
  3030.   {$EXTERNALSYM SHDID_FS_OTHER}
  3031.   SHDID_FS_OTHER                  = 4;
  3032.   {$EXTERNALSYM SHDID_COMPUTER_DRIVE35}
  3033.   SHDID_COMPUTER_DRIVE35          = 5;
  3034.   {$EXTERNALSYM SHDID_COMPUTER_DRIVE525}
  3035.   SHDID_COMPUTER_DRIVE525         = 6;
  3036.   {$EXTERNALSYM SHDID_COMPUTER_REMOVABLE}
  3037.   SHDID_COMPUTER_REMOVABLE        = 7;
  3038.   {$EXTERNALSYM SHDID_COMPUTER_FIXED}
  3039.   SHDID_COMPUTER_FIXED            = 8;
  3040.   {$EXTERNALSYM SHDID_COMPUTER_NETDRIVE}
  3041.   SHDID_COMPUTER_NETDRIVE         = 9;
  3042.   {$EXTERNALSYM SHDID_COMPUTER_CDROM}
  3043.   SHDID_COMPUTER_CDROM            = 10;
  3044.   {$EXTERNALSYM SHDID_COMPUTER_RAMDISK}
  3045.   SHDID_COMPUTER_RAMDISK          = 11;
  3046.   {$EXTERNALSYM SHDID_COMPUTER_OTHER}
  3047.   SHDID_COMPUTER_OTHER            = 12;
  3048.   {$EXTERNALSYM SHDID_NET_DOMAIN}
  3049.   SHDID_NET_DOMAIN                = 13;
  3050.   {$EXTERNALSYM SHDID_NET_SERVER}
  3051.   SHDID_NET_SERVER                = 14;
  3052.   {$EXTERNALSYM SHDID_NET_SHARE}
  3053.   SHDID_NET_SHARE                 = 15;
  3054.   {$EXTERNALSYM SHDID_NET_RESTOFNET}
  3055.   SHDID_NET_RESTOFNET             = 16;
  3056.   {$EXTERNALSYM SHDID_NET_OTHER}
  3057.   SHDID_NET_OTHER                 = 17;
  3058.  
  3059. type
  3060.   PSHDescriptionID = ^TSHDescriptionID;
  3061.   {$EXTERNALSYM _SHDESCRIPTIONID}
  3062.   _SHDESCRIPTIONID = record
  3063.     dwDescriptionId: DWORD;
  3064.     Id: TCLSID;
  3065.   end;
  3066.   TSHDescriptionID = _SHDESCRIPTIONID;
  3067.   {$EXTERNALSYM SHDESCRIPTIONID}
  3068.   SHDESCRIPTIONID = _SHDESCRIPTIONID;
  3069.  
  3070.  
  3071. {$EXTERNALSYM SHGetDataFromIDListA}
  3072. function SHGetDataFromIDListA(psf: IShellFolder; pidl: PItemIDList;
  3073.   nFormat: Integer; ptr: Pointer; cb: Integer): HResult; stdcall;
  3074. {$EXTERNALSYM SHGetDataFromIDListW}
  3075. function SHGetDataFromIDListW(psf: IShellFolder; pidl: PItemIDList;
  3076.   nFormat: Integer; ptr: Pointer; cb: Integer): HResult; stdcall;
  3077. {$EXTERNALSYM SHGetDataFromIDList}
  3078. function SHGetDataFromIDList(psf: IShellFolder; pidl: PItemIDList;
  3079.   nFormat: Integer; ptr: Pointer; cb: Integer): HResult; stdcall;
  3080.  
  3081. { PROPIDs for Internet Shortcuts (FMTID_Intshcut) to be used with }
  3082. { IPropertySetStorage/IPropertyStorage }
  3083. {
  3084.  The known property ids and their variant types are:
  3085.       PID_IS_URL          [VT_LPWSTR]   URL
  3086.       PID_IS_NAME         [VT_LPWSTR]   Name of the internet shortcut
  3087.       PID_IS_WORKINGDIR   [VT_LPWSTR]   Working directory for the shortcut
  3088.       PID_IS_HOTKEY       [VT_UI2]      Hotkey for the shortcut
  3089.       PID_IS_SHOWCMD      [VT_I4]       Show command for shortcut
  3090.       PID_IS_ICONINDEX    [VT_I4]       Index into file that has icon
  3091.       PID_IS_ICONFILE     [VT_LPWSTR]   File that has the icon
  3092.       PID_IS_WHATSNEW     [VT_LPWSTR]   What's New text
  3093.       PID_IS_AUTHOR       [VT_LPWSTR]   Author
  3094.       PID_IS_DESCRIPTION  [VT_LPWSTR]   Description text of site
  3095.       PID_IS_COMMENT      [VT_LPWSTR]   User annotated comment
  3096. }
  3097.  
  3098. const
  3099.   {$EXTERNALSYM PID_IS_URL}
  3100.   PID_IS_URL           = 2;
  3101.   {$EXTERNALSYM PID_IS_NAME}
  3102.   PID_IS_NAME          = 4;
  3103.   {$EXTERNALSYM PID_IS_WORKINGDIR}
  3104.   PID_IS_WORKINGDIR    = 5;
  3105.   {$EXTERNALSYM PID_IS_HOTKEY}
  3106.   PID_IS_HOTKEY        = 6;
  3107.   {$EXTERNALSYM PID_IS_SHOWCMD}
  3108.   PID_IS_SHOWCMD       = 7;
  3109.   {$EXTERNALSYM PID_IS_ICONINDEX}
  3110.   PID_IS_ICONINDEX     = 8;
  3111.   {$EXTERNALSYM PID_IS_ICONFILE}
  3112.   PID_IS_ICONFILE      = 9;
  3113.   {$EXTERNALSYM PID_IS_WHATSNEW}
  3114.   PID_IS_WHATSNEW      = 10;
  3115.   {$EXTERNALSYM PID_IS_AUTHOR}
  3116.   PID_IS_AUTHOR        = 11;
  3117.   {$EXTERNALSYM PID_IS_DESCRIPTION}
  3118.   PID_IS_DESCRIPTION   = 12;
  3119.   {$EXTERNALSYM PID_IS_COMMENT}
  3120.   PID_IS_COMMENT       = 13;
  3121.  
  3122. { PROPIDs for Internet Sites (FMTID_InternetSite) to be used with }
  3123. { IPropertySetStorage/IPropertyStorage }
  3124. {
  3125.  The known property ids and their variant types are:
  3126.       PID_INTSITE_WHATSNEW     [VT_LPWSTR]   What's New text
  3127.       PID_INTSITE_AUTHOR       [VT_LPWSTR]   Author
  3128.       PID_INTSITE_LASTVISIT    [VT_FILETIME] Time site was last visited
  3129.       PID_INTSITE_LASTMOD      [VT_FILETIME] Time site was last modified
  3130.       PID_INTSITE_VISITCOUNT   [VT_UI4]      Number of times user has visited
  3131.       PID_INTSITE_DESCRIPTION  [VT_LPWSTR]   Description text of site
  3132.       PID_INTSITE_COMMENT      [VT_LPWSTR]   User annotated comment
  3133.       PID_INTSITE_RECURSE      [VT_UI4]      Levels to recurse (0-3)
  3134.       PID_INTSITE_WATCH        [VT_UI4]      PIDISM_ flags
  3135.       PID_INTSITE_SUBSCRIPTION [VT_UI8]      Subscription cookie
  3136.       PID_INTSITE_URL          [VT_LPWSTR]   URL
  3137.       PID_INTSITE_TITLE        [VT_LPWSTR]   Title
  3138.       PID_INTSITE_CODEPAGE     [VT_UI4]      Codepage of the document
  3139.       PID_INTSITE_TRACKING     [VT_UI4]      Tracking
  3140. }
  3141.  
  3142.   {$EXTERNALSYM PID_INTSITE_WHATSNEW}
  3143.   PID_INTSITE_WHATSNEW      = 2;
  3144.   {$EXTERNALSYM PID_INTSITE_AUTHOR}
  3145.   PID_INTSITE_AUTHOR        = 3;
  3146.   {$EXTERNALSYM PID_INTSITE_LASTVISIT}
  3147.   PID_INTSITE_LASTVISIT     = 4;
  3148.   {$EXTERNALSYM PID_INTSITE_LASTMOD}
  3149.   PID_INTSITE_LASTMOD       = 5;
  3150.   {$EXTERNALSYM PID_INTSITE_VISITCOUNT}
  3151.   PID_INTSITE_VISITCOUNT    = 6;
  3152.   {$EXTERNALSYM PID_INTSITE_DESCRIPTION}
  3153.   PID_INTSITE_DESCRIPTION   = 7;
  3154.   {$EXTERNALSYM PID_INTSITE_COMMENT}
  3155.   PID_INTSITE_COMMENT       = 8;
  3156.   {$EXTERNALSYM PID_INTSITE_FLAGS}
  3157.   PID_INTSITE_FLAGS         = 9;
  3158.   {$EXTERNALSYM PID_INTSITE_CONTENTLEN}
  3159.   PID_INTSITE_CONTENTLEN    = 10;
  3160.   {$EXTERNALSYM PID_INTSITE_CONTENTCODE}
  3161.   PID_INTSITE_CONTENTCODE   = 11;
  3162.   {$EXTERNALSYM PID_INTSITE_RECURSE}
  3163.   PID_INTSITE_RECURSE       = 12;
  3164.   {$EXTERNALSYM PID_INTSITE_WATCH}
  3165.   PID_INTSITE_WATCH         = 13;
  3166.   {$EXTERNALSYM PID_INTSITE_SUBSCRIPTION}
  3167.   PID_INTSITE_SUBSCRIPTION  = 14;
  3168.   {$EXTERNALSYM PID_INTSITE_URL}
  3169.   PID_INTSITE_URL           = 15;
  3170.   {$EXTERNALSYM PID_INTSITE_TITLE}
  3171.   PID_INTSITE_TITLE         = 16;
  3172.   {$EXTERNALSYM PID_INTSITE_CODEPAGE}
  3173.   PID_INTSITE_CODEPAGE      = 18;
  3174.   {$EXTERNALSYM PID_INTSITE_TRACKING}
  3175.   PID_INTSITE_TRACKING      = 19;
  3176.  
  3177.   // Flags for PID_IS_FLAGS
  3178.   {$EXTERNALSYM PIDISF_RECENTLYCHANGED}
  3179.   PIDISF_RECENTLYCHANGED  = $00000001;
  3180.   {$EXTERNALSYM PIDISF_CACHEDSTICKY}
  3181.   PIDISF_CACHEDSTICKY     = $00000002;
  3182.   {$EXTERNALSYM PIDISF_CACHEIMAGES}
  3183.   PIDISF_CACHEIMAGES      = $00000010;
  3184.   {$EXTERNALSYM PIDISF_FOLLOWALLLINKS}
  3185.   PIDISF_FOLLOWALLLINKS   = $00000020;
  3186.  
  3187.   // Values for PID_INTSITE_WATCH
  3188.   {$EXTERNALSYM PIDISM_GLOBAL}
  3189.   PIDISM_GLOBAL           = 0;       // Monitor based on global setting
  3190.   {$EXTERNALSYM PIDISM_WATCH}
  3191.   PIDISM_WATCH            = 1;       // User says watch
  3192.   {$EXTERNALSYM PIDISM_DONTWATCH}
  3193.   PIDISM_DONTWATCH        = 2;       // User says don't watch
  3194.  
  3195. { The shell keeps track of some per-user state to handle display
  3196.   options that is of major interest to ISVs.
  3197.   The key one requested right now is "DoubleClickInWebView". }
  3198.  
  3199. type
  3200.   {$EXTERNALSYM SHELLFLAGSTATE}
  3201.   SHELLFLAGSTATE = packed record
  3202.     Data: Word;
  3203. {   BOOL fShowAllObjects : 1;
  3204.     BOOL fShowExtensions : 1;
  3205.     BOOL fNoConfirmRecycle : 1;
  3206.     BOOL fShowSysFiles : 1;
  3207.     BOOL fShowCompColor : 1;
  3208.     BOOL fDoubleClickInWebView : 1;
  3209.     BOOL fDesktopHTML : 1;
  3210.     BOOL fWin95Classic : 1;
  3211.     BOOL fDontPrettyPath : 1;
  3212.     BOOL fShowAttribCol : 1;
  3213.     BOOL fMapNetDrvBtn : 1;
  3214.     BOOL fShowInfoTip : 1;
  3215.     BOOL fHideIcons : 1;
  3216.     UINT fRestFlags : 3;}
  3217.   end;
  3218.   PShellFlagState = ^TShellFlagState;
  3219.   TShellFlagState = SHELLFLAGSTATE;
  3220.  
  3221. const
  3222.   {$EXTERNALSYM SSF_SHOWALLOBJECTS}
  3223.   SSF_SHOWALLOBJECTS          = $0001;
  3224.   {$EXTERNALSYM SSF_SHOWEXTENSIONS}
  3225.   SSF_SHOWEXTENSIONS          = $0002;
  3226.   {$EXTERNALSYM SSF_SHOWCOMPCOLOR}
  3227.   SSF_SHOWCOMPCOLOR           = $0008;
  3228.   {$EXTERNALSYM SSF_SHOWSYSFILES}
  3229.   SSF_SHOWSYSFILES            = $0020;
  3230.   {$EXTERNALSYM SSF_DOUBLECLICKINWEBVIEW}
  3231.   SSF_DOUBLECLICKINWEBVIEW    = $0080;
  3232.   {$EXTERNALSYM SSF_SHOWATTRIBCOL}
  3233.   SSF_SHOWATTRIBCOL           = $0100;
  3234.   {$EXTERNALSYM SSF_DESKTOPHTML}
  3235.   SSF_DESKTOPHTML             = $0200;
  3236.   {$EXTERNALSYM SSF_WIN95CLASSIC}
  3237.   SSF_WIN95CLASSIC            = $0400;
  3238.   {$EXTERNALSYM SSF_DONTPRETTYPATH}
  3239.   SSF_DONTPRETTYPATH          = $0800;
  3240.   {$EXTERNALSYM SSF_SHOWINFOTIP}
  3241.   SSF_SHOWINFOTIP             = $2000;
  3242.   {$EXTERNALSYM SSF_MAPNETDRVBUTTON}
  3243.   SSF_MAPNETDRVBUTTON         = $1000;
  3244.   {$EXTERNALSYM SSF_NOCONFIRMRECYCLE}
  3245.   SSF_NOCONFIRMRECYCLE        = $8000;
  3246.   {$EXTERNALSYM SSF_HIDEICONS}
  3247.   SSF_HIDEICONS               = $4000;
  3248.  
  3249. { Specify the bits you are interested in in dwMask and they will be
  3250.  filled out in the lpss structure.
  3251.  
  3252.  When these settings change, a WM_SETTINGCHANGE message is sent
  3253.  with the string lParam value of "ShellState". }
  3254.  
  3255. procedure SHGetSettings(var lpss: TShellFlagState; dwMask: DWORD); stdcall;
  3256. {$EXTERNALSYM SHGetSettings}
  3257.  
  3258. { SoftwareUpdateMessageBox }
  3259. {
  3260.     Provides a standard message box for the alerting the user that a software
  3261.     update is available or installed. No UI will be displayed if there is no
  3262.     update available or if the available update version is less than or equal
  3263.     to the Advertised update version.
  3264.  
  3265.     hWnd                - [in] Handle of owner window
  3266.     szDistUnit          - [in] Unique identifier string for a code distribution unit. For
  3267.                                ActiveX controls and Active Setup installed components, this
  3268.                                is typically a GUID string.
  3269.     dwFlags             - [in] Must be 0.
  3270.     psdi                - [in,out] Pointer to SOFTDISTINFO ( see URLMon.h ). May be NULL.
  3271.                                 cbSize should be initialized
  3272.                                 by the caller to sizeof(SOFTDISTINFO), dwReserved should be set to 0.
  3273.  
  3274.     RETURNS:
  3275.  
  3276.     IDNO     - The user chose cancel. If *pbRemind is FALSE, the caller should save the 
  3277.                update version from the SOFTDISTINFO and pass it in as the Advertised
  3278.                version in future calls.
  3279.  
  3280.     IDYES    - The user has selected Update Now/About Update. The caller should navigate to
  3281.                the SOFTDISTINFO's pszHREF to initiate the install or learn about it.
  3282.                The caller should save the update version from the SOFTDISTINFO and pass
  3283.                it in as the Advertised version in future calls.
  3284.  
  3285.     IDIGNORE - There is no pending software update. Note: There is
  3286.                no Ignore button in the standard UI. This occurs if the available
  3287.                version is less than the installed version or is not present or if the
  3288.                Advertised version is greater than or equal to the update version.
  3289.  
  3290.     IDABORT  - An error occured. Call GetSoftwareUpdateInfo() for a more specific HRESULT.
  3291.                Note: There is no Abort button in the standard UI.
  3292. }
  3293.  
  3294. function SoftwareUpdateMessageBox(hWnd: HWND; szDistUnit: PWideChar;
  3295.   dwFlags: DWORD; var psdi: TSoftDistInfo): DWORD; stdcall;
  3296. {$EXTERNALSYM SoftwareUpdateMessageBox}
  3297.  
  3298. implementation
  3299.  
  3300. const
  3301.   shell32 = 'shell32.dll';
  3302.  
  3303. procedure SHAddToRecentDocs;             external shell32 name 'SHAddToRecentDocs';
  3304. function SHBrowseForFolderA;          external shell32 name 'SHBrowseForFolderA';
  3305. function SHBrowseForFolderW;          external shell32 name 'SHBrowseForFolderW';
  3306. function SHBrowseForFolder;          external shell32 name 'SHBrowseForFolderA';
  3307. procedure SHChangeNotify;                external shell32 name 'SHChangeNotify';
  3308. function SHGetDataFromIDListA;        external shell32 name 'SHGetDataFromIDListA';
  3309. function SHGetDataFromIDListW;        external shell32 name 'SHGetDataFromIDListW';
  3310. function SHGetDataFromIDList;        external shell32 name 'SHGetDataFromIDListA';
  3311. function SHGetDesktopFolder;            external shell32 name 'SHGetDesktopFolder';
  3312. function SHGetInstanceExplorer;         external shell32 name 'SHGetInstanceExplorer';
  3313. function SHGetMalloc;                   external shell32 name 'SHGetMalloc';
  3314. function SHGetPathFromIDListA;        external shell32 name 'SHGetPathFromIDListA';
  3315. function SHGetPathFromIDListW;        external shell32 name 'SHGetPathFromIDListW';
  3316. function SHGetPathFromIDList;        external shell32 name 'SHGetPathFromIDListA';
  3317. function SHGetSpecialFolderLocation;    external shell32 name 'SHGetSpecialFolderLocation';
  3318. function SHLoadInProc;                  external shell32 name 'SHLoadInProc';
  3319. function SHGetSpecialFolderPathA;     external shell32 name 'SHGetSpecialFolderPathA'
  3320. function SHGetSpecialFolderPathW;     external shell32 name 'SHGetSpecialFolderPathW'
  3321. function SHGetSpecialFolderPath;     external shell32 name 'SHGetSpecialFolderPathA'
  3322. procedure SHGetSettings;                external shell32 name 'SHGetSettings'
  3323. function SoftwareUpdateMessageBox;      external shell32 name 'SoftwareUpdateMessageBox'
  3324.  
  3325. end.
  3326.  
  3327.  
  3328.