AdventOfCodeSupport 1.2.3

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

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

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
{
    protected override void InternalPart1()
    {
        // Part 1 solution here.
        Console.WriteLine($"Input characters: {InputText.Length}");
        Console.WriteLine($"Input lines: {InputLines.Length}");
    }

    protected override void InternalPart2()
    {
        // Part 2 solution here.
        Bag["Foo"] = "Bar"; // Pass information to unit tests
    }
}
  • The properties InputText and InputLines load from the day's input file automatically.
  • 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 514 12/6/2023
2.4.1 434 12/4/2023
2.3.3 409 12/2/2023
2.3.2 426 12/2/2023
2.0.0 383 11/21/2023
1.4.0 778 12/5/2022
1.3.3 789 12/3/2022
1.3.2 773 12/3/2022
1.3.1 691 12/2/2022
1.2.3 783 12/1/2022
1.1.2 818 12/1/2022
1.1.0 761 11/30/2022
1.0.0 768 11/30/2022

- Fixed Year/Day not being set when AdventBase derived classes are instantiated without the AdventSolutions collection. (thanks Kao)