Compartilhar via


Função MsiDetermineApplicablePatchesW (msi.h)

A função MsiDetermineApplicablePatches usa um conjunto de arquivos de patch, arquivos XML e blobs XML e determina quais patches se aplicam a um pacote especificado do Windows Installer e em qual sequência. A função pode considerar patches substituídos ou obsoletos. Essa função não contabiliza produtos ou patches instalados no sistema que não são especificados no conjunto.

Sintaxe

UINT MsiDetermineApplicablePatchesW(
  [in] LPCWSTR                szProductPackagePath,
  [in] DWORD                  cPatchInfo,
  [in] PMSIPATCHSEQUENCEINFOW pPatchInfo
);

Parâmetros

[in] szProductPackagePath

Caminho completo para um arquivo .msi. A função determina os patches aplicáveis a esse pacote e em qual sequência.

[in] cPatchInfo

Número de patches na matriz. Deve ser maior que zero.

[in] pPatchInfo

Ponteiro para uma matriz de estruturas de MSIPATCHSEQUENCEINFO .

Valor de retorno

A função MsiDetermineApplicablePatches retorna os valores a seguir.

Valor Significado
ERROR_FUNCTION_FAILED
A função falhou de uma maneira não abordada nos outros códigos de erro.
ERROR_INVALID_PARAMETER
Um argumento é inválido.
ERROR_PATCH_NO_SEQUENCE
Nenhuma sequência válida foi encontrada para o conjunto de patches.
ERROR_SUCCESS
Os patches foram classificados com êxito.
ERROR_FILE_NOT_FOUND
O arquivo .msi não foi encontrado.
ERROR_PATH_NOT_FOUND
O caminho para o arquivo .msi não foi encontrado.
ERROR_INVALID_PATCH_XML
Os dados do patch XML são inválidos.
ERROR_INSTALL_PACKAGE_OPEN_FAILED
Não é possível abrir um pacote de instalação referenciado por caminho.
ERROR_CALL_NOT_IMPLEMENTED
Esse erro poderá ser retornado se a função tiver sido chamada de uma ação personalizada ou se o MSXML 3.0 não estiver instalado.

Observações

Se essa função for chamada de uma ação personalizada, ela falhará e retornará ERROR_CALL_NOT_IMPLEMENTED. A função requer MSXML versão 3.0 para processar XML e retorna ERROR_CALL_NOT_IMPLEMENTED se o MSXML 3.0 não estiver instalado.

A função MsiDetermineApplicablePatches define a estrutura de uStatus e dwOrder de cada estrutura MSIPATCHSEQUENCEINFO apontada por pPatchInfo. Cada estrutura contém informações sobre um patch específico.

Se a função for bem-sucedida, a estrutura MSIPATCHSEQUENCEINFO de cada patch que pode ser aplicado ao produto retorna com um uStatus de ERROR_SUCCESS e um dwOrder maior ou igual a zero. Os valores de dwOrder maior ou igual a zero indicam a melhor sequência de aplicativos para os patches começando com zero.

Se a função for bem-sucedida, os patches excluídos da melhor sequência de aplicação de patch retornarão uma estrutura MSIPATCHSEQUENCEINFO com um dwOrder igual a -1. Nesses casos, um campo uStatus de ERROR_SUCCESS indica um patch obsoleto ou substituído para o produto. Um campo uStatus de ERROR_PATCH_TARGET_NOT_FOUND indica um patch inaplicável ao produto.

Se a função falhar, a estrutura MSIPATCHSEQUENCEINFO para cada patch retornará um dwOrder igual a -1. Nesse caso, os campos uStatus podem conter erros com mais informações sobre patches individuais. Por exemplo, ERROR_PATCH_NO_SEQUENCE é retornado para patches que têm informações de sequenciamento circular.

Nota

O cabeçalho msi.h define MsiDetermineApplicablePatches como um alias que seleciona automaticamente a versão ANSI ou Unicode dessa função com base na definição da constante do pré-processador UNICODE. A combinação do uso do alias neutro de codificação com código que não é neutro em codificação pode levar a incompatibilidades que resultam em erros de compilação ou de runtime. Para obter mais informações, consulte Conventions for Function Prototypes.

Requisitos

Requisito Valor
de cliente com suporte mínimo Windows Installer 5.0 no Windows Server 2012, Windows 8, Windows Server 2008 R2 ou Windows 7. Windows Installer 4.0 ou Windows Installer 4.5 no Windows Server 2008 ou Windows Vista. Windows Installer 3.0 ou posterior no Windows Server 2003 ou Windows XP. Consulte os Requisitos de Run-Time do Windows Installer para obter informações sobre o service pack mínimo do Windows exigido por uma versão do Windows Installer.
da Plataforma de Destino Windows
cabeçalho msi.h
biblioteca Msi.lib
de DLL Msi.dll

Consulte também

MsiDeterminePatchSequence

sem suporte no Windows Installer 2.0 e anteriores

ProductCode