IVsSolution2.GetProjrefOfItem Method

Returns a project reference string for the specified hierarchy and hierarchy item pair.

Namespace:  Microsoft.VisualStudio.Shell.Interop
Assembly:  Microsoft.VisualStudio.Shell.Interop (in Microsoft.VisualStudio.Shell.Interop.dll)

Syntax

'Declaration
Function GetProjrefOfItem ( _
    pHierarchy As IVsHierarchy, _
    itemid As UInteger, _
    <OutAttribute> ByRef pbstrProjref As String _
) As Integer
int GetProjrefOfItem(
    IVsHierarchy pHierarchy,
    uint itemid,
    out string pbstrProjref
)
int GetProjrefOfItem(
    [InAttribute] IVsHierarchy^ pHierarchy, 
    [InAttribute] unsigned int itemid, 
    [OutAttribute] String^% pbstrProjref
)
abstract GetProjrefOfItem : 
        pHierarchy:IVsHierarchy * 
        itemid:uint32 * 
        pbstrProjref:string byref -> int 
function GetProjrefOfItem(
    pHierarchy : IVsHierarchy, 
    itemid : uint, 
    pbstrProjref : String
) : int

Parameters

  • itemid
    Type: System.UInt32
    [in] Valid item identifier within the project; not a VSITEMID value.
  • pbstrProjref
    Type: System.String%
    [out] Pointer to the project reference string.

Return Value

Type: System.Int32
If the method succeeds, it returns S_OK. If it fails, it returns an error code.

Implements

IVsSolution.GetProjrefOfItem(IVsHierarchy, UInt32, String%)

Remarks

COM Signature

From vsshell.idl:

HRESULT IVsSolution2::GetProjrefOfItem(
   [in] IVsHierarchy *pHierarchy, 
   [in] VSITEMID itemid, 
   [out] BSTR *pbstrProjref
);

The following is a description of how the GetProjrefOfItem method is used to support drag-and-drop operations:

The CF_VSPROJECTITEMS and CF_VSPROJECTS clipboard formats use the DROPFILES structure in the same manner as CF_HDROP or CF_PRINTERS. The data that follows the DROPFILES structure is a double-NULL-terminated list of Projref strings. The consumer of the drop operation can use the Windows API DragQueryFile to examine the data in the DROPFILES structure. CF_VSPROJECTS format is offered when the Projref strings identify projects as a whole, that is, *pitemid == VSITEMID_ROOT. The CF_VSPROJECTITEMS format is offered when the Projref strings identify one or more individual project items. Either CF_VSPROJECTS or CF_VSPROJECTITEMS should be offered, but never both.

.NET Framework Security

See Also

Reference

IVsSolution2 Interface

Microsoft.VisualStudio.Shell.Interop Namespace