Método IVsSolution.GetProjectOfProjref (String, IVsHierarchy, String, VSUPDATEPROJREFREASON )
Publicado: abril de 2016
Retorna uma hierarquia para a seqüência de referência do projeto especificado.
Namespace: Microsoft.VisualStudio.Shell.Interop
Assembly: Microsoft.VisualStudio.Shell.Interop (em Microsoft.VisualStudio.Shell.Interop.dll)
Sintaxe
int GetProjectOfProjref(
string pszProjref,
out IVsHierarchy ppHierarchy,
out string pbstrUpdatedProjref,
VSUPDATEPROJREFREASON[] puprUpdateReason
)
int GetProjectOfProjref(
String^ pszProjref,
[OutAttribute] IVsHierarchy^% ppHierarchy,
[OutAttribute] String^% pbstrUpdatedProjref,
array<VSUPDATEPROJREFREASON>^ puprUpdateReason
)
abstract GetProjectOfProjref :
pszProjref:string *
ppHierarchy:IVsHierarchy byref *
pbstrUpdatedProjref:string byref *
puprUpdateReason:VSUPDATEPROJREFREASON[] -> int
Function GetProjectOfProjref (
pszProjref As String,
<OutAttribute> ByRef ppHierarchy As IVsHierarchy,
<OutAttribute> ByRef pbstrUpdatedProjref As String,
puprUpdateReason As VSUPDATEPROJREFREASON()
) As Integer
Parâmetros
- pszProjref
[in] Ponteiro para a existente seqüência de referência de projeto, se aplicável.Can be null.
- ppHierarchy
[out] Ponteiro para o IVsHierarchy interface é nomeada de acordo com a referência do projeto.
- pbstrUpdatedProjref
[out] Ponteiro para a seqüência de referência de projeto atualizado.
- puprUpdateReason
[out] Identificado descrevendo o motivo da alteração na seqüência de referência de projeto.Para obter uma lista de puprUpdateReason valores, consulte VSUPDATEPROJREFREASON.
Valor de retorno
Type: System.Int32
Se o método for bem-sucedido, ele retorna S_OK.Se ele falhar, ele retorna um código de erro.
Comentários
COM assinatura
De vsshell.idl:
HRESULT IVsSolution::GetProjectOfProjref(
[in] LPCOLESTR pszProjref,
[out] IVsHierarchy **ppHierarchy,
[out] BSTR *pbstrUpdatedProjref,
[out] VSUPDATEPROJREFREASON *puprUpdateReason
);
Há dois cenários para este método:
A referência de projeto controla quando o projeto é renomeado dentro de uma única solução.Ao tentar vincular uma referência de projeto, o GUID do projeto é tentado em primeiro lugar, chamando GetProjectOfGuid.Se essa chamada tiver êxito e o projeto foi renomeado, a referência de projeto atualizado também é fornecida para o cliente.
Projetos são adicionados a uma nova solução e a referência de projeto é ainda é possível ligar.Se o GUID não ligar, é feita uma tentativa para localizar o projeto usando as informações de nome do tipo.Se isso tiver êxito, uma referência ao projeto atualizado que inclui o novo projeto é retornada.
O conteúdo de referência de projeto é opaco para o cliente.No entanto, para oferecer suporte a esses dois cenários para nossa implementação interna, precisamos ter uma seqüência de referência do projeto é composta das seguintes informações:
GUID atribuído e mantido pelo arquivo de solução do projeto
Tipo (ou nome) do projeto
A seguir está uma descrição de como o GetProjectOfProjref método é usado para dar suporte às operações de arrastar e soltar:
O CF_VSPROJECTITEMS e CF_VSPROJECTS uso de formatos de área de transferência de DROPFILES estrutura da mesma maneira que CF_HDROP ou CF_PRINTERS.Os dados que segue a DROPFILES estrutura é uma lista de terminação dupla-nula de Projref seqüências de caracteres.O consumidor da operação soltar pode usar a API do Windows DragQueryFile para examinar os dados a DROPFILES estrutura.CF_VSPROJECTSformato é oferecido quando o Projref seqüências identificam projetos como um todo, isto é, *pitemid = = VSITEMID_ROOT.O CF_VSPROJECTITEMS formato é oferecido quando o Projref seqüências identificam um ou mais itens de projeto individual.Um dos CF_VSPROJECTS ou CF_VSPROJECTITEMS deve ser oferecida, mas nunca os dois.
Consulte também
Interface IVsSolution
Namespace Microsoft.VisualStudio.Shell.Interop
Retornar ao topo