Compartir a través de


Función MsiGetComponentPathExW (msi.h)

La función MsiGetComponentPathEx devuelve la ruta de acceso completa a un componente instalado. Si la ruta de acceso de la clave del componente es una clave del Registro, la función devuelve la clave del Registro.

Esta función amplía la función MsiGetComponentPath existente para habilitar las búsquedas de componentes en cuentas de usuario y contextos de instalación.

Sintaxis

INSTALLSTATE MsiGetComponentPathExW(
  [in]                LPCWSTR           szProductCode,
  [in]                LPCWSTR           szComponentCode,
  [in, optional]      LPCWSTR           szUserSid,
  [in, optional]      MSIINSTALLCONTEXT dwContext,
  [out, optional]     LPWSTR            lpOutPathBuffer,
  [in, out, optional] LPDWORD           pcchOutPathBuffer
);

Parámetros

[in] szProductCode

Valor de cadena terminada en NULL que especifica el GUID de código de producto de una aplicación. La función obtiene la ruta de acceso de los componentes instalados usados por esta aplicación.

[in] szComponentCode

Valor de cadena terminada en NULL que especifica un GUID de código de componente. La función obtiene la ruta de acceso de un componente instalado que tiene este código de componente.

[in, optional] szUserSid

Valor de cadena terminada en NULL que especifica el identificador de seguridad (SID) para un usuario del sistema. La función obtiene las rutas de acceso de los componentes instalados de las aplicaciones instaladas en las cuentas de usuario identificadas por este SID. La cadena de SID especial s-1-1-0 (Todos) especifica todos los usuarios del sistema. Si este parámetro es NULL, la función obtiene la ruta de acceso de un componente instalado solo para el usuario que ha iniciado sesión actualmente.

Tipo de SID Significado
NULL
Especifica el usuario que ha iniciado sesión actualmente.
siD de usuario de
Especifica un usuario determinado en el sistema. Un ejemplo de SID de usuario es "S-1-3-64-2415071341-1358098788-3127455600-2561".
s-1-1-0
Especifica todos los usuarios del sistema.
 
Nota La cadena de SID especial s-1-5-18 (Sistema) no se puede usar para buscar aplicaciones instaladas en el contexto de instalación por máquina. Si se establece el valor de SID en s-1-5-18, se devuelve ERROR_INVALID_PARAMETER. Cuando dwContext solo se establece en MSIINSTALLCONTEXT_MACHINE, szUserSid debe ser NULL.
 

[in, optional] dwContext

Marca que especifica el contexto de instalación. La función obtiene las rutas de acceso de los componentes instalados de las aplicaciones instaladas en el contexto de instalación especificado. Este parámetro puede ser una combinación de los siguientes valores.

Contexto Significado
MSIINSTALLCONTEXT_USERMANAGED
1
Incluya las aplicaciones instaladas en el contexto de instalación administrado por usuario.
MSIINSTALLCONTEXT_USERUNMANAGED
2
Incluya las aplicaciones instaladas en el contexto de instalación por usuario y no administrado.
MSIINSTALLCONTEXT_MACHINE
4
Incluya las aplicaciones instaladas en el contexto de instalación por máquina. Cuando dwInstallContext solo se establece en MSIINSTALLCONTEXT_MACHINE, el parámetro szUserSID debe ser NULL.

[out, optional] lpOutPathBuffer

Valor de cadena que recibe la ruta de acceso al componente. Este parámetro puede ser null. Si el componente es una clave del Registro, las raíces del Registro se representan numéricamente. Si se trata de una ruta de acceso de subclave del Registro, hay una barra diagonal inversa al final de la ruta de acceso de la clave. Si se trata de una ruta de acceso de clave de valor del Registro, no hay ninguna barra diagonal inversa al final. Por ejemplo, una ruta de acceso del Registro en un sistema operativo de 32 bits de HKEY_CURRENT_USER\SOFTWARE\Microsoft se devuelve como "01:\SOFTWARE\Microsoft". Las raíces del Registro devueltas en sistemas operativos de 32 bits se definen como se muestra en la tabla siguiente.

Nota En sistemas operativos de 64 bits, se agrega un valor de 20 a las raíces numéricas del registro de esta tabla para distinguirlas de las rutas de acceso de clave del Registro en sistemas operativos de 32 bits. Por ejemplo, una ruta de acceso de clave del Registro de HKEY_CURRENT_USER\SOFTWARE\Microsoft se devuelve como "21:\SOFTWARE\Microsoft\", si la ruta de acceso del componente es una clave del Registro en un sistema operativo de 64 bits.
 
Raíz Significado
HKEY_CLASSES_ROOT
00
HKEY_CURRENT_USER
01
HKEY_LOCAL_MACHINE
02
HKEY_USERS
03

[in, out, optional] pcchOutPathBuffer

Puntero a una ubicación que recibe el tamaño del búfer, en TCHAR, al que apunta el parámetro szPathBuf. El valor de esta ubicación debe establecerse en el recuento de TCHAR de la cadena, incluido el carácter nulo de terminación. Si el tamaño del búfer es demasiado pequeño, este parámetro recibe la longitud del valor de cadena sin incluir el carácter nulo de terminación en el recuento.

Valor devuelto

La función msiGetComponentPathEx devuelve los valores siguientes.

Valor Significado
INSTALLSTATE_NOTUSED
El componente que se solicita está deshabilitado en el equipo.
INSTALLSTATE_BADCONFIG
Los datos de configuración están dañados.
INSTALLSTATE_ABSENT
El componente no está instalado.
INSTALLSTATE_INVALIDARG
Uno de los parámetros de función no es válido.
INSTALLSTATE_LOCAL
El componente se instala localmente.
INSTALLSTATE_SOURCE
El componente se instala para ejecutar desde el origen.
INSTALLSTATE_SOURCEABSENT
No se puede acceder al origen del componente.
INSTALLSTATE_UNKNOWN
Se desconoce el código del producto o el identificador del componente.
INSTALLSTATE_BROKEN
El componente está dañado o parcialmente falta de alguna manera y requiere reparación.

Observaciones

La función MsiGetComponentPathEx puede devolver INSTALLSTATE_ABSENT o INSTALL_STATE_UNKNOWN, por los siguientes motivos:

  • INSTALLSTATE_ABSENT

    La aplicación no se ha asegurado correctamente de que la característica se instaló llamando a MsiUseFeature y, si es necesario, MsiConfigureFeature.

  • INSTALLSTATE_UNKNOWN

    La característica no está publicada. La aplicación debe haber determinado esto anteriormente llamando a MsiQueryFeatureState o MsiEnumFeatures. La aplicación realiza estas llamadas mientras se inicializa. Una aplicación solo debe usar características que se conocen como publicadas. Dado que INSTALLSTATE_UNKNOWN debe haber sido devuelto por MsiUseFeature también, no se llamó a MsiUseFeature o su valor devuelto no se ha comprobado correctamente.

Nota

El encabezado msi.h define MsiGetComponentPathEx 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.

Requisitos

Requisito Valor
cliente mínimo admitido Windows Installer 5.0 en Windows Server 2012, Windows 8, Windows Server 2008 R2 o Windows 7. Consulte Windows Installer Run-Time Requirements (Requisitos de Windows Installer) para obtener información sobre el Service Pack mínimo de Windows que requiere una versión de Windows Installer.
de la plataforma de destino de Windows
encabezado de msi.h
biblioteca de Msi.lib
DLL de Msi.dll

Consulte también

Component-Specific Functions