IServiceContractGenerationExtension Interfaccia
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Definisce i metodi chiamati durante la generazione del contratto che possono essere utilizzati per modificare il codice generato per un contratto di servizio.
public interface class IServiceContractGenerationExtension
public interface IServiceContractGenerationExtension
type IServiceContractGenerationExtension = interface
Public Interface IServiceContractGenerationExtension
Esempio
Nell'esempio di codice seguente viene illustrato come aggiungere IServiceContractGenerationExtension alla proprietà ContractDescription.Behaviors durante la chiamata a ImportContract.
public void ImportContract(WsdlImporter importer, WsdlContractConversionContext context)
{
Console.Write("ImportContract");
// Contract Documentation
if (context.WsdlPortType.Documentation != null)
{
context.Contract.Behaviors.Add(new WsdlDocumentationImporter(context.WsdlPortType.Documentation));
}
// Operation Documentation
foreach (Operation operation in context.WsdlPortType.Operations)
{
if (operation.Documentation != null)
{
OperationDescription operationDescription = context.Contract.Operations.Find(operation.Name);
if (operationDescription != null)
{
operationDescription.Behaviors.Add(new WsdlDocumentationImporter(operation.Documentation));
}
}
}
}
Negli esempi di codice seguenti viene illustrata l'implementazione di GenerateContract aggiunge commenti al codice generato per un contratto di servizio.
public void GenerateContract(ServiceContractGenerationContext context)
{
Console.WriteLine("In generate contract.");
context.ContractType.Comments.AddRange(Formatter.FormatComments(commentText));
}
Nell'esempio di codice seguente vengono mostrati i commenti generati relativi al contratto di servizio.
/// From WSDL Documentation:
///
/// <summary>The string for the Name data member.</summary>
///
[System.Runtime.Serialization.DataMemberAttribute()]
public string Name
{
get
{
return this.NameField;
}
set
{
this.NameField = value;
}
}
'''From WSDL Documentation:
'''
'''<summary>The string for the Name data member.</summary>
'''
<System.Runtime.Serialization.DataMemberAttribute()> _
Public Property Name() As String
Get
Return Me.NameField
End Get
Set
Me.NameField = value
End Set
End Property
Commenti
Implementare l'interfaccia IServiceContractGenerationExtension in un comportamento del contratto (di tipo System.ServiceModel.Description.IContractBehavior) per consentire la modifica del codice generato quando un contratto o un endpoint viene compilato nel codice.
In genere, un'interfaccia System.ServiceModel.Description.IWsdlImportExtension personalizzata consente di inserire un comportamento del contratto personalizzato nella raccolta di proprietà ContractDescription.Behaviors durante la chiamata a ImportContract o a ImportEndpoint.
Metodi
GenerateContract(ServiceContractGenerationContext) |
Procedere all'implementazione per modificare l'oggetto CodeDOM (Code Document Object Model) prima del processo di generazione del contratto. |