diff --git a/build/Build.cs b/build/Build.cs
index 28eda0c..9cc38f0 100644
--- a/build/Build.cs
+++ b/build/Build.cs
@@ -8,6 +8,7 @@
using static Nuke.Common.IO.FileSystemTasks;
using static Nuke.Common.Tools.DotNet.DotNetTasks;
using Nuke.Common.Tools.OctoVersion;
+using Serilog;
[UnsetVisualStudioEnvironmentVariables]
class Build : NukeBuild
@@ -16,12 +17,12 @@ class Build : NukeBuild
readonly Configuration Configuration = Configuration.Release;
- [Solution] readonly Solution Solution;
+ [Solution] readonly Solution Solution = null!; // assigned by Nuke via reflection
[Parameter] readonly bool? OctoVersionAutoDetectBranch = NukeBuild.IsLocalBuild;
[Parameter("Branch name for OctoVersion to use to calculate the version number. Can be set via the environment variable " + CiBranchNameEnvVariable + ".", Name = CiBranchNameEnvVariable)]
- readonly string OctoVersionBranch;
+ readonly string OctoVersionBranch = null!; // assigned by Nuke via reflection
[Parameter] readonly string? OctoVersionFullSemVer;
[Parameter] readonly int? OctoVersionMajor;
@@ -37,8 +38,7 @@ class Build : NukeBuild
MinorMember = nameof(OctoVersionMinor),
PatchMember = nameof(OctoVersionPatch),
Framework = "net8.0")]
-
- readonly OctoVersionInfo OctoVersionInfo;
+ readonly OctoVersionInfo OctoVersionInfo = null!; // assigned by Nuke via reflection
static AbsolutePath SourceDirectory => RootDirectory / "source";
static AbsolutePath ArtifactsDirectory => RootDirectory / "artifacts";
@@ -49,9 +49,9 @@ class Build : NukeBuild
.Before(Restore)
.Executes(() =>
{
- SourceDirectory.GlobDirectories("**/bin", "**/obj", "**/TestResults").ForEach(DeleteDirectory);
- EnsureCleanDirectory(ArtifactsDirectory);
- EnsureCleanDirectory(PublishDirectory);
+ SourceDirectory.GlobDirectories("**/bin", "**/obj", "**/TestResults").ForEach(x => x.DeleteDirectory());
+ ArtifactsDirectory.CreateOrCleanDirectory();
+ PublishDirectory.CreateOrCleanDirectory();
});
Target Restore => _ => _
@@ -67,7 +67,7 @@ class Build : NukeBuild
.DependsOn(Restore)
.Executes(() =>
{
- Logger.Info("Building Octopus Versioning v{0}", OctoVersionInfo.FullSemVer);
+ Log.Information("Building Octopus Versioning v{0}", OctoVersionInfo.FullSemVer);
DotNetBuild(_ => _
.SetProjectFile(Solution)
@@ -93,7 +93,7 @@ class Build : NukeBuild
.Produces(ArtifactsDirectory / "*.nupkg")
.Executes(() =>
{
- Logger.Info("Packing Octopus Versioning v{0}", OctoVersionInfo.FullSemVer);
+ Log.Information("Packing Octopus Versioning v{0}", OctoVersionInfo.FullSemVer);
// This is done to pass the data to github actions
Console.Out.WriteLine($"::set-output name=semver::{OctoVersionInfo.FullSemVer}");
@@ -115,7 +115,7 @@ class Build : NukeBuild
.TriggeredBy(Pack)
.Executes(() =>
{
- EnsureExistingDirectory(LocalPackagesDir);
+ LocalPackagesDir.CreateDirectory();
ArtifactsDirectory.GlobFiles("*.nupkg")
.ForEach(package =>
{
diff --git a/build/_build.csproj b/build/_build.csproj
index 0806f98..1a22a74 100644
--- a/build/_build.csproj
+++ b/build/_build.csproj
@@ -10,6 +10,7 @@
1
true
+ enable
@@ -17,7 +18,7 @@
-
+