Exemplarische Vorgehensweise: Erstellen einer neuen MSBuild-Projektdatei
Programmiersprachen für das .NET Framework verwenden MSBuild-Projektdateien zum Beschreiben und Steuern des Anwendungsbuildprozesses. Wenn Sie in Visual Studio eine MSBuild-Projektdatei erstellen, wird der Datei automatisch das entsprechende XML hinzugefügt. Ein Grundverständnis der Organisation des XML und der Änderungsmöglichkeiten zum Steuern eines Builds ist jedoch empfehlenswert.
Weitere Informationen über das Erstellen einer Projektdatei für ein C++-Projekt finden Sie unter MSBuild (Visual C++).
In dieser exemplarischen Vorgehensweise wird das inkrementelle Erstellen einer einfachen Projektdatei nur mit einem Texteditor veranschaulicht. In der exemplarischen Vorgehensweise werden die nachfolgenden Schritte ausgeführt:
Erstellen einer minimalen Anwendungsquelldatei
Erstellen einer minimalen MSBuild-Projektdatei
Erweitern der PATH-Umgebungsvariablen um MSBuild
Erstellen der Anwendung mit der Projektdatei
Hinzufügen von Eigenschaften zum Steuern des Builds
Steuern des Builds durch Ändern von Eigenschaftswerten
Hinzufügen von Zielen zum Build
Steuern des Build durch Hinzufügen von Zielen
Inkrementeller Build
In dieser exemplarischen Vorgehensweise werden das Erstellen des Projekts an der Eingabeaufforderung und das Untersuchen der Ergebnisse veranschaulicht. Weitere Informationen zu MSBuild und zum Ausführen von MSBuild an der Eingabeaufforderung finden Sie unter Exemplarische Vorgehensweise: Verwenden von MSBuild.
Sie können die exemplarische Vorgehensweise nur ausführen, wenn Sie .NET Framework (Version 2.0, 3.5, 4.0 oder 4.5) installiert haben, da darin MSBuild und der Visual C#-Compiler enthalten sind, die für die exemplarische Vorgehensweise erforderlich sind.
Erstellen einer minimalen Anwendung
Dieser Abschnitt veranschaulicht das Erstellen einer minimalen Visual C#-Anwendungsquelldatei mit einem Texteditor.
So erstellen Sie die minimale Anwendung
Wechseln Sie an der Eingabeaufforderung zu dem Ordner, in dem Sie die Anwendung erstellen möchten, z. B. \Eigene Dateien\ oder \Desktop\.
Geben Sie md HelloWorld ein, um den Unterordner \HelloWorld\ zu erstellen.
Geben Sie cd HelloWorld ein, um zum neuen Ordner zu wechseln.
Starten Sie Editor oder einen anderen Texteditor, und geben Sie dann den folgenden Code ein.
using System; class HelloWorld { static void Main() { #if DebugConfig Console.WriteLine("WE ARE IN THE DEBUG CONFIGURATION"); #endif Console.WriteLine("Hello, world!"); } }
Speichern Sie diese Quellcodedatei, und nennen Sie sie Helloworld.cs.
Erstellen Sie die Anwendung, indem Sie an der Eingabeaufforderung csc helloworld.cs eingeben.
Testen Sie die Anwendung, indem Sie an der Eingabeaufforderung helloworld eingeben.
Die Meldung Hello, world! sollte angezeigt werden.
Löschen Sie die Anwendung, indem Sie an der Eingabeaufforderung del helloworld.exe eingeben.
Erstellen einer minimalen MSBuild-Projektdatei
Da Sie nun über eine minimale Anwendungsquelldatei verfügen, können Sie eine minimale Projektdatei für den Build der Anwendung erstellen. Diese Projektdatei enthält die folgenden Elemente:
Erforderlicher Project-Stammknoten
ItemGroup-Knoten mit Elementelementen
Elementelement, das auf die Anwendungsquelldatei verweist
Target-Knoten mit Aufgaben, die für den Build der Anwendung erforderlich sind.
Ein Task-Element, mit dem der Visual C#-Compiler für den Build der Anwendung gestartet wird.
So erstellen Sie eine minimale MSBuild-Projektdatei
Ersetzen Sie im Texteditor den vorhandenen Text durch die beiden folgenden Zeilen:
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003"> </Project>
Fügen Sie diesen ItemGroup-Knoten als untergeordnetes Element des Project-Knotens ein:
<ItemGroup> <Compile Include="helloworld.cs" /> </ItemGroup>
Beachten Sie, dass diese ItemGroup bereits ein Elementelement enthält.
Fügen Sie einen Target-Knoten als untergeordnetes Element des Project-Knotens ein. Benennen Sie den Knoten mit Build.
<Target Name="Build"> </Target>
Fügen Sie dieses Aufgabenelement als untergeordnetes Element des Target-Knotens ein:
<Csc Sources="@(Compile)"/>
Speichern Sie diese Projektdatei, und benennen Sie sie mit Helloworld.csproj.
Die minimale Projektdatei sollte dem folgenden Code ähneln:
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Compile Include="helloworld.cs" />
</ItemGroup>
<Target Name="Build">
<Csc Sources="@(Compile)"/>
</Target>
</Project>
Aufgaben im Build-Ziel werden sequenziell ausgeführt. In diesem Fall bildet die Csc-Aufgabe des Visual C#-Compilers die einzige Aufgabe. Erwartet wird eine Liste zu kompilierender Quelldateien, angegeben durch den Wert des Compile-Elements. Das Compile-Element verweist nur auf eine einzelne Quelldatei, Helloworld.cs.
Hinweis
Im Elementelement können Sie wie folgt mithilfe des Platzhalterzeichens Sternchen (*) auf alle Dateien mit der Dateinamenerweiterung .cs verweisen:
<Compile Include="*.cs" />
Die Verwendung von Platzhalterzeichen wird jedoch nicht empfohlen, da Debugging und selektive Zielauswahl erschwert werden, wenn Quelldateien hinzugefügt oder gelöscht werden.
Erweitern des Pfads um MSBuild
Auf MSBuild können Sie erst zugreifen, wenn Sie die PATH-Umgebungsvariable um den .NET Framework-Ordner erweitert haben.
So fügen Sie MSBuild zum Pfad hinzu
Ab Visual Studio 2013 ist die Datei MSBuild.exe im MSBuild-Ordner zu finden (%ProgramFiles%\MSBuild in einem 32-Bit-Betriebssystem oder %ProgramFiles(x86)%\MSBuild in einem 64-Bit-Betriebssystem).
Geben Sie in der Eingabeaufforderung set PATH=%PATH%;%ProgramFiles%\MSBuild oder set PATH=%PATH%;%ProgramFiles(x86)%\MSBuild ein.
Wenn Sie Visual Studio installiert haben, können Sie auch die Visual Studio-Eingabeaufforderung verwenden, deren Pfad den MSBuild-Ordner einschließt.
Erstellen der Anwendung mit der Projektdatei
Für den Build der Anwendung verwenden Sie nun die Projektdatei, die Sie eben erstellt haben.
So erstellen Sie die Anwendung
Geben Sie an der Eingabeaufforderung msbuild helloworld.csproj /t:Build ein.
Damit wird das Build-Ziel der Helloworld-Projektdatei erstellt, da der Visual C#-Compiler aufgerufen wird, um die Anwendung Helloworld zu erstellen.
Testen Sie die Anwendung, indem Sie helloworld eingeben.
Die Meldung Hello, world! sollte angezeigt werden.
Hinweis
Weitere Details zum Build werden angezeigt, wenn Sie den Ausführlichkeitsgrad erhöhen.Wenn Sie den Ausführlichkeitsgrad auf "Detailliert" festzulegen, geben Sie an der Eingabeaufforderung einen der beiden folgenden Befehle ein:
msbuild helloworld.csproj /t:Build /verbosity:detailed
Hinzufügen von Buildeigenschaften
Sie können der Projektdatei Buildeigenschaften hinzufügen, um den Build genauer steuern zu können. Fügen Sie jetzt die folgenden Eigenschaften hinzu:
Eine AssemblyName-Eigenschaft, mit der der Name der Anwendung angegeben wird
Eine OutputPath-Eigenschaft, mit der ein Ordner für die Anwendung angegeben wird
So fügen Sie Buildeigenschaften hinzu
Löschen Sie die vorhandene Anwendung, indem Sie an der Eingabeaufforderung del helloworld.exe eingeben.
Fügen Sie in der Projektdatei nach dem ersten Project-Element das folgende PropertyGroup-Element ein:
<PropertyGroup> <AssemblyName>MSBuildSample</AssemblyName> <OutputPath>Bin\</OutputPath> </PropertyGroup>
Fügen Sie dem Build-Ziel direkt vor der Csc-Aufgabe die folgende Aufgabe hinzu:
<MakeDir Directories="$(OutputPath)" Condition="!Exists('$(OutputPath)')" />
Mit der MakeDir-Aufgabe wird ein Ordner erstellt, der nach der OutputPath-Eigenschaft benannt wird, sofern noch kein Ordner mit diesem Namen vorhanden ist.
Fügen Sie der Csc-Aufgabe das folgende OutputAssembly-Attribut hinzu:
<Csc Sources="@(Compile)" OutputAssembly="$(OutputPath)$(AssemblyName).exe" />
Damit wird der Visual C#-Compiler angewiesen, eine nach der AssemblyName-Eigenschaft benannte Assembly zu erzeugen und diese in dem nach der OutputPath-Eigenschaft benannten Ordner einzufügen.
Speichern Sie die Änderungen.
Die Projektdatei sollte nun dem folgenden Code ähneln:
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<AssemblyName>MSBuildSample</AssemblyName>
<OutputPath>Bin\</OutputPath>
</PropertyGroup>
<ItemGroup>
<Compile Include="helloworld.cs" />
</ItemGroup>
<Target Name="Build">
<MakeDir Directories="$(OutputPath)" Condition="!Exists('$(OutputPath)')" />
<Csc Sources="@(Compile)" OutputAssembly="$(OutputPath)$(AssemblyName).exe" />
</Target>
</Project>
Hinweis
Es wird empfohlen, den umgekehrten Schrägstrich (\) als Pfadtrennzeichen am Ende des Ordnernamens bei der Angabe im OutputPath-Element anzufügen und nicht im OutputAssembly-Attribut der Csc-Aufgabe.Daher eignet sich
<OutputPath>Bin\</OutputPath>
OutputAssembly=="$(OutputPath)$(AssemblyName).exe" />
besser als
<OutputPath>Bin</OutputPath>
OutputAssembly=="$(OutputPath)\$(AssemblyName).exe" />
Testen der Buildeigenschaften
Nun können Sie die Anwendung mithilfe der Projektdatei erstellen, in der Sie über Buildeigenschaften den Ausgabeordner und den Anwendungsnamen angegeben haben.
So testen Sie die Buildeigenschaften
Geben Sie an der Eingabeaufforderung msbuild helloworld.csproj /t:Build ein.
Damit wird der Ordner \Bin\ erstellt und anschließend der Visual C#-Compiler aufgerufen, um die Anwendung MSBuildSample zu erstellen und im Ordner \Bin\ einzufügen.
Wenn Sie überprüfen möchten, ob der Ordner \Bin\ erstellt wurde und die Anwendung MSBuildSample enthält, geben Sie dir Bin ein.
Testen Sie die Anwendung, indem Sie Bin\MSBuildSample eingeben.
Die Meldung Hello, world! sollte angezeigt werden.
Hinzufügen von Build-Zielen
Fügen Sie der Projektdatei anschließend wie folgt zwei weitere Ziele hinzu:
Ein Clean-Ziel, mit dem alte Dateien gelöscht werden.
Ein Rebuild-Ziel, das über das DependsOnTargets-Attribut die Ausführung der Clean-Aufgabe erzwingt, bevor die Build-Aufgabe ausgeführt wird.
Da Sie nun über mehrere Ziele verfügen, können Sie das Build-Ziel als Standardziel festlegen.
So fügen Sie Build-Ziele hinzu
Fügen Sie in der Projektdatei direkt nach dem Build-Ziel die folgenden beiden Ziele hinzu:
<Target Name="Clean" > <Delete Files="$(OutputPath)$(AssemblyName).exe" /> </Target> <Target Name="Rebuild" DependsOnTargets="Clean;Build" />
Das Clean-Ziel ruft die Delete-Aufgabe auf, die Anwendung zu löschen. Das Rebuild-Ziel wird erst ausgeführt, nachdem das Clean-Ziel und das Build-Ziel ausgeführt wurden. Zwar weist das Rebuild-Ziel keine Aufgaben auf, doch führt es dazu, dass das Clean-Ziel vor dem Build-Ziel ausgeführt wird.
Fügen Sie dem ersten Project-Element das folgende DefaultTargets-Attribut hinzu:
<Project DefaultTargets="Build" xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
Damit wird das Build-Ziel als Standardziel festgelegt.
Die Projektdatei sollte nun dem folgenden Code ähneln:
<Project DefaultTargets="Build" xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<AssemblyName>MSBuildSample</AssemblyName>
<OutputPath>Bin\</OutputPath>
</PropertyGroup>
<ItemGroup>
<Compile Include="helloworld.cs" />
</ItemGroup>
<Target Name="Build">
<MakeDir Directories="$(OutputPath)" Condition="!Exists('$(OutputPath)')" />
<Csc Sources="@(Compile)" OutputAssembly="$(OutputPath)$(AssemblyName).exe" />
</Target>
<Target Name="Clean" >
<Delete Files="$(OutputPath)$(AssemblyName).exe" />
</Target>
<Target Name="Rebuild" DependsOnTargets="Clean;Build" />
</Project>
Testen der Build-Ziele
Mit den neuen Build-Zielen können Sie die folgenden Funktionen der Projektdatei testen:
Erstellen des Standardbuilds
Festlegen des Anwendungsnamens an der Eingabeaufforderung
Löschen der Anwendung, bevor eine andere Anwendung erstellt wird
Löschen der Anwendung, ohne eine andere Anwendung zu erstellen
So testen Sie die Build-Ziele
Geben Sie an der Eingabeaufforderung msbuild helloworld.csproj /p:AssemblyName=Greetings ein.
Da Sie das Ziel nicht explizit mit dem /t-Schalter festgelegt haben, führt MSBuild das Build-Standardziel aus. Der /p-Schalter überschreibt die AssemblyName-Eigenschaft und gibt dieser den neuen Wert Greetings. Dies führt zum Erstellen der neuen Anwendung Greetings.exe im Ordner \Bin\.
Wenn Sie überprüfen möchten, ob der Ordner \Bin\ die Anwendung MSBuildSample und die neue Anwendung Greetings enthält, geben Sie dir Bin ein.
Testen Sie die Anwendung Greetings, in dem Sie Bin\Greetings eingeben.
Die Meldung Hello, world! sollte angezeigt werden.
Löschen Sie die Anwendung MSBuildSample, indem Sie msbuild helloworld.csproj /t:clean eingeben.
Dadurch wird die Clean-Aufgabe ausgeführt, um die Anwendung mit dem AssemblyName-Standardeigenschaftswert MSBuildSample zu entfernen.
Löschen Sie die Anwendung Greetings, indem Sie msbuild helloworld.csproj /t:clean /p:AssemblyName=Greetings eingeben.
Dadurch wird die Clean-Aufgabe ausgeführt, um die Anwendung mit dem angegebenen AssemblyName-Eigenschaftswert Greetings zu entfernen.
Wenn Sie überprüfen möchten, ob der Ordner \Bin\ jetzt leer ist, geben Sie dir Bin ein.
Geben Sie msbuild ein.
Zwar ist keine Projektdatei angegeben, doch erstellt MSBuild die Datei helloworld.csproj, da der aktuelle Ordner nur eine Projektdatei enthält. Auf diese Weise wird die Anwendung MSBuildSample im Ordner \Bin\ erstellt.
Wenn Sie überprüfen möchten, ob der Ordner \Bin\ die Anwendung MSBuildSample enthält, geben Sie dir Bin ein.
Inkrementeller Build
Sie können MSBuild anweisen, ein Ziel nur zu erstellen, wenn die Quelldateien oder Zieldateien, von denen das Ziel abhängig ist, geändert wurden. MSBuild bestimmt anhand des Zeitstempels einer Datei, ob diese geändert wurde.
So nehmen Sie einen inkrementellen Build vor
Fügen Sie in der Projektdatei dem ersten Build-Ziel die folgenden Attribute hinzu:
Inputs="@(Compile)" Outputs="$(OutputPath)$(AssemblyName).exe"
Damit wird festgelegt, dass das Build-Ziel von den in der Compile-Elementgruppe angegebenen Eingabedateien abhängt und dass als Ausgabeziel die Anwendungsdatei verwendet wird.
Das resultierende Build-Ziel sollte dem folgenden Code ähneln:
<Target Name="Build" Inputs="@(Compile)" Outputs="$(OutputPath)$(AssemblyName).exe"> <MakeDir Directories="$(OutputPath)" Condition="!Exists('$(OutputPath)')" /> <Csc Sources="@(Compile)" OutputAssembly="$(OutputPath)$(AssemblyName).exe" /> </Target>
Testen Sie das Build-Ziel, indem Sie an der Eingabeaufforderung msbuild /v:d eingeben.
Vergessen Sie nicht, dass helloworld.csproj die Standardprojektdatei und Build das Standardziel darstellt.
Mit dem /v:d-Schalter wird eine ausführliche Beschreibung für den Buildprozess angegeben.
Die folgenden Zeilen sollten angezeigt werden:
Skipping target "Build" because all output files are up-to-date with respect to the input files.
Input files: HelloWorld.cs
Output files: Bin\MSBuildSample.exe
MSBuild überspringt das Build-Ziel, da seit dem letzten Build der Anwendung keine der Quelldateien geändert wurde.
Beispiel
Beschreibung
Das folgende Beispiel enthält eine Projektdatei, durch die eine Visual C#-Anwendung kompiliert und eine Meldung mit dem Namen der Ausgabedatei protokolliert wird.
Code
<Project DefaultTargets = "Compile"
xmlns="https://schemas.microsoft.com/developer/msbuild/2003" >
<!-- Set the application name as a property -->
<PropertyGroup>
<appname>HelloWorldCS</appname>
</PropertyGroup>
<!-- Specify the inputs by type and file name -->
<ItemGroup>
<CSFile Include = "consolehwcs1.cs"/>
</ItemGroup>
<Target Name = "Compile">
<!-- Run the Visual C# compilation using input files of type CSFile -->
<CSC
Sources = "@(CSFile)"
OutputAssembly = "$(appname).exe">
<!-- Set the OutputAssembly attribute of the CSC task
to the name of the executable file that is created -->
<Output
TaskParameter = "OutputAssembly"
ItemName = "EXEFile" />
</CSC>
<!-- Log the file name of the output file -->
<Message Text="The output file is @(EXEFile)"/>
</Target>
</Project>
Beispiel
Beschreibung
Das folgende Beispiel enthält eine Projektdatei, durch die eine Visual Basic-Anwendung kompiliert und eine Meldung mit dem Namen der Ausgabedatei protokolliert wird.
Code
<Project DefaultTargets = "Compile"
xmlns="https://schemas.microsoft.com/developer/msbuild/2003" >
<!-- Set the application name as a property -->
<PropertyGroup>
<appname>HelloWorldVB</appname>
</PropertyGroup>
<!-- Specify the inputs by type and file name -->
<ItemGroup>
<VBFile Include = "consolehwvb1.vb"/>
</ItemGroup>
<Target Name = "Compile">
<!-- Run the Visual Basic compilation using input files of type VBFile -->
<VBC
Sources = "@(VBFile)"
OutputAssembly= "$(appname).exe">
<!-- Set the OutputAssembly attribute of the VBC task
to the name of the executable file that is created -->
<Output
TaskParameter = "OutputAssembly"
ItemName = "EXEFile" />
</VBC>
<!-- Log the file name of the output file -->
<Message Text="The output file is @(EXEFile)"/>
</Target>
</Project>
Weitere Informationen
Visual Studio kann einen großen Teil der in dieser exemplarischen Vorgehensweise gezeigten Aktionen automatisch übernehmen. Informationen zum Erstellen und Bearbeiten sowie zum Build und zu Tests von MSBuild-Projektdateien in Visual Studio finden Sie unter Exemplarische Vorgehensweise: Verwenden von MSBuild.