MSBuild, tâche
Mise à jour : novembre 2007
Génère des projets MSBuild depuis un autre projet MSBuild.
Paramètres
Le tableau suivant décrit les paramètres de la tâche MSBuild.
Paramètre |
Description |
||
---|---|---|---|
BuildInParallel |
Paramètre Boolean facultatif. Si ce paramètre a la valeur true, les projets spécifiés dans le paramètre Projects sont générés en parallèle si possible. La valeur par défaut est true. |
||
Projects |
Paramètre ITaskItem[] obligatoire. Spécifie les fichiers projet à générer. |
||
Properties |
Paramètre String facultatif. Liste délimitée par des points-virgules de paires nom/valeur de propriété à appliquer en tant que propriétés globales au projet enfant. Lorsque vous spécifiez ce paramètre, cela équivaut, d'un point de vue fonctionnel, à définir des propriétés possédant le commutateur /property lorsque vous générez avec MSBuild.exe. Par exemple : Properties="Configuration=Debug;Optimize=$(Optimize)" Lorsque vous passez des propriétés au projet via le paramètre Properties, MSBuild crée une nouvelle instance du projet, même si le fichier projet a déjà été chargé. Lorsqu'une nouvelle instance du projet est créée, MSBuild traite cette instance comme un projet différent avec des propriétés globales différentes et qui peut être généré en parallèle avec d'autres instances du projet. Par exemple, une configuration Release pourrait être générée en même temps qu'une configuration Debug. |
||
ToolsVersion |
Paramètre String facultatif. Permet à une tâche MSBuild de générer un projet qui vise une version différente du .NET Framework de celle spécifiée dans le projet. Les valeurs valides sont 2.0, 3.0 et 3.5. La valeur par défaut est 3.5. |
||
RebaseOutputs |
Paramètre Boolean facultatif. Si la valeur est true, les chemins d'accès relatifs des éléments de sortie cibles des projets créés sont modifiés par rapport au projet appelant. La valeur par défaut est false. |
||
RunEachTargetSeparately |
Paramètre Boolean facultatif. Si le paramètre a la valeur true, la tâche MSBuild appelle une par une chaque cible de la liste passée à MSBuild, plutôt que de toutes les appeler en même temps. Affecter à ce paramètre la valeur true garantit que les cibles sont toutes appelées même en cas d'échec de l'appel d'une des cibles. Sinon, une erreur de génération arrêterait l'appel de toutes les cibles consécutives. La valeur par défaut est false. |
||
StopOnFirstFailure |
Paramètre Boolean facultatif. Si la valeur du paramètre est true, la tâche arrête la génération des projets restants dès que l'un d'entre eux risque de ne pas fonctionner. |
||
TargetOutputs |
Paramètre de sortie en lecture seule ITaskItem[] facultatif. Retourne les sorties des cibles créées à partir de tous les fichiers projet. Seules les sorties des cibles spécifiées sont retournées et non les sorties qui peuvent exister sur les cibles dont ces cibles dépendent. Le paramètre TargetOutputs contient également les métadonnées suivantes :
|
||
Targets |
Paramètre String facultatif. Spécifie la ou les cibles à générer dans les fichiers projet. Utilisez un point-virgule pour séparer une liste de noms cibles. Si aucune cible n'est spécifiée dans la tâche MSBuild, cette dernière génère les cibles par défaut spécifiées dans les fichiers projet.
|
Notes
Contrairement à ce qui se passe lors de l'utilisation de la Exec, tâche pour appeler MSBuild.exe, cette tâche utilise le même processus MSBuild pour générer les projets enfants. La liste de cibles déjà générées qu'il est possible d'ignorer est partagée entre les générations parentes et enfants. Cette tâche est également plus rapide car aucun nouveau processus MSBuild n'est créé.
Cette tâche peut traiter non seulement les fichiers projet, mais aussi les fichiers solution.
Toute configuration requise par MSBuild pour permettre à des projets d'être générés en même temps, même si la configuration implique une infrastructure distante (par exemple : ports, protocoles, délais d'attente, tentatives, etc.), doit être configurable via un fichier de configuration. Lorsque cela est possible, les éléments de configuration doivent être en mesure d'être spécifiés comme paramètres de tâche de la tâche MSBuild.
Depuis MSBuild 3.5, les projets Solution font maintenant ressurgir TargetOutputs parmi tous les sous-projets qu'ils génèrent.
Passage de propriétés aux projets
Dans les versions de MSBuild antérieures à MSBuild 3.5, le passage de différents jeux de propriétés aux différents projets répertoriés dans l'élément MSBuild présentait quelques difficultés. Si vous utilisiez l'attribut Properties de MSBuild, tâche, cette configuration était alors appliquée à tous les projets construits à moins que vous n'ayez regroupé la MSBuild, tâche et attribué, de manière conditionnelle, différentes propriétés à chaque projet de la liste d'éléments.
Toutefois, MSBuild 3.5 fournit deux nouveaux éléments de métadonnées réservés, Properties et AdditionalProperties, qui vous offrent une méthode flexible pour passer des propriétés différentes à différents projets construits à l'aide de la MSBuild, tâche.
Remarque : |
---|
Ces nouveaux éléments de métadonnées sont uniquement applicables aux éléments passés dans l'attribut Projects de la MSBuild, tâche. |
Avantages de la génération multiprocesseur
L'un des avantages majeurs de l'utilisation de ces nouvelles métadonnées est flagrant lorsque vous générés vos projets en parallèle sur un système multiprocesseur. Les métadonnées vous permettent de consolider tous les projets en un appel de MSBuild, tâche sans devoir effectuer de traitement par lot ou définir des tâches MSBuild conditionnelles. Et lorsque vous appelez uniquement une MSBuild, tâcheunique, tous les projets répertoriés dans l'attribut Projects seront générés en parallèle. (Toutefois, uniquement si l'attribut BuildInParallel=true est présent dans la MSBuild, tâche.) Pour plus d'informations, consultez Génération pour plusieurs processeurs.
Métadonnées Properties
Un scénario courant est lorsque vous générez plusieurs fichiers solution à l'aide de la MSBuild, tâche avec différentes configurations de génération. Vous voulez peut-être générer la solution a1 en configuration Debug et la solution a2 en configuration Release. Dans MSBuild 2.0, le fichier projet ressemblerait à ceci :
Remarque : |
---|
Dans l'exemple suivant, "…" représente des fichiers solution supplémentaires. |
a.proj
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<Target Name="Build">
<MSBuild Projects="a1.sln…" Properties="Configuration=Debug"/>
<MSBuild Projects="a2.sln" Properties="Configuration=Release"/>
</Target>
</Project>
En utilisant les métadonnées Properties, vous pouvez pourtant simplifier ceci en une MSBuild, tâche unique, comme indiqué ci-après :
a.proj
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<ProjectToBuild Include="a1.sln…">
<Properties>Configuration=Debug</Properties>
</ProjectToBuild>
<ProjectToBuild Include="a2.sln">
<Properties>Configuration=Release</Properties>
</ProjectToBuild>
</ItemGroup>
<Target Name="Build">
<MSBuild Projects="@(ProjectToBuild)"/>
</Target>
</Project>
- ou -
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<ProjectToBuild Include="a1.sln…"/>
<ProjectToBuild Include="a2.sln">
<Properties>Configuration=Release</Properties>
</ProjectToBuild>
</ItemGroup>
<Target Name="Build">
<MSBuild Projects="@(ProjectToBuild)"
Properties="Configuration=Debug"/>
</Target>
</Project>
Métadonnées AdditionalProperties
Considérez le scénario suivant où vous générez deux fichiers solution à l'aide de la MSBuild, tâche, tous deux en configuration Release, mais un sur l'architecture x86 et l'autre sur l'architecture ia64. Dans MSBuild 2.0, vous devriez créer plusieurs instances de la MSBuild, tâche : une pour générer le projet en configuration Release avec l'architecture x86, l'autre en configuration Release avec l'architecture ia64. Votre fichier projet ressemblerait à ceci :
a.proj
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<Target Name="Build">
<MSBuild Projects="a1.sln…" Properties="Configuration=Release;
Architecture=x86"/>
<MSBuild Projects="a2.sln" Properties="Configuration=Release;
Architecture=ia64"/>
</Target>
</Project>
En utilisant les métadonnées AdditionalProperties, vous pouvez simplifier ceci pour n'utiliser qu'une MSBuild, tâche unique, de la manière suivante :
a.proj
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<ProjectToBuild Include="a1.sln…">
<AdditionalProperties>Architecture=x86
</AdditionalProperties>
</ProjectToBuild>
<ProjectToBuild Include="a2.sln">
<AdditionalProperties>Architecture=ia64
</AdditionalProperties>
</ProjectToBuild>
</ItemGroup>
<Target Name="Build">
<MSBuild Projects="@(ProjectToBuild)"
Properties="Configuration=Release"/>
</Target>
</Project>
Exemple
L'exemple suivant utilise la tâche MSBuild pour générer les projets spécifiés par la collection d'éléments ProjectReferences. Les sorties cibles résultantes sont stockées dans la collection d'éléments AssembliesBuiltByChildProjects.
<Project xmlns="https://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<ProjectReferences Include="*.*proj" />
</ItemGroup>
<Target Name="BuildOtherProjects">
<MSBuild
Projects="@(ProjectReferences)"
Targets="Build">
<Output
TaskParameter="TargetOutputs"
ItemName="AssembliesBuiltByChildProjects" />
</MSBuild>
</Target>
</Project>