Aufrufen der Texttransformation im Buildprozess
Texttransformation kann als Teil des Buildprozesses einer Visual Studio-Projektmappe aufgerufen werden. Es gibt Buildaufgaben, die für die Texttransformation angegeben wurden. Die T4-Buildaufgaben führen Entwurfszeittextvorlagen aus und kompilieren gleichzeitig Laufzeitvorlagen (vorverarbeitete Textvorlagen.)
Je nachdem, welche Build-Engine Sie verwenden, können die Buildaufgaben unterschiedliche Ergebnisse haben. Wenn Sie die Projektmappe in Visual Studio erstellen, kann eine Textvorlage auf die Visual Studio-API (EnvDTE) zugreifen, wenn das Attribut hostspecific="true" angegeben ist. Dies gilt jedoch nicht, wenn Sie die Projektmappe aus der Befehlszeile erstellen oder wenn Sie einen Serverbuild mit Visual Studio starten. In diesen Fällen wird der Build von MSBuild ausgeführt, und ein anderer T4-Host wird verwendet. Dies bedeutet, dass Sie auf Elemente wie Projektdateinamen nicht genauso zugreifen können, wie wenn Sie eine Textvorlage mit MSBuild erstellen. Sie können Umgebungsinformationen mit Buildparametern in Textvorlagen und Anweisungsprozessoren übergeben.
Konfigurieren des Computers
Um Buildaufgaben auf dem Entwicklungscomputer zu aktivieren, installieren Sie das Visual Studio SDK für Modellierung.
Hinweis
Die Komponente Textvorlagentransformation wird automatisch als Teil der Workload Visual Studio-Erweiterungsentwicklung installiert. Sie können die Installation auch über die Registerkarte Einzelne Komponenten des Visual Studio-Installers unter der Kategorie SDKs, Bibliotheken und Frameworks durchführen. Installieren Sie die Komponente Modellierungs-SDK auf der Registerkarte Einzelne Komponenten.
Wenn der Buildserver auf einem Computer ausgeführt wird, auf dem Visual Studio nicht installiert ist, kopieren Sie die folgenden Dateien vom Entwicklungscomputer auf den Buildcomputer:
%ProgramFiles(x86)%\Microsoft Visual Studio\2019\Community\MSBuild\Microsoft\VisualStudio\v16.0\TextTemplating
- Microsoft.VisualStudio.TextTemplating.Sdk.Host.15.0.dll
- Microsoft.TextTemplating.Build.Tasks.dll
- Microsoft.TextTemplating.targets
%ProgramFiles(x86)%\Microsoft Visual Studio\2019\Community\VSSDK\VisualStudioIntegration\Common\Assemblies\v4.0
- Microsoft.VisualStudio.TextTemplating.15.0.dll
- Microsoft.VisualStudio.TextTemplating.Interfaces.15.0.dll
- Microsoft.VisualStudio.TextTemplating.VSHost.15.0.dll
%ProgramFiles(x86)%\Microsoft Visual Studio\2019\Community\Common7\IDE\PublicAssemblies
- Microsoft.VisualStudio.TextTemplating.Modeling.15.0.dll
Tipp
Wenn Sie eine MissingMethodException
für eine Microsoft.CodeAnalysis-Methode beim Ausführen von TextTemplating-Buildzielen auf einem Buildserver erhalten, stellen Sie sicher, dass sich die Roslyn-Assemblys in einem Verzeichnis namens Roslyn befinden, das sich im selben Verzeichnis wie die ausführbare Builddatei befindet (z. B. msbuild.exe).
Bearbeiten der Projektdatei
Bearbeiten Sie Ihre Projektdatei, um einige der Features in MSBuild zu konfigurieren, z. B. das Importieren der Texttransformationsziele.
Wählen Sie im Projektmappen-Explorer im Kontextmenü des Projekts Entladen aus. Damit können Sie die CSPROJ- oder VBPROJ-Datei im XML-Editor zu bearbeiten. Wenn Sie die Bearbeitung abgeschlossen haben, wählen Sie Erneut laden aus.
Importieren der Texttransformationsziele
Suchen Sie in der VBPROJ- oder CSPROJ-Datei nach der letzten Import Project
-Zeile.
Fügen Sie nach dieser Zeile, falls vorhanden, den Textvorlagenimport ein:
<Import Project="$(MSBuildExtensionsPath)\Microsoft\VisualStudio\v17.0\TextTemplating\Microsoft.TextTemplating.targets" />
<Import Project="$(MSBuildExtensionsPath)\Microsoft\VisualStudio\v16.0\TextTemplating\Microsoft.TextTemplating.targets" />
Transformieren von Vorlagen in einem Build
Einige Eigenschaften, die Sie in die Projektdatei einfügen können, um die Transformationsaufgabe zu steuern:
Führen Sie die Transformierensaufgabe am Anfang jedes Builds aus:
<PropertyGroup> <TransformOnBuild>true</TransformOnBuild> </PropertyGroup>
Überschreiben Sie Dateien, die schreibgeschützt sind, weil sie z. B. nicht ausgecheckt sind:
<PropertyGroup> <OverwriteReadOnlyOutputFiles>true</OverwriteReadOnlyOutputFiles> </PropertyGroup>
Transformieren Sie jede Vorlage jedes Mal:
<PropertyGroup> <TransformOutOfDateOnly>false</TransformOutOfDateOnly> </PropertyGroup>
Standardmäßig generiert die T4-MSBuild-Aufgabe eine Ausgabedatei, wenn sie älter ist als:
- ihre Vorlagendatei
- alle enthaltenen Dateien
- alle Dateien, die zuvor von der Vorlage oder von einem von ihr verwendeten Anweisungsprozessor gelesen wurden
Hierbei wird ein leistungsstärkerer Abhängigkeitstest durchgeführt als mit dem Befehl Alle Vorlagen transformieren in Visual Studio, bei dem nur die Daten der Vorlage und der Ausgabedatei verglichen werden.
Wenn Sie nur die Texttransformationen im Projekt ausführen möchten, rufen Sie die Aufgabe „TransformAll“ auf:
msbuild myProject.csproj /t:TransformAll
Zur Transformation einer bestimmten Textvorlage:
msbuild myProject.csproj /t:Transform /p:TransformFile="Template1.tt"
In TransformFile können Sie Platzhalter verwenden:
msbuild dsl.csproj /t:Transform /p:TransformFile="GeneratedCode\**\*.tt"
Quellcodeverwaltung
Es besteht keine spezifische integrierte Integration in ein Quellcodeverwaltungssystem. Sie können jedoch eigene Erweiterungen hinzufügen, z. B. zum Auschecken und Einchecken einer generierten Datei. Standardmäßig vermeidet die Texttransformationsaufgabe das Überschreiben einer Datei, die als schreibgeschützt markiert ist. Wenn eine solche Datei vorkommt, wird ein Fehler in der Visual Studio-Fehlerliste protokolliert, und die Aufgabe schlägt fehl.
Fügen Sie die folgende Eigenschaft ein, um anzugeben, dass schreibgeschützte Dateien überschrieben werden sollen:
<OverwriteReadOnlyOutputFiles>true</OverwriteReadOnlyOutputFiles>
Sofern Sie den Schritt zur nachträglichen Verarbeitung nicht anpassen, wird eine Warnung in der Fehlerliste protokolliert, wenn eine Datei überschrieben wird.
Anpassen des Buildprozesses
Texttransformation geschieht vor anderen Aufgaben im Buildprozess. Sie können Aufgaben definieren, die vor und nach der Transformation aufgerufen werden, indem Sie die Eigenschaften $(BeforeTransform)
und $(AfterTransform)
festlegen:
<PropertyGroup>
<BeforeTransform>CustomPreTransform</BeforeTransform>
<AfterTransform>CustomPostTransform</AfterTransform>
</PropertyGroup>
<Target Name="CustomPreTransform">
<Message Text="In CustomPreTransform..." Importance="High" />
</Target>
<Target Name="CustomPostTransform">
<Message Text="In CustomPostTransform..." Importance="High" />
</Target>
In AfterTransform
können Sie auf Dateilisten verweisen:
GeneratedFiles – Eine Liste von Dateien, die vom Prozess geschrieben werden. Bei Dateien, die vorhandene schreibgeschützte Dateien überschreiben, ist
%(GeneratedFiles.ReadOnlyFileOverwritten)
„true“. Diese Dateien können aus der Quellcodeverwaltung ausgecheckt werden.NonGeneratedFiles– Eine Liste von schreibgeschützten Dateien, die nicht überschrieben wurden.
Sie definieren z. B. eine Aufgabe zum Auschecken von GeneratedFiles.
OutputFilePath und OutputFileName
Diese Eigenschaften werden nur von MSBuild verwendet. Sie beeinflussen nicht die Codegenerierung in Visual Studio. Sie leiten die generierte Ausgabedatei in einen anderen Ordner oder eine andere Datei um. Der Zielordner muss bereits vorhanden sein.
<ItemGroup>
<None Include="MyTemplate.tt">
<Generator>TextTemplatingFileGenerator</Generator>
<OutputFilePath>MyFolder</OutputFilePath>
<LastGenOutput>MyTemplate.cs</LastGenOutput>
</None>
</ItemGroup>
Ein hilfreicher Ordner für die Umleitung ist $(IntermediateOutputPath)
.
Wenn Sie einen Ausgabedateinamen angeben, hat dieser Vorrang vor der Erweiterung, die in der output-Anweisung in den Vorlagen angegeben ist.
<ItemGroup>
<None Include="MyTemplate.tt">
<Generator>TextTemplatingFileGenerator</Generator>
<OutputFileName>MyOutputFileName.cs</OutputFileName>
<LastGenOutput>MyTemplate.cs</LastGenOutput>
</None>
</ItemGroup>
Es wird nicht empfohlen, OutputFileName oder OutputFilePath anzugeben, wenn Sie außerdem in Visual Studio mit Alle transformieren Vorlagen transformieren oder einen Generator einzelner Dateien ausführen. Je nachdem, wie Sie die Transformation ausgelöst haben, erhalten Sie dann unterschiedliche Dateipfade. Dies kann verwirrend sein.
Hinzufügen von Verweis- und Includepfaden
Der Host verfügt über einen Standardsatz an Pfaden, in denen er nach Assemblys sucht, auf die von Vorlagen verwiesen wird. So fügen Sie diesem Satz Pfade hinzu:
<ItemGroup>
<T4ReferencePath Include="$(VsIdePath)PublicAssemblies\" />
<!-- Add more T4ReferencePath items here -->
</ItemGroup>
Stellen Sie eine durch Semikolons getrennte Liste bereit, um die Ordner festzulegen, in denen nach Includedateien gesucht wird. Normalerweise fügen Sie der vorhandenen Liste Pfade hinzu.
<PropertyGroup>
<IncludeFolders>
$(IncludeFolders);$(MSBuildProjectDirectory)\Include;AnotherFolder;And\Another</IncludeFolders>
</PropertyGroup>
Übergeben der Buildkontextdaten in die Vorlagen
Sie können Parameterwerte in der Projektdatei festlegen. Beispielsweise können Sie Buildeigenschaften und Umgebungsvariablen übergeben:
<ItemGroup>
<T4ParameterValues Include="ProjectFolder">
<Value>$(ProjectDir)</Value>
<Visible>false</Visible>
</T4ParameterValues>
</ItemGroup>
Legen Sie in einer Textvorlage hostspecific
in der template-Direktive fest. Verwenden Sie die Parameter-Anweisung, um Werte abzurufen:
<#@template language="c#" hostspecific="true"#>
<#@ parameter type="System.String" name="ProjectFolder" #>
The project folder is: <#= ProjectFolder #>
In einem Anweisungsprozessor können Sie ITextTemplatingEngineHost.ResolveParameterValueaufrufen:
Hinweis
ResolveParameterValue
ruft Daten nur dann aus T4ParameterValues
ab, wenn Sie MSBuild verwenden. Wenn Sie die Vorlage mit Visual Studio transformieren, haben die Parameter Standardwerte.
Verwenden von Projekteigenschaften in der Assembly- und Includeanweisung
Visual Studio-Makros wie $(SolutionDir) funktionieren nicht in MSBuild. Sie können stattdessen Projekteigenschaften verwenden.
Bearbeiten Sie die CSPROJ- oder VBPROJ-Datei, und definieren Sie eine Projekteigenschaft. In folgendem Beispiel wird eine Eigenschaft mit dem Namen myLibFolder definiert:
<!-- Define a project property, myLibFolder: -->
<PropertyGroup>
<myLibFolder>$(MSBuildProjectDirectory)\..\libs</myLibFolder>
</PropertyGroup>
<!-- Tell the MSBuild T4 task to make the property available: -->
<ItemGroup>
<T4ParameterValues Include="myLibFolder">
<Value>$(myLibFolder)</Value>
</T4ParameterValues>
</ItemGroup>
Nun können Sie die Projekteigenschaft in der Assembly- und der Includedirektive verwenden:
<#@ assembly name="$(myLibFolder)\MyLib.dll" #>
<#@ include file="$(myLibFolder)\MyIncludeFile.t4" #>
Diese Direktiven rufen Werte von T4parameterValues in MSBuild- und Visual Studio-Hosts ab.
Q&A
Warum sollte ich Vorlagen im Buildserver transformieren? Ich habe bereits Vorlagen in Visual Studio transformiert, bevor ich meinen Code eingecheckt habe.
Wenn Sie eine eingeschlossene Datei oder eine andere Datei, die von der Vorlage gelesen wird, aktualisieren, wird diese Datei nicht automatisch von Visual Studio transformiert. Durch die Transformation von Vorlagen im Rahmen des Builds wird sichergestellt, dass alle Teile aktuell sind.
Welche anderen Optionen zur Transformation von Textvorlagen gibt es?
Sie können das TextTransform-Hilfsprogramm in den Befehlsskripten verwenden. In den meisten Fällen ist es einfacher, MSBuild zu verwenden.
Aufrufen der Texttransformation in einer Visual Studio-Erweiterung.
Entwurfszeittextvorlagen werden von Visual Studio transformiert.
Laufzeittextvorlagen werden zur Laufzeit in der Anwendung transformiert.
Zugehöriger Inhalt
- Es gibt gute Empfehlungen in der Vorlage T4 MSbuild unter
%ProgramFiles%\Microsoft Visual Studio\2022\Enterprise\MSBuild\Microsoft\VisualStudio\v17.0\TextTemplating\Microsoft.TextTemplating.targets
- Es gibt gute Empfehlungen in der Vorlage T4 MSbuild unter
%ProgramFiles(x86)%\Microsoft Visual Studio\2019\Enterprise\msbuild\Microsoft\VisualStudio\v16.0\TextTemplating\Microsoft.TextTemplating.targets