Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/akosasante/advent-of-code-helper-elixir
Access your advent of code inputs, right from elixir!
https://github.com/akosasante/advent-of-code-helper-elixir
advent-of-code elixir hex-package
Last synced: about 2 months ago
JSON representation
Access your advent of code inputs, right from elixir!
- Host: GitHub
- URL: https://github.com/akosasante/advent-of-code-helper-elixir
- Owner: akosasante
- License: mit
- Created: 2017-08-06T11:04:14.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2022-12-02T22:47:29.000Z (about 2 years ago)
- Last Synced: 2024-06-07T10:40:02.854Z (7 months ago)
- Topics: advent-of-code, elixir, hex-package
- Language: Elixir
- Homepage:
- Size: 90.8 KB
- Stars: 8
- Watchers: 1
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Advent of Code Helper [![Build Status](https://app.travis-ci.com/akosasante/Advent-Of-Code-Helper-Elixir.svg?branch=main)](https://app.travis-ci.com/github/akosasante/Advent-Of-Code-Helper-Elixir) [![codecov](https://codecov.io/gh/akosasante/Advent-Of-Code-Helper-Elixir/branch/main/graph/badge.svg?token=vssP39GcoL)](https://codecov.io/gh/akosasante/Advent-Of-Code-Helper-Elixir) [![Hex.pm](https://img.shields.io/hexpm/v/advent_of_code_helper.svg?style=plastic)](https://hex.pm/packages/advent_of_code_helper) [![hexdocs.pm](https://img.shields.io/badge/hex-docs-lightgreen.svg)](https://hexdocs.pm/advent_of_code_helper/api-reference.html)
This Elixir package allows you to quickly grab inputs for Advent of ode puzzles, and not have to worry about manually pasting them in! After you've got a puzzle input for the first time, the result is stored on disk so every subsequent request bypasses the need to download it from the server again.
## Usage
### Via Mix Tasks
There are two mix tasks included in this library: `advent.setup_day` and `advent.run_day`.
For creating a new directory and `.ex` file for a given Advent puzzle, use the setup command:
`mix advent.setup_day ` or `mix advent.setup_day `
where year is a four-digit integer (eg: 2022) and day is a number between 1 and 25. Year will be inferred as the current year if it's not passed in. A folder will be created under the `lib` directory of the mix project, and a skeleton module will be generated.
To run the code you've added to the generated template file, use the run command:
`mix advent.run_day day= year= bench= split= sep= trim=`
Only `day` is a required argument. `Year` will be inferred as current year if it's not given, otherwise it should be a 4-digit number.
If bench is `true`, the task will run the day's puzzles through [benchee](https://github.com/bencheeorg/benchee) and return the benchmark results.By default, (if no `split` or `sep` options are passed in), the puzzle input will be read as a string, split on newlines, and the resulting list will be passed into the puzzle module to be run.
You can change this behaviour by passing in either `list`, `stream`, or `false` for split. This will split the string into a List, a Stream, or leave the input as-is, respectively. The separator to use as the split boundary can be changed by passing in a `sep` argument; trimming extra newlines/whitespace can be enabled by setting `trim` to `true`.### Directly calling AdventOfCodeHelper
There are two main functions for fetching the puzzle input:
```elixir
AdventOfCodeHelper.get_input(year,day) # Specify year and day for puzzleAdventOfCodeHelper.get_input(day) # Automatically gets puzzle from most recent year
```
Both of these functions will simply return a tuple `{:ok, value}` if they succeed, where `value` is the puzzle input in the form of a `String`, or `{:fail, message}` if there was something wrong.
You can also use the provided helpers for splitting the string input into a List or Stream: `split_to_list/2` and `split_to_stream/2`.
### Configuration
There are two configuration directives that are also needed to make this package work correctly. Simply add the following to your `config/config.exs`
```elixir
config :advent_of_code_helper,
session: "",
cache_dir: ".cache/" # this is a sensible default, but feel free to put it wherever you have write access
```The session string will need to be taken from [adventofcode.com](https://adventofcode.com), it will be under cookies as `session`. You can extract the value using the inspector/devTools in your browser of choice.
## Installation
This package can be installed by adding `advent_of_code_helper` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:advent_of_code_helper, "~> 0.3.1"}
]
end
```