Compartilhar via


Função SetupGetFileCompressionInfoA (setupapi.h)

[Essa função está disponível para uso nos sistemas operacionais indicados na seção Requisitos. Ele pode estar alterado ou indisponível em versões subsequentes. SetupAPI não deve mais ser usado para instalar aplicativos. Em vez disso, use o Windows Installer para desenvolver instaladores de aplicativos. SetupAPI continua a ser usado para instalar drivers de dispositivo.]

A função SetupGetFileCompressionInfo examina um arquivo físico para determinar se ele é compactado e obtém o caminho completo, o tamanho e o tamanho do arquivo de destino não compactado.

Observe que essa função é obsoleta e foi substituída por SetupGetFileCompressionInfoEx. Não use SetupGetFileCompressionInfo, em vez disso, use sempre SetupGetFileCompressionInfoEx.

Sintaxe

WINSETUPAPI DWORD SetupGetFileCompressionInfoA(
  [in]      PCSTR  SourceFileName,
  [in, out] PSTR   *ActualSourceFileName,
  [in, out] PDWORD SourceFileSize,
  [in, out] PDWORD TargetFileSize,
  [in, out] PUINT  CompressionType
);

Parâmetros

[in] SourceFileName

Nome do arquivo sobre quais informações são necessárias. Se o arquivo não for encontrado na mídia de origem exatamente como nomeado, o arquivo será pesquisado com até dois nomes alternativos de "formulário compactado". Por exemplo, se o arquivo for F:\x86\cmd.exe e não for encontrado, F:\mpis\cmd.ex_ será pesquisado e, se isso não for encontrado, uma pesquisa será feita para F:\x86\cmd.ex$. Você deve usar uma cadeia de caracteres terminada em nulo.

[in, out] ActualSourceFileName

Ponteiro para uma variável que recebe o caminho completo do arquivo que ele foi capaz de localizar. O chamador pode liberar o ponteiro com uma chamada para LocalFree. O caminho será válido somente se a função retornar NO_ERROR. Observe que, se a versão do SetupAPI.dll for menor que 5.0.2195, o chamador precisará usar a função exportada MyFree da SetupAPI para liberar a memória alocada por essa função, em vez de usar LocalFree. Consulte a seção Comentários.

[in, out] SourceFileSize

Ponteiro para uma variável na qual essa função retorna o tamanho do arquivo em sua forma atual, que é o tamanho atual do arquivo nomeado por ActualSourceFileName. O tamanho é determinado examinando o arquivo de origem; ele não é recuperado de um arquivo INF. O tamanho do arquivo de origem será válido somente se a função retornar NO_ERROR.

[in, out] TargetFileSize

Ponteiro para uma variável na qual essa função retorna o tamanho que o arquivo ocupará quando for descompactado ou copiado. Se o arquivo não for compactado, esse valor será o mesmo que SourceFileSize. O tamanho é determinado examinando o arquivo; ele não é recuperado de um arquivo INF. O tamanho do arquivo de destino será válido somente se a função retornar NO_ERROR.

[in, out] CompressionType

Ponteiro para uma variável na qual essa função retorna um valor que indica o tipo de compactação usada em ActualSourceFileName. O tipo de compactação só será válido se a função retornar NO_ERROR. O valor pode ser um dos sinalizadores a seguir.

FILE_COMPRESSION_NONE

O arquivo de origem não é compactado com um algoritmo de compactação reconhecido.

FILE_COMPRESSION_WINLZA

O arquivo de origem é compactado com compactação LZ.

FILE_COMPRESSION_MSZIP

O arquivo de origem é compactado com compactação MSZIP.

Valor de retorno

A função retorna um de código de erro do sistema que indica o resultado da pesquisa de arquivos. O código de erro pode ser um dos seguintes valores.

Para obter informações de erro estendidas, chame GetLastError.

Observações

Não use SetupGetFileCompressionInfo, em vez disso, use sempre SetupGetFileCompressionInfoEx.

Como SetupGetFileCompressionInfo determina a compactação fazendo referência ao arquivo físico, seu aplicativo de instalação deve garantir que o arquivo esteja presente antes de chamar SetupGetFileCompressionInfo.

Observe que, se a versão do SetupAPI.dll for menor que 5.0.2195, o chamador precisará usar a função exportada MyFree da SetupAPI para liberar a memória alocada por essa função, em vez de usar LocalFree. Se a chamada para LocalFree causar uma Violação de Acesso, você deverá resolver o problema usando MyFree.

Veja a seguir um exemplo de como obter a função MyFree do SetupAPI.dll:

typedef VOID (WINAPI* MYFREEFUNC)(LPVOID lpBuff);
   MYFREEFUNC MyFree;

   HMODULE hDll=NULL;
   hDll = GetModuleHandle("SETUPAPI.DLL");
   MyFree = (MYFREEFUNC)GetProcAddress(hDll, "MyFree");
   ...
   other code here to prepare file queue
   ...
   PTSTR lpActualSourceFileName;
   SetupGetFileCompressionInfo(...,&lpActualSourceFileName,...,...,...);
   ...
   MyFree(lpActualSourceFileName); 

Nota

O cabeçalho setupapi.h define SetupGetFileCompressionInfo 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 XP [somente aplicativos da área de trabalho]
servidor com suporte mínimo Windows Server 2003 [somente aplicativos da área de trabalho]
da Plataforma de Destino Windows
cabeçalho setupapi.h
biblioteca Setupapi.lib
de DLL Setupapi.dll

Consulte também

Funções

Visão geral

setupDecompressOrCopyFile