Compartilhar via


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.

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