Função SHSetFolderPathW (shlobj_core.h)
Deprecado. Atribui um novo caminho a uma pasta do sistema identificada pelo CSIDL.
Sintaxe
HRESULT SHSetFolderPathW(
[in] int csidl,
[in] HANDLE hToken,
[in] DWORD dwFlags,
[in] LPCWSTR pszPath
);
Parâmetros
[in] csidl
Tipo: int
Um valor CSIDL que identifica a pasta cujo caminho deve ser definido. Somente pastas físicas são válidas. Se uma pasta virtual for especificada, essa função falhará.
Adicione o valor CSIDL_FLAG_DONT_UNEXPAND ao CSIDL para garantir que a cadeia de caracteres seja gravada no registro exatamente como fornecido. Se o sinalizador CSIDL_FLAG_DONT_UNEXPAND não estiver incluído, partes do caminho poderão ser substituídas por cadeias de caracteres de ambiente, como %USERPROFILE%.
[in] hToken
Tipo: HANDLE
Um token de acesso que pode ser usado para representar um usuário específico. Esse parâmetro geralmente é definido como NULL, nesse caso, a função tenta acessar a instância do usuário atual da pasta. No entanto, talvez seja necessário atribuir um valor a hToken para as pastas que podem ter vários usuários, mas que são tratadas como pertencentes a um único usuário. A pasta mais usada desse tipo é Documentos.
O aplicativo de chamada é responsável pela representação correta quando hToken não é nulo. Ele deve ter privilégios de segurança apropriados para o usuário específico, incluindo TOKEN_QUERY e TOKEN_IMPERSONATE, e o hive do registro do usuário deve estar montado no momento. Consulte de Controle de Acesso para obter mais discussões sobre problemas de controle de acesso.
[in] dwFlags
Tipo: DWORD
Reservado. Deve ser definido como 0.
[in] pszPath
Tipo: LPCTSTR
Um ponteiro para uma cadeia de caracteres de comprimento terminada em nulo MAX_PATH que contém o novo caminho da pasta. Esse valor não pode ser NULL e a cadeia de caracteres não pode ter tamanho zero.
Valor de retorno
Tipo: HRESULT
Retorna códigos de
Código de retorno | Descrição |
---|---|
|
O caminho da pasta foi atualizado com êxito. |
|
Várias condições de erro causam o retorno desse valor, incluindo o seguinte:
|
Observações
É recomendável que os caminhos sejam expressos como cadeias de caracteres Unicode porque os nomes de pasta podem conter caracteres Unicode não expressíveis no ANSI.
Nota
O cabeçalho shlobj_core.h define SHSetFolderPath como um alias que seleciona automaticamente a versão ANSI ou Unicode dessa função com base na definição da constante de 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 | shlobj_core.h (inclua Shlobj.h, Shlobj_core.h) |
biblioteca | Shell32.lib |
de DLL |
Shell32.dll (versão 5.0 ou posterior) |