Skip to content

PosInformatique.MSBuild.Yaml is a MSBuild extension that converts YAML files into JSON format during the compilation of a Visual Studio project (C#, VB. NET, ...).

License

Notifications You must be signed in to change notification settings

PosInformatique/PosInformatique.MSBuild.Yaml

Repository files navigation

PosInformatique.MSBuild.Yaml

PosInformatique.MSBuild.Yaml is a MSBuild extension that converts YAML files into a JSON during the compilation of a Visual Studio project (C#, VB. NET, ...).

This extension is very useful when you want to use YAML format for user friendly specifications, but you need to provides a JSON format into your assemblies.

For example you can use this extension for the following scenario:

Setting up

PosInformatique.MSBuild.Yaml provides an MSBuild task called YamlToJson. This task can be used with two ways:

  • Call the YamlToJson MSBuild task explicitly.
  • Declare YAML file to convert automatically before each compilation.

The PosInformatique.MSBuild.Yaml is available directly on the NuGet official website.

Call the YamlToJson MSBuild task explicitly.

To use the YamlToJson MSBuild task:

Install-Package PosInformatique.AspNetCore.Server.AspNet
  • Calls the YamlToJson tasks in your .xxproj file using MSBuild syntax:
<Project>
  <Target Name="ConvertToJson">
    <YamlToJson YamlInputFile="Api.yaml" JsonOutputFile="Api.json" />
  </Target>
</Project>

The previous example will converts the YAML content of the Api.yaml file into JSON format to the Api.json file.

Declare YAML file to convert automatically before each compilation.

This method allow to generate automatically YAML files before compilation of a .xxproj file. The input YAML files declared are automatically generated into a .Designer.json file.

Designer Files Example

To declare YAML files to generate automatically before compilation:

Install-Package PosInformatique.MSBuild.Yaml
  • Updates the .xxproj file by declaring the YAML files in the <YamlToJsonFile> inside an <ItemGroup> element.
<Project>
  <ItemGroup>
    <YamlToJsonFile Include="API.yaml" WithIndentation="false" />
  </ItemGroup>
</Project>

In the previous example, the API.yaml file will be convert into API.Designer.json JSON file with indentation disabled.

The WithIndentation attribute allow to indent or not the output JSON file. If this option is not specified, the indentation is enabled (it is mean by default the option WithIndentation is defined to true).

REMARKS: It is possible to changes the behavior of the .Designer.json file to be embedded as resource or copy the file into the output folder of the project. Defines the behavior as usual using the Properties window inside Visual Studio or by customized manually the .xxproj.

For example to include the JSON file generated as embedded resources of the assembly compiled, use the following code:

<ItemGroup>
  <EmbeddedResource Include="API.Designer.json" />
</ItemGroup>

YamlToJson MSBuild task documentation

The full documentation of the MSBuild task documentation is specified in the YamlToJson task page.

Contributions

Do not hesitate to clone my code and submit some changes... It is a open source project, so everyone is welcome to improve this library...

By the way, I am french... So maybe you will remarks that my english is not really fluent... So do not hesitate to fix my resources strings or my documentation... Merci !

Thanks

I want to thank the DiliTrust company to test and gave me their feedback of this library for their Swagger Web API and Kubernetes usage.

About

PosInformatique.MSBuild.Yaml is a MSBuild extension that converts YAML files into JSON format during the compilation of a Visual Studio project (C#, VB. NET, ...).

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages