Procédure pas à pas : création d'un fichier projet MSBuild en partant de zéro
Les langages de programmation qui ciblent .NET Framework utilisent des fichiers projet MSBuild pour décrire et contrôler le processus de génération d'application. Quand vous utilisez Visual Studio pour créer un fichier projet MSBuild, le code XML approprié est ajouté automatiquement au fichier. Il peut cependant être utile de comprendre comment le code XML est organisé et comment vous pouvez le modifier pour contrôler une build.
Pour plus d'informations sur la création d'un fichier projet pour un projet C++, consultez MSBuild (Visual C++).
Cette procédure pas à pas montre comment créer progressivement un fichier projet de base, en utilisant seulement un éditeur de texte. Cette procédure pas à pas comprend les étapes suivantes :
Créer un fichier source d'application minimal.
Créer un fichier projet MSBuild minimal.
Étendre la variable d'environnement PATH pour y inclure MSBuild.
Générer l'application en utilisant le fichier projet.
Ajouter des propriétés pour contrôler la build.
Contrôler la build en changeant les valeurs de propriétés.
Ajouter des cibles à la build.
Contrôler la build en spécifiant des cibles.
Générer de façon incrémentielle.
Cette procédure pas à pas montre comment créer le projet sur l'invite de commandes et examiner les résultats. Pour plus d'informations sur MSBuild et savoir comment exécuter MSBuild à l'invite de commandes, consultez Procédures pas à pas : utilisation de MSBuild.
Pour effectuer la procédure pas à pas, vous devez disposer de .NET Framework (version 2.0, 3.5, 4.0 ou 4.5), car il comprend MSBuild et le compilateur Visual C#, qui sont requis cette procédure.
Création d'une application minimale
Cette section montre comment créer un fichier source d'application Visual C# minimal en utilisant un éditeur de texte.
Pour créer l'application minimale
À l'invite de commandes, accédez au dossier où vous voulez créer l'application, par exemple, \Documents\ ou \Bureau\.
Entrez md HelloWorld pour créer un sous-dossier nommé \HelloWorld\.
Entrez cd HelloWorld pour accéder au nouveau dossier.
Démarrez le Bloc-notes ou un autre éditeur de texte, puis entrez le code suivant.
using System; class HelloWorld { static void Main() { #if DebugConfig Console.WriteLine("WE ARE IN THE DEBUG CONFIGURATION"); #endif Console.WriteLine("Hello, world!"); } }
Enregistrez ce fichier de code source et nommez-le Helloworld.cs.
Générez l'application en entrant csc helloworld.cs à l'invite de commandes.
Testez l'application en entrant helloworld à l'invite de commandes.
Le message Hello, world! doit s'afficher.
Supprimez l'application en entrant del helloworld.exe à l'invite de commandes.
Création d'un fichier projet MSBuild minimal
Maintenant que vous avez un fichier source d'application minimal, vous pouvez créer un fichier projet minimal pour générer l'application. Ce fichier projet contient les éléments suivants :
Le nœud Project racine requis.
Un nœud ItemGroup pour contenir les éléments item.
Un élément item qui référence le fichier source d'application.
Un nœud Target pour contenir les tâches requises pour générer l'application.
Un élément Task pour démarrer le compilateur Visual C# pour générer l'application.
Pour créer un fichier projet MSBuild minimal
Dans l'éditeur de texte, remplacez le texte existant en utilisant ces deux lignes :
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003"> </Project>
Insérez ce nœud ItemGroup comme élément enfant du nœud Project :
<ItemGroup> <Compile Include="helloworld.cs" /> </ItemGroup>
Notez que ce nœud ItemGroup contient déjà un élément item.
Ajoutez un nœud Target comme élément enfant du nœud Project. Nommez le nœud Build.
<Target Name="Build"> </Target>
Insérez cet élément de tâche comme élément enfant du nœud Target :
<Csc Sources="@(Compile)"/>
Enregistrez ce fichier projet et nommez-le Helloworld.csproj.
Votre fichier projet minimal doit ressembler au code suivant :
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Compile Include="helloworld.cs" />
</ItemGroup>
<Target Name="Build">
<Csc Sources="@(Compile)"/>
</Target>
</Project>
Les tâches de la cible Build sont exécutées séquentiellement. Dans ce cas, la tâche du compilateur Visual C# Csc est la seule tâche. Elle attend une liste de fichiers source à compiler, qui lui est donnée par la valeur de l'élément Compile. L'élément Compile ne référence qu'un seul fichier source, Helloworld.cs.
Notes
Dans l'élément item, vous pouvez utiliser le caractère générique astérisque (*) pour référencer tous les fichiers ayant l'extension de nom de fichier .cs, comme ceci :
<Compile Include="*.cs" />
Nous ne recommandons cependant pas l'utilisation de caractères génériques, car ils rendent le débogage et le ciblage sélectif plus difficiles si des fichiers source sont ajoutés ou supprimés.
Extension de la variable PATH pour inclure MSBuild
Avant de pouvoir accéder à MSBuild, vous devez étendre la variable d'environnement PATH pour y inclure le dossier de .NET Framework.
Pour ajouter MSBuild à votre variable PATH
Depuis Visual Studio 2013, vous pouvez trouver MSBuild.exe dans le dossier MSBuild (%ProgramFiles%\MSBuild sur un système d'exploitation 32 bits ou %ProgramFiles(x86)%\MSBuild sur un système d'exploitation 64 bits).
À l'invite de commandes, entrez set PATH=%PATH%;%ProgramFiles%\MSBuild ou set PATH=%PATH%;%ProgramFiles(x86)%\MSBuild.
SI vous avez installé Visual Studio, vous pouvez aussi utiliser l'Invite de commandes de Visual Studio, qui a un chemin incluant le dossier MSBuild.
Utilisation du fichier projet pour générer l'application
Maintenant, pour créer l'application, utilisez le fichier projet que vous venez de créer.
Pour générer l'application
À l'invite de commandes, entrez msbuild helloworld.csproj /t:Build.
Ceci crée la cible Build du fichier projet Helloworld en appelant le compilateur Visual C# pour créer l'application Helloworld.
Testez l'application en entrant helloworld.
Le message Hello, world! doit s'afficher.
Notes
Vous pouvez afficher plus de détails sur la génération en augmentant le niveau de commentaire.Pour définir le niveau de commentaire à « détaillé », entrez l'une ou l'autre de ces deux commandes à l'invite de commandes :
msbuild helloworld.csproj /t:Build /verbosity:detailed
Ajout de propriétés de build
Vous pouvez ajouter des propriétés de build au fichier projet pour contrôler davantage la génération. Ajoutez maintenant ces propriétés :
Une propriété AssemblyName pour spécifier le nom de l'application.
Une propriété OutputPath pour spécifier un dossier destiné à contenir l'application.
Pour ajouter des propriétés de build
Supprimez l'application existante en entrant del helloworld.exe à l'invite de commandes.
Dans le fichier projet, insérez cet élément PropertyGroup juste après l'élément Project du début :
<PropertyGroup> <AssemblyName>MSBuildSample</AssemblyName> <OutputPath>Bin\</OutputPath> </PropertyGroup>
Ajoutez cette tâche à la cible Build, juste avant la tâche Csc :
<MakeDir Directories="$(OutputPath)" Condition="!Exists('$(OutputPath)')" />
La tâche MakeDir crée un dossier dont le nom est donné par la propriété OutputPath, à condition qu'aucun dossier de ce nom n'existe déjà.
Ajoutez cet attribut OutputAssembly à la tâche Csc :
<Csc Sources="@(Compile)" OutputAssembly="$(OutputPath)$(AssemblyName).exe" />
Ceci demande au compilateur Visual C# de produire un assembly dont le nom est donné par la propriété AssemblyName et de le placer dans le dossier dont le nom est donné par la propriété OutputPath.
Enregistrez les modifications apportées.
Votre fichier projet doit maintenant ressembler au code suivant :
<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>
Notes
Nous vous recommandons d'ajouter le délimiteur de chemin « \ » (barre oblique inverse) à la fin du nom du dossier quand vous le spécifiez dans l'élément OutputPath, au lieu de l'ajouter dans l'attribut OutputAssembly de la tâche Csc.Par conséquent,
<OutputPath>Bin\</OutputPath>
OutputAssembly=="$(OutputPath)$(AssemblyName).exe" />
est mieux que
<OutputPath>Bin</OutputPath>
OutputAssembly=="$(OutputPath)\$(AssemblyName).exe" />
Test des propriétés de build
Vous pouvez maintenant générer l'application en utilisant le fichier projet où vous avez utilisé des propriétés de build pour spécifier le dossier de sortie et le nom de l'application.
Pour tester les propriétés de build
À l'invite de commandes, entrez msbuild helloworld.csproj /t:Build.
Ceci crée le dossier \Bin\, puis appelle le compilateur Visual C# pour créer l'application MSBuildSample et la place dans le dossier \Bin\.
Pour vérifier que le dossier \Bin\ a été créé et qu'il contient l'application MSBuildSample, entrez dir Bin.
Testez l'application en entrant Bin\MSBuildSample.
Le message Hello, world! doit s'afficher.
Ajout de cibles de génération
Ensuite, ajoutez deux cibles de plus au fichier projet, comme suit :
Une cible Clean qui supprime les anciens fichiers.
Une cible Rebuild qui utilise l'attribut DependsOnTargets pour forcer la tâche Clean à s'exécuter avant la tâche Build.
Maintenant que vous avez plusieurs cibles, vous pouvez définir la cible Build comme cible par défaut.
Pour ajouter des cibles de génération
Dans le fichier projet, ajoutez ces deux cibles juste après la cible Build :
<Target Name="Clean" > <Delete Files="$(OutputPath)$(AssemblyName).exe" /> </Target> <Target Name="Rebuild" DependsOnTargets="Clean;Build" />
La cible Clean appelle la tâche Delete pour supprimer l'application. La cible Rebuild ne s'exécute pas tant que la cible Clean et la cible Build n'ont pas été exécutées. Même si la cible Rebuild n'a pas de tâches, elle provoque l'exécution de la cible Clean avant l'exécution de la cible Build.
Ajoutez cet attribut DefaultTargets à l'élément Project du début :
<Project DefaultTargets="Build" xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
Ceci définit la cible Build comme cible par défaut.
Votre fichier projet doit maintenant ressembler au code suivant :
<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>
Test des cibles de génération
Vous pouvez utiliser les nouvelles cibles de génération pour tester ces fonctionnalités dans le fichier projet :
Création de la génération par défaut
Définition du nom de l'application à l'invite de commandes
Suppression de l'application avant la génération d'une autre application
Suppression de l'application sans génération d'une autre application
Pour tester les cibles de génération
À l'invite de commandes, entrez msbuild helloworld.csproj /p:AssemblyName=Greetings.
Comme vous n'avez pas utilisé le commutateur /t pour définir explicitement la cible, MSBuild exécute la cible de génération par défaut. Le commutateur /p remplace la propriété AssemblyName et lui donne la nouvelle valeur, Greetings. Ceci provoque la création d'une nouvelle application, Greetings.exe, dans le dossier \Bin\.
Pour vérifier que le dossier \Bin\ contient à la fois l'application MSBuildSample et la nouvelle application Greetings, entrez dir Bin.
Testez l'application Greetings en entrant Bin\Greetings.
Le message Hello, world! doit s'afficher.
Supprimez l'application MSBuildSample en entrant msbuild helloworld.csproj /t:clean.
Ceci exécute la tâche Clean pour supprimer l'application qui a la valeur de la propriété AssemblyName par défaut, MSBuildSample.
Supprimez l'application Greetings en entrant msbuild helloworld.csproj /t:clean /p:AssemblyName=Greetings.
Ceci exécute la tâche Clean pour supprimer l'application qui a la valeur de la propriété AssemblyName spécifiée, MSBuildSample.
Pour vérifier que le dossier \Bin\ est maintenant vide, entrez dir Bin.
Tapez msbuild.
Même si aucun fichier projet n'est spécifié, MSBuild génère le fichier helloworld.csproj, car il n'existe qu'un seul fichier projet dans le dossier actif. Ceci provoque la création de l'application MSBuildSample dans le dossier \Bin\.
Pour vérifier que le dossier \Bin\ contient l'application MSBuildSample, entrez dir Bin.
Générer de façon incrémentielle
Vous pouvez indiquer à MSBuild de générer une cible seulement si les fichiers source ou les fichiers cible dont dépend la cible ont changé. MSBuild utilise l'horodatage d'un fichier pour déterminer s'il a changé.
Pour générer de façon incrémentielle
Dans le fichier projet, ajoutez ces attributs après la cible Build du début :
Inputs="@(Compile)" Outputs="$(OutputPath)$(AssemblyName).exe"
Ceci spécifie que la cible Build dépend des fichiers d'entrée qui sont spécifiés dans le groupe d'éléments Compile et que la cible en sortie est le fichier d'application.
La cible Build résultante doit être similaire au code suivant :
<Target Name="Build" Inputs="@(Compile)" Outputs="$(OutputPath)$(AssemblyName).exe"> <MakeDir Directories="$(OutputPath)" Condition="!Exists('$(OutputPath)')" /> <Csc Sources="@(Compile)" OutputAssembly="$(OutputPath)$(AssemblyName).exe" /> </Target>
Testez la cible Build en entrant msbuild /v:d à l'invite de commandes.
Rappelez-vous que helloworld.csproj est le fichier projet par défaut et que Build est la cible par défaut.
Le switch /v:d spécifie une description détaillée pour le processus de génération.
Ces lignes doivent être affichées.
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 ignore la cible Build, car aucun des fichiers source n'a changé depuis la dernière génération de l'application.
Exemple
Description
L'exemple suivant montre un fichier de projet qui compile une application Visual C# et consigne un message contenant le nom du fichier de sortie.
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>
Exemple
Description
L'exemple suivant montre un fichier de projet qui compile une application Visual Basic et consigne un message contenant le nom du fichier de sortie.
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>
Quelle est la suite ?
Visual Studio peut faire automatiquement la plus grande partie du travail qui est montré dans cette procédure pas à pas. Pour découvrir comment utiliser Visual Studio pour créer, modifier, générer et tester des fichiers projet MSBuild, consultez Procédures pas à pas : utilisation de MSBuild.