Método RequiresProvidesDirectiveProcessor.GeneratePostInitializationCode
Quando substituído em uma classe derivada, adiciona código para o código de inicialização para a classe de transformação gerada. Esse código é adicionado depois que a classe base é inicializada.
Namespace: Microsoft.VisualStudio.TextTemplating
Assembly: Microsoft.VisualStudio.TextTemplating.10.0 (em Microsoft.VisualStudio.TextTemplating.10.0.dll)
Sintaxe
'Declaração
Protected MustOverride Sub GeneratePostInitializationCode ( _
directiveName As String, _
codeBuffer As StringBuilder, _
languageProvider As CodeDomProvider, _
requiresArguments As IDictionary(Of String, String), _
providesArguments As IDictionary(Of String, String) _
)
protected abstract void GeneratePostInitializationCode(
string directiveName,
StringBuilder codeBuffer,
CodeDomProvider languageProvider,
IDictionary<string, string> requiresArguments,
IDictionary<string, string> providesArguments
)
protected:
virtual void GeneratePostInitializationCode(
String^ directiveName,
StringBuilder^ codeBuffer,
CodeDomProvider^ languageProvider,
IDictionary<String^, String^>^ requiresArguments,
IDictionary<String^, String^>^ providesArguments
) abstract
abstract GeneratePostInitializationCode :
directiveName:string *
codeBuffer:StringBuilder *
languageProvider:CodeDomProvider *
requiresArguments:IDictionary<string, string> *
providesArguments:IDictionary<string, string> -> unit
protected abstract function GeneratePostInitializationCode(
directiveName : String,
codeBuffer : StringBuilder,
languageProvider : CodeDomProvider,
requiresArguments : IDictionary<String, String>,
providesArguments : IDictionary<String, String>
)
Parâmetros
- directiveName
Tipo: System.String
O nome da diretiva.
- codeBuffer
Tipo: System.Text.StringBuilder
O buffer que concatena o código que todos os processadores de diretriz devem ser executado após a classe base é inicializado durante o processamento de execução.Qualquer código que o processador de diretriz deve executar para essa diretiva depois de inicializar a classe base deve ser concatenado a esse buffer.
- languageProvider
Tipo: System.CodeDom.Compiler.CodeDomProvider
O gerador de código que cria o código para adicionar a codeBuffer.
- requiresArguments
Tipo: System.Collections.Generic.IDictionary<String, String>
Os parâmetros padrão que o processador de diretriz requer.
- providesArguments
Tipo: System.Collections.Generic.IDictionary<String, String>
Os parâmetros padrão que o processador de diretriz fornece.
Comentários
Porque GenerateTransformCode pode adicionar métodos para a classe de transformação de gerado, o código de inicialização é geralmente necessário para chamar esses métodos.
Este método é chamado uma vez para cada diretiva que processa a este processador. Portanto, você pode acrescentar o código para cada diretiva para codeBuffer. GetPostInitializationCodeForProcessingRunRetorna o conteúdo de codeBuffer após o processamento de todas as diretivas.
Este método é chamado por ProcessDirective.
Exemplos
Este exemplo gera código depois que a classe base é inicializada. Este exemplo é parte de um exemplo maior para o RequiresProvidesDirectiveProcessor classe.
protected override void GeneratePostInitializationCode(string directiveName, StringBuilder codeBuffer, System.CodeDom.Compiler.CodeDomProvider languageProvider, IDictionary<string, string> requiresArguments, IDictionary<string, string> providesArguments)
{
if (StringComparer.InvariantCultureIgnoreCase.Compare(directiveName, DomDirectiveTag) == 0)
{
// Resolve the file name of the specified "requires" xml file
// This allows the xml file to be a path relative to the text template that is using the directive processor.
string xmlFile = this.Host.ResolvePath(requiresArguments[XmlFileRequiredParameterName]);
if (!File.Exists(xmlFile))
{
throw new FileNotFoundException("Unable to load " + XmlFileRequiredParameterName, xmlFile);
}
string fieldName = providesArguments[DomProvidedParameterName].ToLower(CultureInfo.InvariantCulture) + "Value";
// Write code to initialize the domValue field by loading the xml file.
// The property is named "Dom" by default but the template writer may have changed the name using a custom provides clause like 'provides="Dom=AnotherName"'
codeBuffer.Append(
"this." + fieldName + " = new XmlDocument();" +
"this." + fieldName + ".Load(@\"" + xmlFile + "\");");
}
}
Segurança do .NET Framework
- Confiança total para o chamador imediato. O membro não pode ser usado por código parcialmente confiável. Para obter mais informações, consulte Usando bibliotecas de código parcialmente confiáveis.
Consulte também
Referência
RequiresProvidesDirectiveProcessor Classe