Partager via


OperationContractGenerationContext Classe

Définition

Passé à la méthode GenerateOperation(OperationContractGenerationContext) pour activer la modification d'un contrat d'opération et de son contexte avant de générer du code.

public ref class OperationContractGenerationContext
public class OperationContractGenerationContext
type OperationContractGenerationContext = class
Public Class OperationContractGenerationContext
Héritage
OperationContractGenerationContext

Exemples

L'exemple suivant illustre l'objet OperationContractGenerationContext passé à la méthode IOperationContractGenerationExtension.GenerateOperation pour ajouter des commentaires de code extraits d'éléments WSDL personnalisés.

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

L'exemple de code suivant montre les commentaires de code obtenus.

/// 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

Remarques

Utilisez l'objet OperationContractGenerationContext passé à la méthode IOperationContractGenerationExtension.GenerateOperation pour modifier le modèle CodeDOM (Code Document Object Model) avant de générer du code. En général, l'interface System.ServiceModel.Description.IOperationContractGenerationExtension est implémentée sur une implémentation System.ServiceModel.Description.IWsdlImportExtension personnalisée qui permet d'importer des éléments WSDL personnalisés ou de modifier le code au niveau du service ou de l'opération. Pour modifier le code au niveau du service, consultez System.ServiceModel.Description.IServiceContractGenerationExtension.

Constructeurs

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

Initialise une nouvelle instance de la classe OperationContractGenerationContext à l'aide du générateur de contrat, du contexte de contrat, de la description d'opération, de la déclaration de type de code, de la méthode de synchronisation et de la méthode de tâche spécifiés.

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

Initialise une nouvelle instance de la classe OperationContractGenerationContext à l'aide du générateur de contrat, du contexte de contrat, de la description d'opération, de la déclaration de type de code et de la méthode spécifiés.

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

Initialise une nouvelle instance de la classe OperationContractGenerationContext.

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

Initialise une nouvelle instance de la classe OperationContractGenerationContext à l'aide du générateur de contrat, du contexte de contrat, de la description d'opération, de la déclaration de type de code, de la méthode de synchronisation, de la méthode Begin, de la méthode End et de la méthode de tâche spécifiés.

Propriétés

BeginMethod

Obtient la CodeMemberMethod pour l'opération Begin asynchrone.

Contract

Obtient le contexte de génération de code pour le contrat de service.

DeclaringType

Obtient le type déclarant pour l’opération actuelle.

EndMethod

Obtient la déclaration de l'opération de fin asynchrone.

IsAsync

Obtient une valeur qui indique si les méthodes asynchrones sont générées pour l'opération actuelle.

IsTask

Obtient une valeur qui indique si une tâche est générée pour l'opération actuelle.

Operation

Obtient OperationDescription pour l'opération actuelle.

ServiceContractGenerator

Obtient le ServiceContractGenerator qui génère l'opération actuelle.

SyncMethod

Obtient la CodeMemberMethod pour l'opération synchrone.

TaskMethod

Obtient la CodeMemberMethod pour l'opération de tâche.

Méthodes

Equals(Object)

Détermine si l'objet spécifié est égal à l'objet actuel.

(Hérité de Object)
GetHashCode()

Fait office de fonction de hachage par défaut.

(Hérité de Object)
GetType()

Obtient le Type de l'instance actuelle.

(Hérité de Object)
MemberwiseClone()

Crée une copie superficielle du Object actuel.

(Hérité de Object)
ToString()

Retourne une chaîne qui représente l'objet actuel.

(Hérité de Object)

S’applique à