IServiceContractGenerationExtension Interface
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Define os métodos chamados durante a geração do contrato que podem ser usados para modificar o código gerado para um contrato de serviço.
public interface class IServiceContractGenerationExtension
public interface IServiceContractGenerationExtension
type IServiceContractGenerationExtension = interface
Public Interface IServiceContractGenerationExtension
Exemplos
O seguinte exemplo de código mostra como adicionar an IServiceContractGenerationExtension à ContractDescription.Behaviors propriedade durante a chamada para 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));
}
}
}
}
Os exemplos de código seguintes mostram a implementação de GenerateContract que adiciona comentários ao código gerado para um contrato de serviço.
public void GenerateContract(ServiceContractGenerationContext context)
{
Console.WriteLine("In generate contract.");
context.ContractType.Comments.AddRange(Formatter.FormatComments(commentText));
}
O seguinte exemplo de código mostra os comentários gerados no contrato de serviço.
/// 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
Observações
Implemente a IServiceContractGenerationExtension interface num comportamento contratual (um System.ServiceModel.Description.IContractBehavior tipo) para lhe permitir modificar o código gerado quando um contrato ou endpoint é compilado em código.
Normalmente, um personalizado System.ServiceModel.Description.IWsdlImportExtension insere um comportamento contratual personalizado na ContractDescription.Behaviors coleção durante a chamada para ImportContract ou ImportEndpoint.
Métodos
| Name | Description |
|---|---|
| GenerateContract(ServiceContractGenerationContext) |
Implemente a modificação do modelo de objeto do documento de código antes do processo de geração do contrato. |