Compartilhar via


Métodos de utilitário do modelo de texto

Há vários métodos que estão sempre disponíveis para você quando você escrever código um Visual Studio modelo de texto.Esses métodos são definidos em TextTransformation.

DicaDica

Você também pode usar outros métodos e os serviços fornecidos pelo ambiente de host em um modelo de texto (não pré-processado) regular.Por exemplo, você pode resolver os caminhos de arquivo, registro de erros e obter serviços fornecidos por Visual Studio e qualquer carregado de pacotes.Para obter mais informações, consulte Accessing Visual Studio from a Text Template.

Métodos de gravação.

Você pode usar o Write() e WriteLine() métodos para acrescentar texto dentro de um bloco de código padrão, em vez de usar um bloco de código de expressão.Os blocos de código de dois a seguir são funcionalmente equivalentes.

Bb126474.collapse_all(pt-br,VS.110).gifBloco de código com um bloco de expressão

<#
int i = 10;
while (i-- > 0)
    { #>
        <#= i #>
    <# }
#>

Bb126474.collapse_all(pt-br,VS.110).gifBloco de código usando WriteLine()

<# 
    int i = 10;
    while (i-- > 0)
    { 
        WriteLine((i.ToString()));
    }
#>

Talvez você ache útil usar um dos seguintes métodos de utilitário em vez de um bloco de expressão dentro de um bloco de código longo com estruturas de controle aninhado.

O Write() e WriteLine() métodos têm duas sobrecargas, uma que aceita um parâmetro de seqüência de caracteres única e outra que leva uma seqüência de caracteres de formato composto além de uma matriz de objetos a serem incluídas na seqüência de caracteres (como o Console.WriteLine() método).Os seguintes dois usos do WriteLine() são funcionalmente equivalentes:

<#
    string msg = "Say: {0}, {1}, {2}";
    string s1 = "hello";
    string s2 = "goodbye";
    string s3 = "farewell";
    
    WriteLine(msg, s1, s2, s3);
    WriteLine("Say: hello, goodbye, farewell");
#> 

Métodos de recuo

Você pode usar métodos de recuo para formatar a saída do seu modelo de texto.O TextTransformation classe tem um CurrentIndent propriedade string que mostra o recuo atual no modelo de texto e um indentLengths campo, ou seja, uma lista dos recuos que foram adicionados.Você pode adicionar um recuo com o PushIndent() método e subtrair um recuo com o PopIndent() método.Se você quiser remover todos os recuos, use o ClearIndent() método.O bloco de código a seguir mostra o uso desses métodos:

<#
    WriteLine(CurrentIndent + "Hello");
    PushIndent("    ");
    WriteLine(CurrentIndent + "Hello");
    PushIndent("    ");
    WriteLine(CurrentIndent + "Hello");
    ClearIndent();
    WriteLine(CurrentIndent + "Hello");
    PushIndent("    ");
    WriteLine(CurrentIndent + "Hello");
#>

Este bloco de código produz a seguinte saída:

Hello
        Hello
                Hello
Hello
        Hello

Métodos de aviso e erro

Você pode usar métodos de utilitário de erro e aviso para adicionar mensagens para o Visual Studio Error List.Por exemplo, o código a seguir irá adicionar uma mensagem de erro para a lista de erros.

<#
  try
  {
    string str = null;
    Write(str.Length.ToString());
  }
  catch (Exception e)
  {
    Error(e.Message);
  }
#>  

Acesso ao Host e o provedor de serviços

A propriedade this.Host pode fornecer acesso a propriedades expostas pelo host que está executando o modelo.Para usar this.Host, você deve definir hostspecific o atributo na <@template#> diretiva:

<#@template ... hostspecific="true" #>

O tipo de this.Host depende do tipo de host no qual o modelo está em execução.Em um modelo que está sendo executado em Visual Studio, você pode converter os this.Host para IServiceProvider para obter acesso a serviços como, por exemplo, o IDE.Por exemplo:

EnvDTE.DTE dte = (EnvDTE.DTE) ((IServiceProvider) this.Host)
                       .GetService(typeof(EnvDTE.DTE));

Usando um conjunto diferente de métodos de utilitário

Como parte do processo de geração de texto, o seu arquivo de modelo é transformado em uma classe, denominada GeneratedTextTransformation e herda de TextTransformation.Se você quiser usar um conjunto de métodos em vez disso, você pode escrever sua própria classe e especificá-lo na diretriz de modelo.Sua classe deve herdar de TextTransformation.

<#@ template inherits="MyUtilityClass" #>

Use o assembly diretiva para fazer referência ao assembly onde a classe compilada pode ser encontrada.