Función SetupInstallFilesFromInfSectionA (setupapi.h)
[Esta función está disponible para su uso en los sistemas operativos indicados en la sección Requisitos. Puede modificarse o no estar disponible en versiones posteriores. SetupAPI ya no debe usarse para instalar aplicaciones. En su lugar, use Windows Installer para desarrollar instaladores de aplicaciones. SetupAPI sigue usándose para instalar controladores de dispositivo.]
La función
Si se modifica un archivo, se requiere que el autor de la llamada de esta función tenga privilegios para escribir en el directorio de destino.
Sintaxis
WINSETUPAPI BOOL SetupInstallFilesFromInfSectionA(
[in] HINF InfHandle,
[in] HINF LayoutInfHandle,
[in] HSPFILEQ FileQueue,
[in] PCSTR SectionName,
[in] PCSTR SourceRootPath,
[in] UINT CopyFlags
);
Parámetros
[in] InfHandle
Identificador de un archivo INF que contiene la sección que se va a instalar.
[in] LayoutInfHandle
Puntero opcional a un identificador del archivo INF que contiene las secciones SourceDisksFiles y SourceDisksNames.
Si no se especifica LayoutInfHandle, se usan las secciones SourceDisksFiles y SourceDisksNames de InfHandle.
[in] FileQueue
Identificador de la cola donde se van a agregar las operaciones de instalación.
[in] SectionName
El nombre de la sección Instalar de la parámetro InfHandle que enumera las secciones Copiar archivos, Eliminar archivos y Cambiar nombre de archivos que contienen los archivos que se van a instalar.
Use una cadenaterminada en un
[in] SourceRootPath
Puntero opcional a una ruta de acceso raíz a los archivos de origen que se van a copiar, por ejemplo, A:\ o \pegasus\win\install.
Use una cadenaterminada en un
[in] CopyFlags
Puntero opcional a un conjunto de marcas que controlan el comportamiento de la operación de copia de archivos.
Las marcas pueden ser una combinación de los valores siguientes.
SP_COPY_DELETESOURCE
Elimina el archivo de origen cuando la tarea de copia se realiza correctamente.
El autor de la llamada no recibe una notificación si se produce un error en una tarea de eliminación.
SP_COPY_REPLACEONLY
Copia un archivo solo para sobrescribir un archivo en la ruta de acceso de destino.
SP_COPY_NEWER_OR_SAME
Examina cada archivo que se copia para determinar si los recursos de versión indican que es la misma versión o no una copia existente en el destino.
Si el archivo de origen no es una versión más reciente o igual, la función notifica al autor de la llamada que puede cancelar la copia.
La información de versión del archivo que se usa durante las comprobaciones de versiones se especifica en el dwFileVersionMS de
Si uno de los archivos no tiene recursos de versión o si tienen información de versión idéntica, el archivo de origen se considera más reciente.
SP_COPY_NEWER_ONLY
Examina cada archivo que se está copiando para determinar si sus recursos de versión indican que no es más reciente que una copia existente en el destino.
Si el archivo de origen es más reciente pero no es igual a la versión del destino existente, se copia el archivo.
SP_COPY_NOOVERWRITE
Comprueba si existe o no el archivo de destino.
Si el archivo de destino existe, la función notifica al autor de la llamada que puede cancelar la copia.
SP_COPY_NODECOMP
No descomprime un archivo.
Cuando se establece esta marca, el archivo de destino no recibe la forma sin comprimir del nombre de origen, por ejemplo, si copia f:\x86\cmd.ex_ en \install\temp, el resultado es el siguiente archivo de destino: \install\temp\cmd.ex_.
Si no se especifica la marca SP_COPY_NODECOMP, el archivo se descomprime y el destino se llama \install\temp\cmd.exe.
La parte de nombre de archivo de DestinationName, si se especifica, se elimina y se reemplaza por el nombre de archivo de origen. Cuando se especifica SP_COPY_NODECOMP, no se puede comprobar la información de idioma y versión.
SP_COPY_LANGUAGEAWARE
Examina cada archivo que se está copiando para determinar si el idioma es diferente del idioma de cualquier archivo existente que ya esté en el destino.
Si el lenguaje es diferente, la función notifica al autor de la llamada que puede cancelar la tarea de copia.
SP_COPY_SOURCE_ABSOLUTE
SourceFile es una ruta de acceso de origen completa.
No lo busque en la sección SourceDisksNames del archivo INF.
SP_COPY_SOURCEPATH_ABSOLUTE
SourcePathRoot es la parte de ruta de acceso completa del archivo de origen.
Omita el origen relativo que se especifica en la sección SourceDisksNames del archivo INF para el medio de origen donde se encuentra el archivo. Esta marca se omite si se especifica SP_COPY_SOURCE_ABSOLUTE.
SP_COPY_FORCE_IN_USE
Pone en cola el archivo para copiar en el siguiente reinicio del sistema, si el destino existe y se está usando.
SP_COPY_IN_USE_NEEDS_REBOOT
Alerta al usuario de que el sistema debe reiniciarse, si el archivo se usa durante una operación de copia.
SP_COPY_NOSKIP
No proporciona al usuario la opción de omitir un archivo.
SP_COPY_FORCE_NOOVERWRITE
Comprueba si existe o no el archivo de destino y, si el destino existe, el archivo no se sobrescribe y no se notifica al autor de la llamada.
SP_COPY_FORCE_NEWER
Examina cada archivo que se está copiando para identificar que sus recursos de versión (o marcas de tiempo para archivos que no son de imagen) indican que no es más reciente que una copia existente en el destino.
Si el archivo que se está copiando no es más reciente, el archivo no se copia y no se notifica al autor de la llamada.
SP_COPY_WARNIFSKIP
Advierte que omitir un archivo puede afectar a una instalación si el usuario intenta omitir un archivo.
Use esta marca para los archivos críticos del sistema.
Valor devuelto
Si la función se ejecuta correctamente, el valor devuelto es un valor distinto de cero.
Si se produce un error en la función, el valor devuelto es 0 (cero). Para obtener información de error extendida, llame a GetLastError.
Observaciones
se puede llamar a setupInstallFilesFromInfSection varias veces para poner en cola los archivos especificados en varias secciones INF. Una vez confirmada correctamente la cola y los archivos se copian, cambian el nombre o se eliminan, se puede llamar a setupInstallFromInfSection para realizar operaciones de instalación del Registro e INI.
Si se especifica un directorio UNC como directorio de destino de una instalación de archivos, debe asegurarse de que el directorio UNC existe antes de llamar a SetupInstallFilesFromInfSection. Las funciones de instalación no comprueban la existencia de directorios y no crean directorios UNC. Si el directorio UNC de destino no existe, se produce un error en la instalación del archivo.
Nota
El encabezado setupapi.h define SetupInstallFilesFromInfSection como alias que selecciona automáticamente la versión ANSI o Unicode de esta función en función de la definición de la constante de preprocesador UNICODE. La combinación del uso del alias neutral de codificación con código que no es neutral de codificación puede dar lugar a errores de coincidencia que dan lugar a errores de compilación o tiempo de ejecución. Para obtener más información, vea Conventions for Function Prototypes.
SetupInstallFilesFromInfSection registrará información de diagnóstico en el registro de texto de instalación de la aplicación setupAPI de . Este archivo de registro suele desactivarse de forma predeterminada. Se puede habilitar modificando los niveles de registro generales de parte del valor de setupAPI LogLevel
tal y como se describe en Configuración de niveles de registro de API. Por motivos de rendimiento, solo debe habilitar este archivo de registro al solucionar un problema. Cuando el archivo de registro está habilitado, puede encontrarlo en %windir%\inf\setupapi.app.log
.
Requisitos
Requisito | Valor |
---|---|
cliente mínimo admitido | Windows XP [solo aplicaciones de escritorio] |
servidor mínimo admitido | Windows Server 2003 [solo aplicaciones de escritorio] |
de la plataforma de destino de |
Windows |
encabezado de |
setupapi.h |
biblioteca de |
Setupapi.lib |
DLL de |
Setupapi.dll |
Consulte también
funciones de