#advent #solution #puzzle #run #cli #input #automatic

advent-of-utils

CLI and library to organise and run Advent of Code puzzles

4 releases

0.2.3 Dec 18, 2024
0.2.2 Dec 18, 2024
0.2.1 Dec 17, 2024
0.2.0 Dec 17, 2024

#108 in Caching

Download history 298/week @ 2024-12-16

298 downloads per month
Used in advent-of-utils-cli

MIT license

14KB
88 lines

Advent-of-Utils

Introduction

Advent of Utils helps you solving your Advent of Code challenges. Not by implementing the solutions for you, but by handling the boilerplate work so you can focus on solving the puzzles.

Table of Contents

Features

  • 🚀 Automatic input fetching with local caching
  • 📊 Built-in performance benchmarking
  • 🔧 Simple macro-based setup
  • 💾 Session token management

Setup

Prerequisites

  1. An Advent of Code account and session token
  2. Rust toolchain installed

Installation

Add this to your Cargo.toml:

[dependencies]
advent-of-utils = "0.2.0"

[lib]
crate-type = ["cdylib"]

Install the CLI using:

cargo install advent-of-utils-cli

Environment Setup

Set your Advent of Code session token:

# Linux/MacOS
export AOC_SESSION=your_session_token

# Windows (PowerShell)
$env:AOC_SESSION="your_session_token"

You will find your session token in the cookies on the Advent of Code page when you are logged in.

Usage

1. Create Your Solution Structure

First, create a new Rust project for your solutions:

cargo new aoc-2023
cd aoc-2023

2. Set Up Your Project

In your project's lib.rs, use the add_days! macro to generate the boilerplate for your solutions:

use advent_of_utils::add_days;

// Generate modules for days 1 through 25
add_days!(1..=25);

3. Implement Solutions

For each day you want to solve, implement the Solution trait in the corresponding module. You need to create a file for all the days you added yet to your macro or the compiler will complain. Here's an example for day 1:

// src/day01.rs

use advent_of_utils::{Solution, AocOption};

pub struct Day01;

impl Solution for Day01 {
    fn part1(&self, input: String) -> AocOption {
        // Your solution for part 1
        1.into()
    }

    fn part2(&self, input: String) -> AocOption {
        // Your solution for part 2
        "part2 result".into()
    }
}

4. Run Solutions

Once your solutions are implemented and your code compiles you can run the your code through the aou CLI:

CLI Reference

Basic Commands

# Run a specific day's solution
aou run <YEAR> <DAY>

# Run all implemented solutions
aou run <YEAR>

For more informations on your options for the CLI run:

aou --help

Disclaimer

This tool adheres to the automation guidelines outlined in the Advent of Code FAQ on automation:

  • The tool will only fetch the puzzle input for a day if it is not already cached locally or during controlled testing.
  • Upon successfully fetching the input online, it will cache the input by default for future use.
  • The User-Agent header in requests includes a reference to this repository. If there are any issues, please contact me (Itron_al_Lenn) via a platform linked in my GitHub profile.

Dependencies

~210–650KB
~15K SLoC