Template repository for Elixir solutions to Advent of Code puzzles.
Adapted from another Advent of Code Elixir Starter.
- Two Mix tasks: (Run
mix help <task_name>
after building the project for usage info)mix advent.gen
- Generate boilerplate solution and test modules for a new year of puzzles.mix advent.solve
- Run or benchmark a solution.
- Automatically downloads puzzle inputs as needed.
- Optional benchmarking with Benchee.
- Special support for puzzle solutions that reuse the same parsed value for both parts.
- Optionally run in a container that handles Erlang/Elixir installation for you.
Start by creating your own repository from this template, using the big green
button up there
Once that's done, let's get your project running.
Enable the automatic puzzle input downloader by creating a config/secrets.exs
file containing the following:
import Config
config :advent_of_code, AdventOfCode.Input,
allow_network?: true,
session_cookie: "..." # paste your AoC session cookie value here
Fetch dependencies with
mix deps.get
Generate a set of solution and test files for a new year of puzzles with
mix advent.gen -y${YEAR}
Now you can run the solutions with
mix advent.solve -d${DAY} [-p${1 | 2}] [-y${YEAR}] [--bench]
and tests with
mix test
either directly in your local terminal, or in VSCode's terminal pane while connected to a dev container as described below.
Your project generated from this template repository can optionally run in a dev container for remote development.
You have two options:
- Go to the landing page of your generated repo.
- Click the
<> Code
drop-down menu, select the Codespaces tab, and click the big green button. - Wait for the Codespace to build.1
- Once the in-browser editor activates, follow the steps from Usage to enable puzzle downloads and run a solution. (You can use Ctrl+Shift+` to open a terminal pane.)
Requires Docker Desktop or an alternative Docker-compliant CLI, like podman.
Simply open the project directory locally in VS Code. It will show a popup asking if you want to use the Dev Container. It will then guide you through getting set up, building the container image, and connecting to the running dev container.
Footnotes
-
If you decide to stick with Codespaces, consider configuring prebuilds for your project to speed up build time. ↩