Compartir a través de


CodeEvent.InfoLocation (Propiedad)

Obtiene las funciones del modelo de código.

Espacio de nombres:  EnvDTE80
Ensamblado:  EnvDTE80 (en EnvDTE80.dll)

Sintaxis

'Declaración
ReadOnly Property InfoLocation As vsCMInfoLocation
    Get
vsCMInfoLocation InfoLocation { get; }
property vsCMInfoLocation InfoLocation {
    vsCMInfoLocation get ();
}
abstract InfoLocation : vsCMInfoLocation
function get InfoLocation () : vsCMInfoLocation

Valor de propiedad

Tipo: EnvDTE.vsCMInfoLocation
Uno de los valores de vsCMInfoLocation.

Comentarios

Si InfoLocation devuelve vsCMInfoLocationProject, podrá establecer propiedades, obtener un StartPoint y un EndPoint, etc. Cuando se desplace desde un objeto de modelo de código (A) hasta otro (B) (como por ejemplo, de una función a su tipo o de una clase a su clase base), B puede ser de tipo vsCMInfoLocationExternal si su definición está en otro proyecto. La disposición dependerá de la implementación del modelo de código, de si el proyecto del objeto B se implementa en el mismo lenguaje que el del objeto A, etc.

Si InfoLocation devuelve vsCMInfoLocationExternal, la información sólo estará disponible en metadatos, al inspeccionar una DLL o en orígenes congelados. Puede que consiga obtener StartPoint y EditPoint, pero no podrá editar el documento; es decir, no podrá establecer propiedades ni modificar el texto subyacente al elemento de código.

Si InfoLocation devuelve vsCMInfoLocationNone, sólo se puede disponer de un objeto de modelo de código que tenga nombre. Además, en función del contexto del código fuente, en algunos casos podrá establecer si el nombre debe ser una clase o una interfaz. Sin embargo, en esta situación, dado que el modelo de código no puede comparar el nombre con ninguna información útil, el objeto no será válido.

Nota

Los valores de los elementos de modelo de código como clases, structs, funciones, atributos, delegados, etc., pueden ser no deterministas una vez realizados determinados tipos de modificaciones; esto significa que no se puede confiar en que sus valores se mantengan siempre igual. Para obtener más información, vea la sección Los valores de elementos de modelo de código pueden cambiar, en Detectar código utilizando el modelo de código (Visual Basic).

Ejemplos

En el siguiente ejemplo se muestra cómo se utiliza la propiedad InfoLocation.

Para probar esta propiedad:

  1. Abra el proyecto de destino y seleccione el elemento de evento de código situando el cursor en el objeto de evento pertinente.

  2. Ejecute el complemento.

public static void InfoLocation(EnvDTE80.DTE2 dte)
{
    TextSelection objTextSel;
    EnvDTE80.CodeEvent codeEvent;
    objTextSel = (TextSelection)dte.ActiveDocument.Selection;
    codeEvent = (EnvDTE80.CodeEvent)objTextSel.ActivePoint.get_CodeElement(vsCMElement.vsCMElementEvent);

    MessageBox.Show("\nInfoLocation property: " +
                    codeEvent.InfoLocation, "Testing CodeEvent");
}

Seguridad de .NET Framework

Vea también

Referencia

CodeEvent Interfaz

EnvDTE80 (Espacio de nombres)

Otros recursos

Cómo: Compilar y ejecutar los ejemplos de código del modelo de objetos de automatización

Detectar código utilizando el modelo de código (Visual Basic)

Detectar código utilizando el modelo de código (Visual C#)