Вспомогательные функции библиотек Windows 7

После двухнедельного перерыва мы возвращаемся к нашим техническим статьям о библиотеках Windows 7. Это шестая по счету статья о библиотеках Windows 7. На данный момент вы должны быть знакомы с библиотеками Windows 7 и понимать их внутреннюю структуру и то, как они встраиваются в оболочку Windows. Вы знакомы с различными доступными моделями программирования, а также знаете, как использовать программируемые интерфейсы Windows Shell для работы с содержимым библиотек. В этой статьей мы рассмотрим вспомогательные функции библиотек Windows 7.

COM-объект IShellLibrary представляет библиотеки Windows 7. Этот интерфейс определяет методы создания и управления библиотеками. Вы можете работать непосредственно с COM-интерфейсом, но проще использовать более высокий уровень абстракции функций. Shobjidl.h предоставляет следующие вспомогательные функции библиотеки:

  • SHAddFolderPathToLibrary – добавляет папку в библиотеку
  • SHCreateLibrary – создает объект IShellLibrary
  • SHLoadLibraryFromItem – создает и считывает объектIShellLibrary из указанного файла определения библиотеки
  • SHLoadLibraryFromKnownFolder – создает и считывает объект IshellLibrary для указанного KNOWNFOLDERID
  • SHLoadLibraryFromParsingName – создает и считывает объект IshellLibrary для указанного пути
  • SHRemoveFolderPathFromLibrary – удаляет папку из библиотеки
  • SHResolveFolderPathInLibrary – пытается восстановить месторасположение папки библиотеки, которая была перемещена или переименована
  • SHSaveLibraryInFolderPath – сохраняет объект IShellLibrary на диск

Примечание: Если вам интересно, как реализованы эти вспомогательные функции, просто откройте файл Shobjudl.h и поищите их там.

Используя эти вспомогательные функции, вы можете выполнить большинство операций управления без использования низкоуровневых API. Например, вы можете добавить папку в библиотеку используя SHAddFolderPathToLibrary, не вызывая ISHellLibrary::Commit() . Поскольку IShellLibrary является программируемым интерфейсом, основанным на COM, вам понадобится вызвать функцию CoInitialize. После вам необходимо использовать вспомогательные функции. Нижеприведенный фрагмент кода создает новую библиотеку, добавляет в нее папку и сохраняет файл определения библиотеки в папку библиотеки.

 

 IShellLibrary *pLib; 
IShellItem *pSi;
SHCreateLibrary(IID_PPV_ARGS(&pLib));
SHAddFolderPathToLibrary( pLib, L"C:\\temp ");
pLib ->SaveInKnownFolder( 
FOLDERID_Libraries, 
            L"Test 1 Lib", 
            LSF_MAKEUNIQUENAME, 
            & pSi);

 

Вспомогательные функции не предоставляют всех возможностей интерфейса IShellLibrary. Работая напрямую с интерфейсом IShellLibrary, вы можете вывести или установить иконку библиотеки, используя GetIcon и SetIcon. Но куда более важно, что вы можете получить содержимое библиотеки, используя IShellLibrary:: GetFolders() , как то показано во фрагменте кода ниже.

 

 IShellLibrary *pslLibrary;
SHLoadLibraryFromKnownFolder(
            FOLDERID_PicturesLibrary, 
            STGM_READ, 
            IID_PPV_ARGS(&pslLibrary));

IShellItemArray *psiaFolders;
pslLibrary->GetFolders(
            LFF_FORCEFILESYSTEM, 
            IID_PPV_ARGS(&psiaFolders));

 

В следующей статьей мы пройдемся по некоторым методам синхронизации содержимого библиотек.