AdventOfCodeSupport 1.1.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package AdventOfCodeSupport --version 1.1.0
NuGet\Install-Package AdventOfCodeSupport -Version 1.1.0
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="AdventOfCodeSupport" Version="1.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AdventOfCodeSupport --version 1.1.0
#r "nuget: AdventOfCodeSupport, 1.1.0"
#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 AdventOfCodeSupport as a Cake Addin
#addin nuget:?package=AdventOfCodeSupport&version=1.1.0

// Install AdventOfCodeSupport as a Cake Tool
#tool nuget:?package=AdventOfCodeSupport&version=1.1.0

AdventOfCodeSupport

This package provides support to simplify the process of storing each day's puzzle within a single solution. Each day is automatically registered to a central location, with built-in support for BenchmarkDotNet.

Usage

  • Begin by adding this NuGet package to your project AdventOfCodeSupport.
  • Add a folder to your project for the current year i.e. 2022.
  • Add a subfolder to the year called Inputs.
  • Place each day's input into that folder named by day with 2 digits 01.txt.
  • Create a class in the 2022 folder called Day01.cs
using AdventOfCodeSupport;

namespace Foo._2022;

public class Day01 : AdventBase
{
    public Day01() : base(/*year*/2022, /*day*/1) { }

    protected override void InternalPart1()
    {
        // Part 1 solution here.
    }

    protected override void InternalPart2()
    {
        // Part 2 solution here.
    }
}
  • The call to the base constructor has an optional 3rd parameter to disable the input for the day.
  • Create a new AdventSolutions() at your entry point.
  • Select your day from the AdventSolutions, for example:
using AdventOfCodeSupport;

var solutions = new AdventSolutions();
var today = solutions.GetMostRecentDay();
var day3 = solutions.GetDay(2022, 3);
var day4 = solutions.First(x => x.Year == 2022 && x.Day == 4);
  • Run your solution parts with today.Part1().Part2().
  • Or benchmark them with today.Benchmark(), benchmarking requires running in Release.
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

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.4.2 491 12/6/2023
2.4.1 429 12/4/2023
2.3.3 398 12/2/2023
2.3.2 423 12/2/2023
2.0.0 378 11/21/2023
1.4.0 773 12/5/2022
1.3.3 777 12/3/2022
1.3.2 769 12/3/2022
1.3.1 685 12/2/2022
1.2.3 763 12/1/2022
1.1.2 806 12/1/2022
1.1.0 756 11/30/2022
1.0.0 763 11/30/2022

Two new methods to grab a specific day, as well as one to grab the most recent day. GetDay, GetMostRecentDay.
AoCBase -> AdventBase
Solutions -> AdventSolutions