PostSharp.Engineering.BuildTools 1.0.97-alpha.2

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
This is a prerelease version of PostSharp.Engineering.BuildTools.
There is a newer version of this package available.
See the version list below for details.
dotnet add package PostSharp.Engineering.BuildTools --version 1.0.97-alpha.2
NuGet\Install-Package PostSharp.Engineering.BuildTools -Version 1.0.97-alpha.2
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PostSharp.Engineering.BuildTools" Version="1.0.97-alpha.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PostSharp.Engineering.BuildTools --version 1.0.97-alpha.2
#r "nuget: PostSharp.Engineering.BuildTools, 1.0.97-alpha.2"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install PostSharp.Engineering.BuildTools as a Cake Addin
#addin nuget:?package=PostSharp.Engineering.BuildTools&version=1.0.97-alpha.2&prerelease

// Install PostSharp.Engineering.BuildTools as a Cake Tool
#tool nuget:?package=PostSharp.Engineering.BuildTools&version=1.0.97-alpha.2&prerelease

PostSharp Engineering

Table of contents

Content

This repository contains common development, build and publishing scripts. It produces two NuGet packages:

  • PostSharp.Engineering.BuildTools is meant to be added as a package reference from the facade C# build program.

  • PostSharp.Engineering.Sdk is meant to be used as an SDK project.

    • AssemblyMetadata.targets: Adds package versions to assembly metadata.
    • BuildOptions.props: Sets the compiler options like language version, nullability and other build options like output path.
    • TeamCity.targets: Enables build and tests reporting to TeamCity.
    • SourceLink.props: Enables SourceLink support.
    • Coverage.props: Enabled code coverage. This script should be imported in test projects only (not in projects being tested). This script adds a package to coverlet so there is no need to have in in test projects (and these references should be removed).
    • MetalamaBranding.props and PostSharpBranding.props: Configure the proper icon for the nuget package.
    • PackagesConfig.targets: Makes the Restore and Pack targets work for projects referencing NuGet using packages.config.
    • WebPublish.targets: Configures the release build of web projects to be published as a zipped artifact.
    • TestsPublish.targets: Configures the release build of test projects to be published as a zipped artifact.

Both packages must be used at the same time.

Concepts

Terminology

A product is almost synonym for repository. There is a single product per repository, and the product name must be the same as the repository name. A product can contain several C# solutions.

Build and testing locally

For details, do Build.ps1 in PowerShell and read the help.

Versioning

Objectives

A major goal of this SDK is to allow to build and test repositories that have references to other repositories without having to publish the nuget package. That is, it is possible and quite easy, with this SDK, to perform builds that reference local clones of repositories. All solutions or projects in the same product share have the same version.

Configuring the version of the current product

The product package version and package version suffix configuration is centralized in the eng\MainVersion.props script via the MainVersion and PackageVersionSuffix properties, respectively. For RTM products, leave the PackageVersionSuffix property value empty.

Configuring the version of dependent products or packages.

Package dependencies versions configuration is centralized in the eng\Versions.props script. Each dependency version is configured in a property named <[DependencyName]Version>, eg. <SystemCollectionsImmutableVersion>.

This property value is then available in all MSBuild project files in the repository and can be used in the PackageReference items. For example:

<ItemGroup>
    <PackageReference Include="System.Collections.Immutable" Version="$(SystemCollectionsImmutableVersion)" />
</ItemGroup>

Using a local build of a referenced product

Dependencies must be checked out under the same root directory (typically c:\src) under their canonic name.

Then, use Build.ps1 dependencies set local <DEPENDENCY> to specify which dependencies should be run locally.

This will generate eng/Versions.g.props, which you should have imported in eng/Versions.props.

Installation

The easiest way to get started is from this repo template: https://github.com/postsharp/PostSharp.Engineering.ProductTemplate.

Step 1. Edit global.json

Add or update the reference to PostSharp.Engineering.Sdk in global.json.

{
  "sdk": {
    "version": "5.0.206",
    "rollForward": "disable"
  },
  "msbuild-sdks": {
    "PostSharp.Engineering.Sdk": "1.0.0"
  }
}

Step 2. Packaging.props

Create eng\Packaging.props file. The content should look like this:

<Project>

    
    <PropertyGroup>
        <Authors>PostSharp Technologies</Authors>
        <PackageProjectUrl>https://github.com/postsharp/Caravela</PackageProjectUrl>
        <PackageTags>PostSharp Caravela AOP</PackageTags>
        <PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
        <PackageIcon>PostSharpIcon.png</PackageIcon>
        <PackageLicenseFile>LICENSE.md</PackageLicenseFile>
    </PropertyGroup>

    
    <ItemGroup>
        <None Include="$(MSBuildThisFileDirectory)..\PostSharpIcon.png" Visible="false" Pack="true" PackagePath="" />
        <None Include="$(MSBuildThisFileDirectory)..\LICENSE.md" Visible="false" Pack="true" PackagePath="" />
        <None Include="$(MSBuildThisFileDirectory)..\THIRD-PARTY-NOTICES.TXT" Visible="false" Pack="true" PackagePath="" />
    </ItemGroup>

</Project>

Make sure that all the files referenced in the previous step exist, or modify the file.

Step 3. MainVersion.props

Create eng\MainVersion.props file. The content should look like:

<Project>
    <PropertyGroup>
        <MainVersion>0.3.6</MainVersion>
        <PackageVersionSuffix>-preview</PackageVersionSuffix>
    </PropertyGroup>
</Project>

Additionally, there may be a property named PatchVersion, which may contain a version number with 4 components. The PatchVersion property value MUST start with the value of the MainVersion property. The use case for this property is when a repo A has a version dependency on another repo B but we want to release a patch of repo B without releasing a new build of repo A.

Step 4. Versions.props

Create eng\Versions.props file. The content should look like this (replace My by the name of the repo without dot):

<Project>

    
    <Import Project="MainVersion.props" Condition="!Exists('MyVersion.props')" />
    
    <PropertyGroup>
        <MyVersion>$(MainVersion)$(PackageVersionSuffix)</MyVersion>
        <MyAssemblyVersion>$(MainVersion)</MyAssemblyVersion>
    </PropertyGroup>

    
    <PropertyGroup>
        <RoslynVersion>3.8.0</RoslynVersion>
        <CaravelaCompilerVersion>3.8.12-preview</CaravelaCompilerVersion>
        <MicrosoftCSharpVersion>4.7.0</MicrosoftCSharpVersion>
    </PropertyGroup>

    
    <Import Project="../artifacts/publish/private/MyVersion.props" Condition="Exists('../artifacts/publish/private/MyVersion.props')" />
    <Import Project="Dependencies.props" Condition="Exists('Dependencies.props')" />

    
    <PropertyGroup>
        <AssemblyVersion>$(MyAssemblyVersion)</AssemblyVersion>
        <Version>$(MyVersion)</Version>
    </PropertyGroup>
    

</Project>

Step 5. Directory.Build.props

Add the following content to Directory.Build.props:

<Project>

  <PropertyGroup>
    <RepoDirectory>$(MSBuildThisFileDirectory)</RepoDirectory>
    <RepoKind>AzureRepos</RepoKind>
  </PropertyGroup>

  <Import Project="eng\Versions.props" />
  <Import Project="eng\Packaging.props" />

  <Import Sdk="PostSharp.Engineering.Sdk" Project="BuildOptions.props" />
  <Import Sdk="PostSharp.Engineering.Sdk" Project="CodeQuality.props" />
  <Import Sdk="PostSharp.Engineering.Sdk" Project="SourceLink.props" />

</Project>

Step 6. Directory.Build.targets

Add the following content to Directory.Build.targets:

<Project>

  <Import Sdk="PostSharp.Engineering.Sdk"  Project="AssemblyMetadata.targets" />
  <Import Sdk="PostSharp.Engineering.Sdk"  Project="TeamCity.targets" />

</Project>

Step 7. Create the front-end build project

Create a file eng\src\Build.csproj with the following content:

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        <OutputType>Exe</OutputType>
        <TargetFramework>net6.0</TargetFramework>
        <AssemblyName>Build</AssemblyName>
        <GenerateDocumentationFile>false</GenerateDocumentationFile>
        <LangVersion>latest</LangVersion>
        <Nullable>enable</Nullable>
        <NoWarn>SA0001;CS8002</NoWarn>
    </PropertyGroup>

    <ItemGroup>
        <PackageReference Include="PostSharp.Engineering.BuildTools.csproj" Version="$(PostSharpEngineeringVersion)" />
    </ItemGroup>

</Project>

Create also a file eng\src\Program.cs with content that varies according to your repo. You can use all the power of C# and PowerShell to customize the build. Note that in the PublicArtifacts, the strings $(Configuration) and $(PackageVersion), and only those strings, are replaced by their value.

using PostSharp.Engineering.BuildTools;
using PostSharp.Engineering.BuildTools.Commands.Build;
using Spectre.Console.Cli;
using System.Collections.Immutable;

namespace BuildCaravela
{
    internal class Program
    {
        private static int Main( string[] args )
        {
            var product = new Product
            {
                ProductName = "Caravela",
                Solutions = ImmutableArray.Create<Solution>(
                    new DotNetSolution( "Caravela.sln" )
                    {
                        SupportsTestCoverage = true
                    },
                    new DotNetSolution( "Tests\\Caravela.Framework.TestApp\\Caravela.Framework.TestApp.sln" )
                    {
                        IsTestOnly = true
                    } ),
                PublicArtifacts = ImmutableArray.Create(
                    "bin\\$(Configuration)\\Caravela.Framework.$(PackageVersion).nupkg",
                    "bin\\$(Configuration)\\Caravela.TestFramework.$(PackageVersion).nupkg",
                    "bin\\$(Configuration)\\Caravela.Framework.Redist.$(PackageVersion).nupkg",
                    "bin\\$(Configuration)\\Caravela.Framework.Sdk.$(PackageVersion).nupkg",
                    "bin\\$(Configuration)\\Caravela.Framework.Impl.$(PackageVersion).nupkg",
                    "bin\\$(Configuration)\\Caravela.Framework.DesignTime.Contracts.$(PackageVersion).nupkg" ),
                 Dependencies = ImmutableArray.Create(
                    new ProductDependency("Caravela.Compiler"), 
                    new ProductDependency("PostSharp.Engineering.BuildTools") )    
            };
            var commandApp = new CommandApp();
            commandApp.AddProductCommands( product );

            return commandApp.Run( args );
        }
    }
}

Step 8. Create Build.ps1, the front-end build script

Create Build.ps1 file in the repo root directory. The content should look like:

if ( $env:VisualStudioVersion -eq $null ) {
    Import-Module "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\Common7\Tools\Microsoft.VisualStudio.DevShell.dll"
    Enter-VsDevShell -VsInstallPath "C:\Program Files (x86)\Microsoft Visual Studio\2019\Enterprise\" -StartInPath $(Get-Location)
}

& dotnet run --project "$PSScriptRoot\eng\src\Build.csproj" -- $args
exit $LASTEXITCODE

Step 9. Editing .gitignore

Exclude this:

artifacts
eng/tools
*.Import.props

Build Concepts

The code in Program.cs uses the concepts described here.

classDiagram

  class Product {

  }

  class Solution {

  }



  Program o-- "1" Product 
  Product o-- "*" Solution
  Product  o-- "*" DependencyDefinition
  Product  o-- "3" BuildConfigurationInfo
  BuildConfigurationInfo  o-- "*" IBuildTrigger
  BuildConfigurationInfo o-- "*" Publisher
  BuildConfigurationInfo o-- "*" Swapper
  Swapper o-- "*" Tester
  Solution <|-- DotNetSolution
  Solution <|-- MSBuildSolution
  Tester <|-- VSTestTester
  IBuildTrigger <|-- NightlyBuildTrigger
  IBuildTrigger <|-- SourceBuildTrigger
  Publisher <|-- MSDeployPublisher
  Publisher <|-- NuGetPublisher
  Publisher <|-- VsixPublisher
  

  • Program is your program, i.e. BuildMyProduct.
  • Product is a unique instance configured by Program, the root object that defines the build for the whole repo.
  • Solution represents a solution, project, or other build script in your repo. A solution is something that can be restored, built, packed, tested. Two standard implementations are DotNetSolution and MSBuildSolution.
  • BuildConfigurationInfo represents properties that are specific to a build configuration (i.e. Debug, Release or Public) for the product.
  • DependencyDefinition are dependencies to other repositories.
  • Publisher is something that publishes, or deploys, an already-built artefact to a feed, marketplace, deployment slot, or anything. There are standard implementations for NuGet, VSIX, web sites.
  • Swapper is something that swaps a staging deployment slot into the production deployment slot.
  • Tester is a test suite, typically running against a staging deployment, that must execute successfully before the staging deployment is swapped into the production deployment.

Continuous integration

We use TeamCity as our CI/CD pipeline, and we use Kotlin scripts stored in the Git repo. For an example, see the .teamcity directory the current repo.

Artifacts

All TeamCity artifacts are published under artifacts/publish. All build configurations should export and import these artifacts.

Commands

All TeamCity build configurations use the front-end Build.ps1:

  • Debug Build and Test: Build.ps1 test --numbered %build.number%
  • Release Build and Test: Build.ps1 test --public --sign
  • Publish to internal package sources: Build.ps1 publish
  • Publish to internal and public package source: Build.ps1 publish --public

Required environment variables

  • SIGNSERVER_SECRET
  • INTERNAL_NUGET_PUSH_URL
  • INTERNAL_NUGET_API_KEY
  • NUGET_ORG_API_KEY
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on PostSharp.Engineering.BuildTools:

Package Downloads
PostSharp.Engineering.BuildTools.AWS The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2023.2.84 76 4/2/2024
2023.2.83 612 3/28/2024
2023.2.82 83 3/26/2024
2023.2.81 63 3/23/2024
2023.2.80 321 3/22/2024
2023.2.79 89 3/13/2024
2023.2.78 487 2/12/2024
2023.2.77 120 1/10/2024
2023.2.76 860 1/8/2024
2023.2.75 234 1/8/2024
2023.2.74 96 1/5/2024
2023.2.73 85 1/5/2024
2023.2.72 100 1/5/2024
2023.2.71 406 1/3/2024
2023.2.70 3,324 1/2/2024
2023.2.69 105 12/22/2023
2023.2.68 458 12/21/2023
2023.2.67 103 12/19/2023
2023.2.66 87 12/18/2023
2023.2.65 98 12/18/2023
2023.2.64 796 12/12/2023
2023.2.63 231 12/1/2023
2023.2.62 476 12/1/2023
2023.2.61 186 11/30/2023
2023.2.60 128 11/30/2023
2023.2.59 94 11/30/2023
2023.2.58 347 11/13/2023
2023.2.57 452 10/25/2023
2023.2.56 1,200 10/23/2023
2023.2.55 111 10/20/2023
2023.2.54 136 10/20/2023
2023.2.53 338 10/19/2023
2023.2.52 220 10/18/2023
2023.2.51 120 10/18/2023
2023.2.50 165 10/17/2023
2023.2.49 1,176 10/12/2023
2023.2.48 300 10/12/2023
2023.2.47 304 10/11/2023
2023.2.46 107 10/11/2023
2023.2.45 296 10/11/2023
2023.2.44 120 10/11/2023
2023.2.43 232 9/25/2023
2023.2.42 120 9/20/2023
2023.2.41 2,077 9/11/2023
2023.2.40 385 8/30/2023
2023.2.39 318 8/25/2023
2023.2.38 362 8/22/2023
2023.2.37 252 8/21/2023
2023.2.36 2,248 8/18/2023
2023.2.35 145 8/18/2023
2023.2.34 150 8/9/2023
2023.2.33 182 7/29/2023
2023.2.32 1,079 7/26/2023
2023.2.31 144 7/25/2023
2023.2.30 182 7/25/2023
2023.2.29 202 7/23/2023
2023.2.28 163 7/23/2023
2023.2.27 206 7/21/2023
2023.2.26 392 7/19/2023
2023.2.25 159 7/19/2023
2023.2.24 1,303 6/27/2023
2023.2.23 306 6/26/2023
2023.2.22 424 6/25/2023
2023.2.21 167 6/24/2023
2023.2.20 144 6/23/2023
2023.2.19 148 6/23/2023
2023.2.18 164 6/23/2023
2023.2.17 196 6/22/2023
2023.2.16 259 6/22/2023
2023.2.15 162 6/22/2023
2023.2.14 192 6/21/2023
2023.2.13 169 6/16/2023
2023.2.12 158 6/15/2023
2023.2.11 593 6/13/2023
2023.2.10 157 6/12/2023
2023.2.9 188 6/12/2023
2023.2.8 175 6/12/2023
2023.2.7 259 6/10/2023
2023.2.6-preview 142 6/10/2023
2023.2.5-preview 112 6/9/2023
2023.2.4-preview 200 6/9/2023
2023.2.3-preview 138 6/7/2023
2023.2.2-preview 173 6/2/2023
2023.2.1-preview 128 6/2/2023
2023.1.14-preview 172 5/24/2023
2023.1.13-preview 856 5/24/2023
2023.1.12-preview 165 5/23/2023
2023.1.11-preview 123 5/23/2023
2023.1.10-preview 116 5/17/2023
2023.1.9-preview 146 5/17/2023
2023.1.8-preview 100 5/15/2023
2023.1.7-preview 400 5/10/2023
2023.1.6-preview 210 4/27/2023
2023.1.5-preview 172 4/26/2023
2023.1.4-preview 112 4/26/2023
2023.1.3-preview 244 4/21/2023
2023.1.2-preview 119 4/21/2023
2023.1.1-preview 129 4/21/2023
2023.1.0-preview 126 4/21/2023
2023.0.150 170 5/29/2023
2023.0.149 465 5/24/2023
2023.0.148 172 5/23/2023
2023.0.147 212 5/17/2023
2023.0.146 244 5/17/2023
2023.0.145 159 5/9/2023
2023.0.144 417 5/2/2023
2023.0.143 174 5/2/2023
1.0.142-preview 153 4/24/2023
1.0.141-preview 220 4/5/2023
1.0.140-preview 231 4/4/2023
1.0.139-preview 224 3/30/2023
1.0.138-preview 203 3/30/2023
1.0.137-preview 119 3/30/2023
1.0.136-preview 119 3/30/2023
1.0.135-preview 740 3/30/2023
1.0.134-preview 282 3/1/2023
1.0.133-preview 135 3/1/2023
1.0.132-preview 512 2/27/2023
1.0.131-preview 392 2/24/2023
1.0.130-preview 833 2/22/2023
1.0.129-preview 130 2/22/2023
1.0.128-preview 192 2/21/2023
1.0.127-preview 123 2/17/2023
1.0.126-preview 602 2/16/2023
1.0.125-preview 163 2/16/2023
1.0.124-preview 130 2/15/2023
1.0.123-preview 117 2/15/2023
1.0.122-preview 156 2/10/2023
1.0.121-preview 115 2/10/2023
1.0.120-preview 120 2/10/2023
1.0.119-preview 162 2/9/2023
1.0.118-preview 153 2/8/2023
1.0.117-preview 166 1/30/2023
1.0.116-preview 121 1/26/2023
1.0.115-preview 123 1/26/2023
1.0.114-preview 764 1/16/2023
1.0.113-preview 191 1/13/2023
1.0.112-preview 335 1/8/2023
1.0.111-preview 443 1/5/2023
1.0.110-preview 647 12/18/2022
1.0.109-preview 181 12/15/2022
1.0.108-preview 162 12/13/2022
1.0.107-preview 176 12/9/2022
1.0.107-alpha.2 105 12/9/2022
1.0.107-alpha.1 93 12/9/2022
1.0.106-preview 177 12/8/2022
1.0.105-preview 133 12/8/2022
1.0.105-alpha.2 96 12/8/2022
1.0.105-alpha.1 103 12/6/2022
1.0.104-preview 193 12/5/2022
1.0.103-preview 257 12/2/2022
1.0.102-preview 437 11/18/2022
1.0.101-preview 1,145 11/3/2022
1.0.101-alpha.3 122 11/3/2022
1.0.101-alpha.2 135 11/2/2022
1.0.101-alpha.1 95 11/2/2022
1.0.100-preview 994 10/28/2022
1.0.99-preview 389 10/27/2022
1.0.99-alpha.3 102 10/27/2022
1.0.99-alpha.2 118 10/26/2022
1.0.99-alpha.1 102 10/26/2022
1.0.98-preview 231 10/25/2022
1.0.97-preview 432 10/20/2022
1.0.97-alpha.2 157 10/19/2022
1.0.97-alpha.1 146 10/19/2022
1.0.96-preview 390 10/7/2022
1.0.95-preview 144 10/4/2022
1.0.94-preview 530 9/29/2022
1.0.93-preview 165 9/29/2022
1.0.92-preview 185 9/27/2022
1.0.91-preview 235 9/27/2022
1.0.90-preview 192 9/27/2022
1.0.90-alpha.1 123 9/26/2022
1.0.89-preview 410 9/11/2022
1.0.87-preview 636 9/6/2022
1.0.86-preview 390 9/5/2022
1.0.86-alpha.1 104 9/2/2022
1.0.85-preview 311 8/2/2022
1.0.84-preview 329 7/29/2022
1.0.83-preview 407 7/28/2022
1.0.83-alpha.3 120 7/28/2022
1.0.83-alpha.2 121 7/28/2022
1.0.83-alpha.1 126 7/28/2022
1.0.82-preview 601 7/27/2022
1.0.82-beta.3 160 7/27/2022
1.0.82-beta.2 159 7/26/2022
1.0.82-beta 170 7/26/2022
1.0.82-alpha.1 112 7/25/2022
1.0.81-preview 240 7/22/2022
1.0.80-preview 180 7/20/2022
1.0.80-alpha.3 122 7/20/2022
1.0.80-alpha.2 120 7/20/2022
1.0.80-alpha 171 7/20/2022
1.0.79-preview 285 7/19/2022
1.0.79-beta 146 7/15/2022
1.0.79-alpha.1 229 7/2/2022
1.0.78-preview 287 7/12/2022
1.0.78-alpha.1 134 7/2/2022
1.0.77-preview 223 6/24/2022
1.0.76-preview 196 6/22/2022
1.0.75-preview 227 6/21/2022
1.0.74-preview 188 6/18/2022
1.0.73-preview 136 6/16/2022
1.0.72-preview 180 6/15/2022
1.0.71-preview 168 6/10/2022
1.0.70-preview 818 6/6/2022
1.0.70-beta 183 6/3/2022
1.0.69-preview 199 5/24/2022
1.0.68-preview 286 5/23/2022
1.0.68-beta-4 147 5/23/2022
1.0.68-beta-3 165 5/16/2022
1.0.68-beta-2 157 5/16/2022
1.0.68-beta 158 5/12/2022
1.0.67-preview 237 5/11/2022
1.0.67-beta-4 165 5/11/2022
1.0.67-beta-3 179 5/10/2022
1.0.67-beta-2 152 5/10/2022
1.0.67-beta 153 5/10/2022
1.0.66-preview 180 5/9/2022
1.0.65-preview 160 5/4/2022
1.0.65-beta 159 4/29/2022
1.0.64-preview 183 4/26/2022
1.0.63-preview 175 4/22/2022
1.0.63-beta-6 172 4/21/2022
1.0.63-beta-5 163 4/21/2022
1.0.63-beta-4 160 4/21/2022
1.0.63-beta-3 176 4/20/2022
1.0.63-beta-2 178 4/20/2022
1.0.63-beta 170 4/19/2022
1.0.62-preview 182 4/15/2022
1.0.62-beta-6 161 4/14/2022
1.0.62-beta-5 165 4/14/2022
1.0.62-beta-4 159 4/14/2022
1.0.62-beta-3 180 4/13/2022
1.0.62-beta-2 162 4/11/2022
1.0.62-beta 184 4/11/2022
1.0.61-preview 199 4/7/2022
1.0.61-beta 182 4/7/2022
1.0.60-preview 176 4/6/2022
1.0.59-preview 167 4/6/2022
1.0.59-beta 177 4/6/2022
1.0.58-beta-6 171 4/6/2022
1.0.58-beta-5 170 4/5/2022
1.0.58-beta-4 170 4/5/2022
1.0.58-beta-3 157 4/5/2022
1.0.58-beta-2 184 4/5/2022
1.0.58-beta 175 4/5/2022
1.0.56-preview 187 4/1/2022
1.0.56-beta-9 169 3/28/2022
1.0.56-beta-8 162 3/28/2022
1.0.56-beta-7 161 3/28/2022
1.0.56-beta-6 186 3/28/2022
1.0.56-beta-5 159 3/25/2022
1.0.56-beta-4 162 3/24/2022
1.0.56-beta-3 171 3/22/2022
1.0.56-beta-2 163 3/22/2022
1.0.56-beta-14 182 3/29/2022
1.0.56-beta-13 186 3/28/2022
1.0.56-beta-12 162 3/28/2022
1.0.56-beta-11 164 3/28/2022
1.0.56-beta-10 173 3/28/2022
1.0.56-beta 149 3/22/2022
1.0.55-preview 195 3/22/2022
1.0.54-preview 164 3/16/2022
1.0.53-preview 166 3/16/2022
1.0.52-preview 177 3/16/2022
1.0.51-preview 170 3/15/2022
1.0.50-preview 159 3/9/2022
1.0.49-preview 173 3/3/2022
1.0.48-preview 168 2/23/2022
1.0.47-preview 183 2/21/2022
1.0.46-preview 288 2/21/2022
1.0.45-preview 153 2/18/2022
1.0.43-preview 176 2/16/2022
1.0.42-preview 190 2/10/2022
1.0.41-preview 159 2/10/2022
1.0.40-preview 169 2/10/2022
1.0.39-preview 190 2/7/2022
1.0.38-preview 196 2/4/2022
1.0.37-preview 166 2/4/2022
1.0.36-preview 191 1/25/2022
1.0.35-preview 181 1/25/2022
1.0.34-preview 169 1/25/2022
1.0.33-preview 171 1/13/2022
1.0.32-preview 197 1/13/2022
1.0.31-preview 186 1/13/2022
1.0.30-preview 180 1/13/2022
1.0.29-preview 181 1/13/2022
1.0.28-preview 182 1/12/2022
1.0.27-preview 171 1/12/2022
1.0.26-preview 195 1/12/2022
1.0.25-preview 198 1/10/2022
1.0.24-preview 199 1/6/2022
1.0.23-preview 189 1/4/2022
1.0.22-preview 175 12/15/2021
1.0.21-preview 267 12/14/2021
1.0.20-preview 265 12/14/2021
1.0.19-preview 195 12/10/2021
1.0.18-preview 214 12/9/2021
1.0.17-preview 418 12/9/2021
1.0.16-preview 182 12/9/2021
1.0.15-preview 204 12/9/2021
1.0.14-preview 216 12/9/2021
1.0.13-preview 212 12/9/2021
1.0.12-preview 197 12/9/2021
1.0.10-preview 209 12/8/2021
1.0.9-preview 204 12/7/2021
1.0.8-preview 179 12/7/2021
1.0.7-preview 204 12/7/2021
1.0.6-preview 203 12/7/2021
1.0.4-preview 174 12/3/2021
1.0.3-preview 186 12/3/2021
1.0.2-preview 178 12/3/2021
1.0.1-preview 190 12/2/2021
1.0.0-preview 196 12/2/2021