Método IVsProject3.GetItemContext (UInt32, IServiceProvider)
Publicado: abril de 2016
Retorna o contexto de um item.
Namespace: Microsoft.VisualStudio.Shell.Interop
Assembly: Microsoft.VisualStudio.Shell.Interop (em Microsoft.VisualStudio.Shell.Interop.dll)
Sintaxe
int GetItemContext(
uint itemid,
out IServiceProvider ppSP
)
int GetItemContext(
unsigned int itemid,
[OutAttribute] IServiceProvider^% ppSP
)
abstract GetItemContext :
itemid:uint32 *
ppSP:IServiceProvider byref -> int
Function GetItemContext (
itemid As UInteger,
<OutAttribute> ByRef ppSP As IServiceProvider
) As Integer
Parâmetros
- itemid
[in] Identificador do item de contexto, cujo valor é obtido a partir do VSITEMIDDWORD.
- ppSP
[out] Ponteiro para o IServiceProvider interface.
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.
Implementações
IVsProject2.GetItemContext(UInt32, IServiceProvider)
Comentários
COM assinatura
De vsshell.idl:
HRESULT IVsProject3::GetItemContext(
[in] VSITEMID itemid,
[out] IServiceProvider **ppSP
);
Este método permite um projeto fornecer serviços de contexto do projeto para um editor de documento.Se o projeto não precisa fornecer os serviços especiais para seus itens, então ele deverá retornar null.Sob nenhuma circunstância deve retornar o IServiceProvider ponteiro que foi passado para o pacote do ambiente por meio de SetSite.Os serviços globais automaticamente estará disponíveis para editores.
O exemplo a seguir fornece mais detalhes sobre os serviços de contexto do projeto fornecidos pelo GetItemContext método.
Exemplos
//---------------------------------------------------------------------
// interface: IServiceProvider
//---------------------------------------------------------------------
STDMETHODIMP CLangFileNode::QueryService(REFIID guidService, REFIID riid, void** ppv)
{
if (ppv == NULL)
return E_INVALIDARG;
*ppv = NULL;
HRESULT hr = E_NOINTERFACE;
if (IsEqualIID(guidService, SID_SVSMDCodeDomProvider))
{
CComPtr<IVSMDCodeDomCreator> srpCodeDomCreator;
hr = _VxModule.QueryService(SID_SVSMDDesignerService, IID_IVSMDCodeDomCreator, (LPVOID*) &srpCodeDomCreator);
if (SUCCEEDED(hr))
{
CComPtr<IVSMDCodeDomProvider> srpCodeDomProvider;
hr = srpCodeDomCreator->CreateCodeDomProvider(GetCVsHierarchy()->GetIVsHierarchy(),GetVsItemID(),&srpCodeDomProvider);
if (SUCCEEDED(hr))
hr = srpCodeDomProvider->QueryInterface(riid, ppv);
}
}
else if (IsEqualIID(guidService, VxDTE::SID_SVSProjectItem))
{
CComPtr<VxDTE::ProjectItem> srpProjectItem;
hr = GetDTEItem(&srpProjectItem);
if (SUCCEEDED(hr))
hr = srpProjectItem->QueryInterface(riid, ppv);
}
else if (IsEqualIID(guidService, SID_SVSWebReferenceDynamicProperties))
{
// We only support this service if our parent folder is a web reference folder
CLangFolderNode* pFolder = GetFolderParent();
if(pFolder && pFolder->IsWebReferenceFolder())
{
CComPtr<IVSWebReferenceDynamicProperties> srpWebRef;
hr = pFolder->GetIVsWebRefDynamicProperties(&srpWebRef);
if(SUCCEEDED(hr))
hr = srpWebRef->QueryInterface(riid, ppv);
}
}
else if (IsEqualIID(guidService, IID_IVsHierarchy))
{
// Access to our hierarchy.
hr = GetProject()->GetHierarchy()->QueryInterface(riid, ppv);
}
return hr;
}
Consulte também
Interface IVsProject3
Namespace Microsoft.VisualStudio.Shell.Interop
Retornar ao topo