Функция SetupInstallFileA (setupapi.h)
[Эта функция доступна для использования в операционных системах, указанных в разделе "Требования". Он может быть изменен или недоступен в последующих версиях. SetupAPI больше не следует использовать для установки приложений. Вместо этого используйте установщик Windows для разработки установщиков приложений. SetupAPI по-прежнему используется для установки драйверов устройств.]
Функция SetupInstallFile устанавливает файл, указанный INFCONTEXT, возвращенный SetupFindXXXLine или явным образом по имени файла и пути.
Если файл копируется, вызывающий эту функцию должен иметь права записи в целевой каталог.
Синтаксис
WINSETUPAPI BOOL SetupInstallFileA(
[in] HINF InfHandle,
[in] PINFCONTEXT InfContext,
[in] PCSTR SourceFile,
[in] PCSTR SourcePathRoot,
[in] PCSTR DestinationName,
[in] DWORD CopyStyle,
[in] PSP_FILE_CALLBACK_A CopyMsgHandler,
[in] PVOID Context
);
Параметры
[in] InfHandle
Необязательный указатель на дескриптор в INF-файл, содержащий разделы SourceDisksNames и SourceDisksFiles. Если для системы пользователя существуют разделы для конкретной платформы (например, SourceDisksNames.x86 и SourceDisksFiles.x86), будет использоваться раздел, зависящий от платформы. Если InfContext имеет значение NULL и CopyStyle включает SP_COPY_SOURCE_ABSOLUTE или SP_COPY_SOURCEPATH_ABSOLUTE, InfHandle игнорируется.
[in] InfContext
Необязательный указатель на контекст строки в разделе "Файлы копирования" в INF-файле. Подпрограмма ищет этот файл в разделе SourceDisksFiles InfHandle для получения сведений о копировании файлов. Если InfHandle не указано, SourceFile.
[in] SourceFile
Необязательный указатель на имя файла (без пути) копируемого файла. Файл ищется в разделе SourceDisksFiles. Параметр SourceFile
[in] SourcePathRoot
Необязательный указатель на корневой путь для копирования файла (например, A:\ или F:). Пути в разделе SourceDisksNames добавляются к этому пути. Параметр SourcePathRoot игнорируется, если CopyStyle включает флаг SP_COPY_SOURCE_ABSOLUTE.
[in] DestinationName
Необязательный указатель на имя файла (без пути) целевого файла. Этот параметр может иметь значение NULL, чтобы указать, что целевой файл должен иметь то же имя, что и исходный файл. Если InfContext не указан, DestinationName предоставляет полный путь и имя файла для целевого объекта.
[in] CopyStyle
Флаги, управляющие поведением операции копирования файлов. Эти флаги могут быть сочетанием следующих значений.
Ценность | Значение |
---|---|
|
Удаляет исходный файл после успешной копии. Вызывающий объект не уведомляется, если операция удаления завершается ошибкой. |
|
Копирует файл только в том случае, если это приведет к перезаписи файла в пути назначения. Если целевой объект не существует, функция возвращает FALSE и возвращает NO_ERROR GetLastError. |
|
Проверяет, копируется ли каждый файл, чтобы узнать, является ли его версия той же версией или не более новой, чем существующую копию в целевом объекте.
Сведения о версии файла, используемые во время проверок версий, указываются в dwFileVersionMS и dwFileVersionLS членов структуры VS_FIXEDFILEINFO, как указано в функциях версии. Если у одного из файлов нет ресурсов версии или если они имеют идентичные сведения о версии, исходный файл считается более новым. Если исходный файл не является более новым или равным в версии, а указан copyMsgHandler, вызывающий объект уведомляется и может отменить операцию копирования. Если CopyMsgHandler не указан, файл не копируется. |
|
Проверьте каждый файл, копируемый, чтобы узнать, являются ли его ресурсы версии более новой, чем существующую копию в целевом объекте. Если исходный файл является более новым, но не равен в версии существующего целевого объекта, файл копируется. |
|
Проверьте, существует ли целевой файл, и, если да, уведомите вызывающего абонента, который может ветоить копию. Если CopyMsgHandler не указан, файл не перезаписывается. |
|
Не распаковывайте файл. Если этот флаг задан, целевой файл не получает несжатую форму исходного имени (при необходимости). Например, копирование F:\x86\cmd.ex_ в \\установить\temp приводит к целевому файлу \\install\temp\cmd.ex_. Если флаг SP_COPY_NODECOMP не указан, файл будет распаковлен, а целевой объект будет вызываться \\install\temp\cmd.exe. Имя файла, часть DestinationName, если указано, удаляется и заменяется именем файла исходного файла. При указании SP_COPY_NODECOMP нет сведений о языке или версии. |
|
Изучите каждый файл, копируемый, чтобы узнать, отличается ли его язык от языка любого существующего файла, уже размещенного в целевом объекте. Если это так, и указана CopyMsgHandler, вызывающий объект уведомляется и может отменить копию. Если CopyMsgHandler не указан, файл не копируется. |
|
SourceFile — это полный путь к источнику. Не ищите его в разделе SourceDisksNames в INF-файле. |
|
SourcePathRoot является полной частью исходного файла. Игнорируйте относительный источник, указанный в разделе SourceDisksNames в INF-файле исходного носителя, где находится файл. Этот флаг игнорируется, если указан SP_COPY_SOURCE_ABSOLUTE. |
|
Если целевой объект существует, ведет себя так, как если бы он использовался и помещает файл в очередь для копирования при следующем перезапуске системы. |
|
Проверяет, существует ли целевой файл, и, если да, файл не перезаписан. Вызывающий объект уведомляется. |
|
Проверяет, копируется ли каждый файл, чтобы узнать, являются ли его ресурсы версии (или метки времени для файлов, не являющихся изображениями) указывает, что она не является более новой, чем существующая копия в целевом объекте. Если копируемый файл не является более новым, файл не копируется. Вызывающий объект уведомляется. Функция возвращает FALSE, а GetLastError возвращает NO_ERROR. |
[in] CopyMsgHandler
Необязательный указатель на функцию обратного вызова, которая может быть уведомлена о различных условиях, которые могут возникнуть во время операции копирования файлов.
[in] Context
Необязательный указатель на определяемое вызывающим значением, которое передается в качестве первого параметра функции обратного вызова.
Возвращаемое значение
Если функция выполнена успешно, возвращаемое значение является ненулевое значение.
Если функция завершается ошибкой, возвращаемое значение равно нулю. Чтобы получить расширенные сведения об ошибке, вызовите GetLastError.
Если GetLastError возвращает NO_ERROR, операция копирования файлов не завершена. Возможно, файл не был скопирован, так как операция копирования файлов была ненужной или так как функция обратного вызова файла вернула FALSE.
Замечания
Если каталог UNC указан в качестве целевого каталога установки файла, перед вызовом SetupInstallFileнеобходимо убедиться, что он существует. Функции установки не проверяют наличие и не создают каталоги UNC. Если целевой каталог UNC не существует, установка файла завершится ошибкой.
Заметка
Заголовок setupapi.h определяет SetupInstallFile как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОДа. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, не зависящим от кодирования, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.
Требования
Требование | Ценность |
---|---|
минимальные поддерживаемые клиентские | Windows XP [только классические приложения] |
минимальный поддерживаемый сервер | Windows Server 2003 [только классические приложения] |
целевая платформа | Виндоус |
заголовка | setupapi.h |
библиотеки |
Setupapi.lib |
DLL | Setupapi.dll |
См. также
Обзор