Поделиться через


Структура SHFILEOPSTRUCTA (shellapi.h)

Содержит сведения о том, что функция SHFileOperation использует для выполнения операций с файлами.

Примечание По состоянию на Windows Vista рекомендуется использовать интерфейс IFileOperation .
 

Синтаксис

typedef struct _SHFILEOPSTRUCTA {
  HWND         hwnd;
  UINT         wFunc;
  PCZZSTR      pFrom;
  PCZZSTR      pTo;
  FILEOP_FLAGS fFlags;
  BOOL         fAnyOperationsAborted;
  LPVOID       hNameMappings;
  PCSTR        lpszProgressTitle;
} SHFILEOPSTRUCTA, *LPSHFILEOPSTRUCTA;

Члены

hwnd

Тип: HWND

Дескриптор окна в диалоговом окне для отображения сведений о состоянии операции файла.

wFunc

Тип: UINT

Значение, указывающее, какая операция выполняется. Одно из следующих значений:

FO_COPY

Скопируйте файлы, указанные в элементе pFrom , в расположение, указанное в элементе pTo.

FO_DELETE

Удалите файлы, указанные в pFrom.

FO_MOVE

Переместите файлы, указанные в pFrom, в расположение, указанное в pTo.

FO_RENAME

Переименуйте файл, указанный в pFrom. Этот флаг нельзя использовать для переименования нескольких файлов с одним вызовом функции. Вместо этого используйте FO_MOVE.

pFrom

Тип: PCZZTSTR

Примечание Эта строка должна быть завершена с двойным значением NULL.
 
Указатель на одно или несколько исходных имен файлов. Эти имена должны быть полными путями, чтобы предотвратить непредвиденные результаты.

Стандартные MS-DOS подстановочные знаки, такие как "*", разрешены только в позиции имени файла. Использование подстановочного знака в другом месте строки приведет к непредсказуемым результатам.

Хотя этот элемент объявлен как одна строка, завершающаяся значением NULL, фактически это буфер, который может содержать несколько имен файлов с разделителями NULL. Каждое имя файла завершается одним символом NULL. Последнее имя файла завершается двойным символом NULL ("\0\0") для указания конца буфера.

pTo

Тип: PCZZTSTR

Примечание Эта строка должна быть завершена с двойным значением NULL.
 
Указатель на целевой файл или имя каталога. Этот параметр должен иметь значение NULL, если он не используется. Подстановочные знаки не допускаются. Их использование приведет к непредсказуемым результатам.

Как и pFrom, элемент pTo также является строкой с двойным значением NULL и обрабатывается точно так же. Однако pTo должны соответствовать следующим спецификациям:

  • Подстановочные знаки не поддерживаются.
  • Операции копирования и перемещения могут указывать конечные каталоги, которые не существуют. В этих случаях система пытается создать их и обычно отображает диалоговое окно, чтобы попросить пользователя создать новый каталог. Чтобы отключить это диалоговое окно и создать каталоги автоматически, задайте флаг FOF_NOCONFIRMMKDIR в fFlags.
  • Для операций копирования и перемещения буфер может содержать несколько имен целевых файлов, если элемент fFlags указывает FOF_MULTIDESTFILES.
  • Упаковайте несколько имен в строку pTo так же, как и для pFrom.
  • Используйте полные пути. Использование относительных путей не запрещено, но может иметь непредсказуемые результаты.

fFlags

Тип: FILEOP_FLAGS

Флаги, управляющие операцией файла. Этот элемент может использовать сочетание следующих флагов.

FOF_ALLOWUNDO

При возможности сохраните сведения об отмене.

До Windows Vista операции можно отменить только из того же процесса, который выполнял исходную операцию.

В Системах Windows Vista и более поздних версий область действия отмены — это сеанс пользователя. Любой процесс, выполняемый в сеансе пользователя, может отменить другую операцию. Состояние отмены хранится в процессе Explorer.exe и до тех пор, пока этот процесс выполняется, он может координировать функции отмены.

Если параметр исходного файла не содержит полный путь и имена файлов, этот флаг игнорируется.

FOF_CONFIRMMOUSE

Не используется.

FOF_FILESONLY

Выполните операцию только в файлах (а не в папках), если указано имя файла подстановочного знака (.) .

FOF_MULTIDESTFILES

Элемент pTo указывает несколько целевых файлов (один для каждого исходного файла в pFrom), а не один каталог, в котором должны быть отложены все исходные файлы.

FOF_NOCONFIRMATION

Ответьте "Да" на все для любого диалогового окна, отображаемого.

FOF_NOCONFIRMMKDIR

Не попросите пользователя подтвердить создание нового каталога, если операция требует создания.

FOF_NO_CONNECTED_ELEMENTS

Версия 5.0. Не перемещайте подключенные файлы как группу. Перемещайте только указанные файлы.

FOF_NOCOPYSECURITYATTRIBS

Версия 4.71. Не копируйте атрибуты безопасности файла. Целевой файл получает атрибуты безопасности новой папки.

FOF_NOERRORUI

Не отображайте диалоговое окно пользователю, если возникает ошибка.

FOF_NORECURSEREPARSE

Не используется.

FOF_NORECURSION

Выполните операцию только в локальном каталоге. Не действовать рекурсивно в подкаталогах, что является поведением по умолчанию.

FOF_NO_UI

Windows Vista. Выполняйте операцию автоматически, не показыв пользовательский интерфейс пользователю. Это эквивалентно FOF_SILENT | FOF_NOCONFIRMATION | FOF_NOERRORUI | FOF_NOCONFIRMMKDIR.

FOF_RENAMEONCOLLISION

Присвойте файлу новое имя в операции перемещения, копирования или переименования, если файл с целевым именем уже существует в месте назначения.

FOF_SILENT

Не отображайте диалоговое окно хода выполнения.

FOF_SIMPLEPROGRESS

Отображает диалоговое окно хода выполнения, но не отображает отдельные имена файлов, так как они работают.

FOF_WANTMAPPINGHANDLE

Если FOF_RENAMEONCOLLISION указан и все файлы были переименованы, назначьте объект сопоставления имен, содержащий старые и новые имена элементу hNameMappings. Этот объект должен быть освобожден с помощью SHFreeNameMappings, если он больше не нужен.

FOF_WANTNUKEWARNING

Версия 5.0. Отправьте предупреждение, если файл окончательно уничтожается во время операции удаления, а не перезапускается. Этот флаг частично переопределяет FOF_NOCONFIRMATION.

fAnyOperationsAborted

Тип: BOOL

Когда функция возвращается, этот элемент содержит TRUE, если все операции с файлами прерваны, прежде чем они были завершены; в противном случае FALSE. Операция может быть прервана пользователем с помощью пользовательского интерфейса или она может быть прервана системой, если были заданы флаги FOF_NOERRORUI или FOF_NOCONFIRMATION.

hNameMappings

Тип: LPVOID

Когда функция возвращается, этот элемент содержит дескриптор объекта сопоставления имен, который содержит старые и новые имена переименованных файлов. Этот элемент используется только в том случае, если элемент fFlags включает флаг FOF_WANTMAPPINGHANDLE. Дополнительные сведения см. в примечаниях.

lpszProgressTitle

Тип: PCTSTR

Указатель на заголовок диалогового окна хода выполнения. Это строка, завершающаяся значением NULL. Этот элемент используется только в том случае, если fFlags включает флаг FOF_SIMPLEPROGRESS.

Замечания

Важные Необходимо убедиться, что пути к источнику и назначению завершаются двойным значением NULL. Обычная строка заканчивается только одним пустым символом. Если передать это значение в исходных или конечных элементах, функция не будет понимать, когда она достигла конца строки и будет продолжать читаться в памяти до тех пор, пока она не перейдет к случайному двойному значению NULL. Это может привести по крайней мере к переполнению буфера и, возможно, непреднамеренному удалению несвязанных данных.
 
// WRONG
LPTSTR pszSource = L"C:\\Windows\\*";

// RIGHT
LPTSTR pszSource = L"C:\\Windows\\*\0";

Чтобы учесть два конечных символа NULL, обязательно создайте буферы, достаточно большие для хранения MAX_PATH (который обычно включает один завершающийся символ NULL) плюс 1.

Невозможно переоценить, что пути всегда должны быть полными. Если pFrom или члены являются неквалифицированными именами, текущие каталоги принимаются из глобальных параметров текущего диска и каталога, управляемых GetCurrentDirectory и функции SetCurrentDirectory.

Если вы не предоставляете полный путь, следующие факты становятся актуальными:

  • Отсутствие пути перед именем файла не указывает на SHFileOperation, что этот файл находится в корне текущего каталога.
  • Переменная среды PATH не используется SHFileOperation для определения допустимого пути.
  • SHFileOperation нельзя использовать каталог, который является текущим каталогом при начале выполнения. Каталог, который рассматривается как текущий каталог, является процессным, и его можно изменить с другого потока во время выполнения операции. Если бы это произошло, результаты SHFileOperation будут непредсказуемыми.

Если pFrom задано имя файла без полного пути, удаление файла с FO_DELETE не перемещает его в корзину, даже если установлен флаг FOF_ALLOWUNDO. Чтобы удалить файл в корзину, необходимо предоставить полный путь.

SHFileOperation не удается выполнить префикс пути с помощью "\?".

Существует две версии этой структуры, версия ANSI (SHFILEOPSTRUCTA) и версия Юникода (SHFILEOPSTRUCTW). Версия Юникода идентична версии ANSI, за исключением того, что широкие символьные строки (LPCWSTR) используются вместо строк символов ANSI (LPCSTR). В Windows 98 и более ранних версиях поддерживается только версия ANSI. В Microsoft Windows NT 4.0 и более поздней версии поддерживаются версии ANSI и Юникод этой структуры. SHFILEOPSTRUCTW и SHFILEOPTSTRUCTA никогда не следует использовать напрямую; Соответствующая структура определена как SHFILEOPSTRUCT предварительной компиляцией в зависимости от того, компилируется ли приложение для ANSI или Юникода.

SHNAMEMAPPING имеет аналогичные версии ANSI и Юникода. Для приложений ANSI hNameMappings указывает на int за массивом структур ANSI SHNAMEMAPPING. Для приложений Юникода hNameMappings указывает на int за массивом структур Юникода SHNAMEMAPPING. Однако в Microsoft Windows NT 4.0 и более поздних версий SHFileOperationвсегда возвращает дескриптор в набор структур SHNAMEMAPPING. Если вы хотите, чтобы приложения были функциональными со всеми версиями Windows, приложение должно использовать условный код для решения сопоставлений имен. Например:

x = SHFileOperation(&shop);

if (fWin9x) 
    HandleAnsiNameMappings(shop.hNameMappings);
else 
    HandleUnicodeNameMappings(shop.hNameMappings);

Рассматривать hNameMappings как указатель на структуру, члены которой являются значением UINT, за которым следует указатель на массив структур SHNAMEMAPPING, как показано в объявлении:

struct HANDLETOMAPPINGS 
{
    UINT              uNumberOfMappings;  // Number of mappings in the array.
    LPSHNAMEMAPPING   lpSHNameMapping;    // Pointer to the array of mappings.
};

Значение UINT указывает количество структур SHNAMEMAPPING в массиве. Каждая структура SHNAMEMAPPING содержит старый и новый путь для одного из переименованных файлов.

Примечание Дескриптор должен быть освобожден с SHFreeNameMappings.
 

Заметка

Заголовок shellapi.h определяет SHFILEOPSTRUCT как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОДа. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, который не является кодировкой нейтральным, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.

Требования

Требование Ценность
минимальные поддерживаемые клиентские Windows XP [только классические приложения]
минимальный поддерживаемый сервер Windows 2000 Server [только классические приложения]
заголовка shellapi.h