OperationContractGenerationContext Clase

Definición

Se pasa al GenerateOperation(OperationContractGenerationContext) método para habilitar la modificación de un contrato de operación y su contexto antes de generar código.

public ref class OperationContractGenerationContext
public class OperationContractGenerationContext
type OperationContractGenerationContext = class
Public Class OperationContractGenerationContext
Herencia
OperationContractGenerationContext

Ejemplos

En el OperationContractGenerationContext ejemplo siguiente se muestra el uso del objeto pasado al IOperationContractGenerationExtension.GenerateOperation método para agregar comentarios de código extraídos de elementos WSDL personalizados.

public void GenerateOperation(OperationContractGenerationContext context)
{
  context.SyncMethod.Comments.AddRange(Formatter.FormatComments(commentText));
  Console.WriteLine("In generate operation.");
}

En el ejemplo de código siguiente se muestran los comentarios de código resultantes.

/// From WSDL Documentation:
///
/// <summary>This contract is a stateless contract that provides a mechanism for
/// computing the nth Fibonacci term.</summary>
///
[System.CodeDom.Compiler.GeneratedCodeAttribute("System.ServiceModel", "3.0.0.0")]
[System.ServiceModel.ServiceContractAttribute(Namespace="http://microsoft.wcf.documentation", ConfigurationName="IFibonacci")]
public interface IFibonacci
{

    /// From WSDL Documentation:
    ///
    /// <summary>The Compute operation returns the nth Fibonacci number.  Because it
    /// uses dual recursion it's very inefficient and therefore useful to demonstrate
    /// caching.</summary><returns>The nth Fibonacci number.</returns><param
    /// name="num">The value to use when computing the Fibonacci number.</param>
    ///
    [System.ServiceModel.OperationContractAttribute(Action="http://microsoft.wcf.documentation/IFibonacci/Compute", ReplyAction="http://microsoft.wcf.documentation/IFibonacci/ComputeResponse")]
    int Compute(int num);

    /// From WSDL Documentation:
    ///
    /// <summary>The GetPerson operation tests custom WSDL documentation
    /// generation.</summary><returns>The Person object to be returned.</returns><param
    /// name="FirstParameter">The value for the first parameter.</param><param
    /// name="SecondParameter">The value for the second parameter.</param>
    ///
    [System.ServiceModel.OperationContractAttribute(Action="http://microsoft.wcf.documentation/IFibonacci/GetPerson", ReplyAction="http://microsoft.wcf.documentation/IFibonacci/GetPersonResponse")]
    Microsoft.WCF.Documentation.Person GetPerson(int FirstParameter, int SecondParameter);
}

'''From WSDL Documentation:
'''
'''<summary>This contract is a stateless contract that provides a mechanism for 
'''computing the nth Fibonacci term.</summary> 
'''
<System.CodeDom.Compiler.GeneratedCodeAttribute("System.ServiceModel", "3.0.0.0"),  _
 System.ServiceModel.ServiceContractAttribute([Namespace]:="http://microsoft.wcf.documentation", ConfigurationName:="IFibonacci")>  _
Public Interface IFibonacci
    
    '''From WSDL Documentation:
    '''
    '''<summary>The Compute operation returns the nth Fibonacci number.  Because it 
    '''uses dual recursion it's very inefficient and therefore useful to demonstrate 
    '''caching.</summary><returns>The nth Fibonacci number.</returns><param 
    '''name="num">The value to use when computing the Fibonacci number.</param> 
    '''
    <System.ServiceModel.OperationContractAttribute(Action:="http://microsoft.wcf.documentation/IFibonacci/Compute", ReplyAction:="http://microsoft.wcf.documentation/IFibonacci/ComputeResponse")>  _
    Function Compute(ByVal num As Integer) As Integer
    
    '''From WSDL Documentation:
    '''
    '''<summary>The GetPerson operation tests custom WSDL documentation 
    '''generation.</summary><returns>The Person object to be returned.</returns><param 
    '''name="FirstParameter">The value for the first parameter.</param><param 
    '''name="SecondParameter">The value for the second parameter.</param> 
    '''
    <System.ServiceModel.OperationContractAttribute(Action:="http://microsoft.wcf.documentation/IFibonacci/GetPerson", ReplyAction:="http://microsoft.wcf.documentation/IFibonacci/GetPersonResponse")>  _
    Function GetPerson(ByVal FirstParameter As Integer, ByVal SecondParameter As Integer) As Microsoft.WCF.Documentation.Person
End Interface

Comentarios

Use el OperationContractGenerationContext objeto pasado al IOperationContractGenerationExtension.GenerateOperation método para modificar el modelo de objetos de documento de código antes de la generación de código. Normalmente, la System.ServiceModel.Description.IOperationContractGenerationExtension interfaz se implementa en una implementación personalizada System.ServiceModel.Description.IWsdlImportExtension que se usa para importar elementos WSDL personalizados o modificar el código en el nivel de servicio o operación. Para modificar el código en el nivel de servicio, consulte System.ServiceModel.Description.IServiceContractGenerationExtension.

Constructores

Nombre Description
OperationContractGenerationContext(ServiceContractGenerator, ServiceContractGenerationContext, OperationDescription, CodeTypeDeclaration, CodeMemberMethod, CodeMemberMethod, CodeMemberMethod, CodeMemberMethod)

Inicializa una nueva instancia de la OperationContractGenerationContext clase utilizando el generador de contratos, el contexto del contrato, la descripción de la operación, la declaración de tipo de código, el método de sincronización, el método begin, el método end y el método task.

OperationContractGenerationContext(ServiceContractGenerator, ServiceContractGenerationContext, OperationDescription, CodeTypeDeclaration, CodeMemberMethod, CodeMemberMethod, CodeMemberMethod)

Inicializa una nueva instancia de la clase OperationContractGenerationContext.

OperationContractGenerationContext(ServiceContractGenerator, ServiceContractGenerationContext, OperationDescription, CodeTypeDeclaration, CodeMemberMethod, CodeMemberMethod)

Inicializa una nueva instancia de la OperationContractGenerationContext clase utilizando el generador de contratos, el contexto del contrato, la descripción de la operación, la declaración de tipo de código y el método especificados.

OperationContractGenerationContext(ServiceContractGenerator, ServiceContractGenerationContext, OperationDescription, CodeTypeDeclaration, CodeMemberMethod)

Inicializa una nueva instancia de la OperationContractGenerationContext clase mediante el generador de contratos, el contexto de contrato, la descripción de la operación, la declaración de tipo de código, el método de sincronización y el método de tarea especificados.

Propiedades

Nombre Description
BeginMethod

Obtiene para CodeMemberMethod la operación de inicio asincrónica.

Contract

Obtiene el contexto de generación de código para el contrato de servicio.

DeclaringType

Obtiene el tipo de declaración de la operación actual.

EndMethod

Obtiene la declaración de operación de finalización asincrónica.

IsAsync

Obtiene un valor que indica si se generan métodos asincrónicos para la operación actual.

IsTask

Obtiene un valor que indica si se genera una tarea para la operación actual.

Operation

Obtiene para OperationDescription la operación actual.

ServiceContractGenerator

Obtiene el ServiceContractGenerator objeto que genera la operación actual.

SyncMethod

Obtiene para CodeMemberMethod la operación sincrónica.

TaskMethod

Obtiene para CodeMemberMethod la operación de tarea.

Métodos

Nombre Description
Equals(Object)

Determina si el objeto especificado es igual al objeto actual.

(Heredado de Object)
GetHashCode()

Actúa como función hash predeterminada.

(Heredado de Object)
GetType()

Obtiene el Type de la instancia actual.

(Heredado de Object)
MemberwiseClone()

Crea una copia superficial del Objectactual.

(Heredado de Object)
ToString()

Devuelve una cadena que representa el objeto actual.

(Heredado de Object)

Se aplica a