Функция SetupGetInfInformationW (setupapi.h)
[Эта функция доступна для использования в операционных системах, указанных в разделе "Требования". Он может быть изменен или недоступен в последующих версиях. SetupAPI больше не следует использовать для установки приложений. Вместо этого используйте установщик Windows для разработки установщиков приложений. SetupAPI по-прежнему используется для установки драйверов устройств.]
Функция SetUpGetInfInformation возвращает структуру
Синтаксис
WINSETUPAPI BOOL SetupGetInfInformationW(
[in] LPCVOID InfSpec,
[in] DWORD SearchControl,
[in, out] PSP_INF_INFORMATION ReturnBuffer,
[in] DWORD ReturnBufferSize,
[in, out] PDWORD RequiredSize
);
Параметры
[in] InfSpec
Дескриптор или имя файла ДЛЯ INF-файла в зависимости от значения SearchControl.
[in] SearchControl
Этот параметр может быть одним из следующих констант.
INFINFO_INF_SPEC_IS_HINF
InfSpec — это дескриптор INF. Один дескриптор INF может ссылать на несколько INF-файлов, если они были загружены вместе. Если это так, структура, возвращаемая этой функцией, содержит несколько наборов сведений.
INFINFO_INF_NAME_IS_ABSOLUTE
Строка, указанная для InfSpec, представляет собой полный путь. Дальнейшая обработка не выполняется на InfSpec.
INFINFO_DEFAULT_SEARCH
Найдите расположения по умолчанию для INF-файла, указанного для InfSpec, которое, как предполагается, является только именем файла. Расположения по умолчанию %windir%\inf, а затем %windir%\system32.
INFINFO_REVERSE_DEFAULT_SEARCH
То же, что и INFINFO_DEFAULT_SEARCH, за исключением расположений по умолчанию, выполняются в обратном порядке.
INFINFO_INF_PATH_LIST_SEARCH
Найдите INF-файл в каждом из каталогов, перечисленных в записи DevicePath значений в следующих статьях:HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion
[in, out] ReturnBuffer
Если не значение NULL, указывает на буфер, в котором эта функция возвращает структуру SP_INF_INFORMATION.
Вы можете вызвать функцию один раз, чтобы получить необходимый размер буфера, выделить необходимую память, а затем вызвать функцию во второй раз, чтобы получить данные. С помощью этого метода можно избежать ошибок из-за недостаточного размера буфера. Дополнительные сведения см. в разделе "Примечания" этой статьи.
[in] ReturnBufferSize
Размер ReturnBufferв байтах.
[in, out] RequiredSize
Если не null, указывает на переменную, в которой эта функция возвращает требуемый размер в байтах для буфера, на который указывает ReturnBuffer.
Если указан ReturnBuffer, а необходимый размер превышает ReturnBufferSize, функция завершается ошибкой и вызовом GetLastError возвращается ERROR_INSUFFICIENT_BUFFER.
Возвращаемое значение
Если функция выполнена успешно, возвращаемое значение является ненулевое значение.
Если функция завершается ошибкой, возвращаемое значение равно 0 (ноль). Чтобы получить расширенные сведения об ошибке, вызовите GetLastError.
Если INF-файл не удается найти, функция возвращает FALSE и последующий вызов GetLastError возвращает ERROR_FILE_NOT_FOUND.
Замечания
Если эта функция вызывается с помощью ReturnBuffer NULL и ReturnBufferSize 0 (ноль), функция помещает размер буфера, необходимый для хранения указанных данных в переменную, на которую указывает RequiredSize. Если функция выполнена успешно, возвращаемое значение является ненулевое значение. В противном случае возвращаемое значение равно 0 (ноль), а расширенные сведения об ошибке можно получить путем вызова GetLastError.
Заметка
Заголовок setupapi.h определяет SetupGetInfInformation как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора UNICODE. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, не зависящим от кодирования, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.
Требования
Требование | Ценность |
---|---|
минимальные поддерживаемые клиентские | Windows XP [только классические приложения] |
минимальный поддерживаемый сервер | Windows Server 2003 [только классические приложения] |
целевая платформа | Виндоус |
заголовка | setupapi.h |
библиотеки |
Setupapi.lib |
DLL | Setupapi.dll |
См. также
Обзор