Función MsiProvideComponentA (msi.h)
La función MsiProvideComponent devuelve la ruta de acceso completa del componente, realizando cualquier instalación necesaria. Esta función solicita el origen si es necesario e incrementa el recuento de uso de la característica.
Sintaxis
UINT MsiProvideComponentA(
[in] LPCSTR szProduct,
[in] LPCSTR szFeature,
[in] LPCSTR szComponent,
[in] DWORD dwInstallMode,
[out] LPSTR lpPathBuf,
[in, out] LPDWORD pcchPathBuf
);
Parámetros
[in] szProduct
Especifica el código de producto del producto que contiene la característica con el componente necesario.
[in] szFeature
Especifica el identificador de característica de la característica con el componente necesario.
[in] szComponent
Especifica el código de componente del componente necesario.
[in] dwInstallMode
Define el modo de instalación. Este parámetro puede ser uno de los valores siguientes.
Valor | Significado |
---|---|
|
Proporcione el componente y realice cualquier instalación necesaria para proporcionar el componente. Si falta el archivo de clave de un componente en la característica solicitada o un elemento primario de la característica, vuelva a instalar la característica mediante MsiReinstallFeature con los siguientes bits de marca establecidos: REINSTALLMODE_FILEMISSING, REINSTALLMODE_FILEOLDERVERSION, REINSTALLMODE_FILEVERIFY, REINSTALLMODE_MACHINEDATA, REINSTALLMODE_USERDATA y REINSTALLMODE_SHORTCUT. |
|
Proporcione el componente solo si existe la característica. De lo contrario, devuelve ERROR_FILE_NOT_FOUND.
Este modo comprueba que existe el archivo de clave del componente. |
|
Proporcione el componente solo si existe la característica. De lo contrario, devuelve ERROR_FILE_NOT_FOUND.
Este modo solo comprueba que el componente está registrado y no comprueba que el archivo de clave del componente exista. |
|
Llame a MsiReinstallFeature para volver a instalar la característica mediante este parámetro para el parámetro dwReinstallMode y, a continuación, proporcione el componente . |
|
Proporcione el componente solo si el estado de instalación de la característica es INSTALLSTATE_LOCAL. Si el estado de instalación de la característica está INSTALLSTATE_SOURCE, devuelva ERROR_INSTALL_SOURCE_ABSENT. De lo contrario, devuelve ERROR_FILE_NOT_FOUND. Este modo solo comprueba que el componente está registrado y no comprueba que el archivo de clave existe. |
[out] lpPathBuf
Puntero a una variable que recibe la ruta de acceso al componente. Este parámetro puede ser NULL.
[in, out] pcchPathBuf
Puntero a una variable que especifica el tamaño, en caracteres, del búfer al que apunta el parámetro lpPathBuf . En la entrada, este es el tamaño completo del búfer, incluido un espacio para un carácter nulo de terminación. Si el búfer pasado es demasiado pequeño, el recuento devuelto no incluye el carácter nulo de terminación.
Si lpPathBuf es null, pcchBuf puede ser null.
Valor devuelto
Valor | Significado |
---|---|
|
Los datos de configuración están dañados. |
|
La característica no está presente o está rota. este error se devuelve para dwInstallMode = INSTALLMODE_EXISTING. |
|
Error de instalación. |
|
El componente que se solicita está deshabilitado en el equipo. |
|
Se pasó un parámetro no válido a la función. |
|
Si se devuelve este valor, significa que la función se completó correctamente. |
|
El id. de característica no identifica una característica conocida. |
|
El código de producto no identifica un producto conocido. |
|
Se pasó un producto no reconocido o un nombre de característica a la función. |
|
Se devuelve el desbordamiento del búfer. |
|
No se puede detectar un origen. |
Para obtener más información, vea Mensajes de error mostrados.
Comentarios
Tras el éxito de la función MsiProvideComponent , el parámetro pcchPathBuf contiene la longitud de la cadena en lpPathBuf.
La función MsiProvideComponent combina la funcionalidad de MsiUseFeature, MsiConfigureFeature y MsiGetComponentPath. Puede usar la función MsiProvideComponent para simplificar la secuencia de llamada. Sin embargo, dado que esta función incrementa el recuento de uso, úsela con precaución para evitar recuentos de uso inexactos. La función MsiProvideComponent también proporciona menos flexibilidad que la serie de llamadas individuales.
Si la aplicación se está recuperando de una situación inesperada, es probable que la aplicación ya se haya llamado MsiUseFeature e incremente el recuento de uso. En este caso, la aplicación debe llamar a MsiConfigureFeature en lugar de MsiProvideComponent para evitar incrementar el recuento de nuevo.
La opción INSTALLMODE_EXISTING no se puede usar en combinación con la marca REINSTALLMODE.
Las características con componentes que contienen un archivo dañado o la versión incorrecta de un archivo deben volver a instalarse explícitamente por el usuario o si la aplicación llama a MsiReinstallFeature.
Nota
El encabezado msi.h define MsiProvideComponent 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 Convenciones para prototipos de función.
Requisitos
Requisito | Value |
---|---|
Cliente mínimo compatible | Windows Installer 5.0 en Windows Server 2012, Windows 8, Windows Server 2008 R2 o Windows 7. Windows Installer 4.0 o Windows Installer 4.5 en Windows Server 2008 o Windows Vista. Windows Installer en Windows Server 2003 o Windows XP. Consulte Windows Installer para obtener información sobre el Service Pack mínimo de Windows que requiere una versión de Windows Installer. |
Plataforma de destino | Windows |
Encabezado | msi.h |
Library | Msi.lib |
Archivo DLL | Msi.dll |