Go to file Use this template
Matej Janezic 0000006088
feat: to_vec<T> and to_vec_vec<T> helpers
2022-11-29 21:02:36 +01:00
.cargo feat: download cli command 2022-11-28 21:59:26 +01:00
src feat: to_vec<T> and to_vec_vec<T> helpers 2022-11-29 21:02:36 +01:00
.env.example feat: download cli command 2022-11-28 21:59:26 +01:00
.gitignore chore: cleanup for 0.1.0 release 2022-11-28 19:49:57 +01:00
Cargo.lock feat: add regex and hashbrown as default deps 2022-11-28 23:59:53 +01:00
Cargo.toml feat: add regex and hashbrown as default deps 2022-11-28 23:59:53 +01:00
README.md feat: download cli command 2022-11-28 21:59:26 +01:00

README.md

Advent-of-Code {YEAR}

This is a dumbed down version of fspoettel/advent-of-code-rust with some extra features

CLI

Prepare

# example: `cargo prepare 1`
cargo prepare <day>

# output:
# Created module "src/bin/01.rs"
# Created empty input file "src/inputs/01.txt"
# Created empty example file "src/examples/01.txt"
# ---
# 🎄 Type `cargo solve 01` to run your solution.

Download input

prepare .env file

cp .env.example .env

set YEAR to whichever year you are solving for and TOKEN to AoC session Cookie.

# example: `cargo download 1`
cargo download <day>

# output:
# Downloaded input file "src/inputs/01.txt"

Solve

# example: `cargo solve 01`
cargo solve <day>

# output:
#     Running `target/debug/01`
# 🎄 Part 1 🎄
#
# 6 (elapsed: 37.03µs)
#
# 🎄 Part 2 🎄
#
# 9 (elapsed: 33.18µs)

Displayed timings show the raw execution time of your solution without overhead (e.g. file reads). To run an optimized version for benchmarking, append the --release flag.

Solve all

cargo all

# output:
#     Running `target/release/aoc`
# ----------
# | Day 01 |
# ----------
# 🎄 Part 1 🎄
#
# 0 (elapsed: 170.00µs)
#
# 🎄 Part 2 🎄
#
# 0 (elapsed: 30.00µs)
# <...other days...>
# Total: 0.20ms

all is an alias for cargo run. To run an optimized version for benchmarking, append the --release flag.

Run against test inputs

run all solutions

cargo test

run for a given day

cargo test --bin <day>