myusername's solutions for https://adventofcode.com/
Project description
advent-of-code-sample:
Provides a working example plugin structure for using the aoc
runner script provided by advent-of-code-data.
The aoc
runner allows you to easily verify your Advent of Code solutions against multiple datasets, or verify other user's code against your own dataset.
$ cat ~/.config/aocd/tokens.json # create this file with some auth tokens
{
"github": "53616c7465645f5f0775...",
"google": "53616c7465645f5f7238...",
"reddit": "53616c7465645f5ff7c8...",
"twitter": "53616c7465645f5fa524..."
}
$ pip install ~/src/advent-of-code-sample # install the directory which contains your setup.py file
...
$ pip install -q advent-of-code-wim # can also install some other user's code if you want..?
...
$ aoc --years 2015 --days 3 4 11 # run it!
0.25s 2015/3 - Perfectly Spherical Houses in a Vacuum wim/github ✔ part a: 2565 ✔ part b: 2639
0.11s 2015/3 - Perfectly Spherical Houses in a Vacuum wim/google ✔ part a: 2592 ✔ part b: 2360
0.12s 2015/3 - Perfectly Spherical Houses in a Vacuum wim/reddit ✔ part a: 2592 ✔ part b: 2360
0.12s 2015/3 - Perfectly Spherical Houses in a Vacuum wim/twitter ✔ part a: 2565 ✔ part b: 2639
0.12s 2015/3 - Perfectly Spherical Houses in a Vacuum myusername/github ✖ part a: 1234 (expected: 2565) ✖ part b: 5678 (expected: 2639)
0.12s 2015/3 - Perfectly Spherical Houses in a Vacuum myusername/google ✖ part a: 1234 (expected: 2592) ✖ part b: 5678 (expected: 2360)
0.11s 2015/3 - Perfectly Spherical Houses in a Vacuum myusername/reddit ✖ part a: 1234 (expected: 2592) ✖ part b: 5678 (expected: 2360)
0.11s 2015/3 - Perfectly Spherical Houses in a Vacuum myusername/twitter ✖ part a: 1234 (expected: 2565) ✖ part b: 5678 (expected: 2639)
9.04s 2015/4 - The Ideal Stocking Stuffer wim/github ✔ part a: 254575 ✔ part b: 1038736
25.43s 2015/4 - The Ideal Stocking Stuffer wim/google ✔ part a: 117946 ✔ part b: 3938038
12.20s 2015/4 - The Ideal Stocking Stuffer wim/reddit ✔ part a: 254575 ✔ part b: 1038736
47.67s 2015/4 - The Ideal Stocking Stuffer wim/twitter ✔ part a: 282749 ✔ part b: 9962624
0.12s 2015/4 - The Ideal Stocking Stuffer myusername/github ✖ part a: 1234 (expected: 254575) ✖ part b: 5678 (expected: 1038736)
0.12s 2015/4 - The Ideal Stocking Stuffer myusername/google ✖ part a: 1234 (expected: 117946) ✖ part b: 5678 (expected: 3938038)
0.12s 2015/4 - The Ideal Stocking Stuffer myusername/reddit ✖ part a: 1234 (expected: 254575) ✖ part b: 5678 (expected: 1038736)
0.12s 2015/4 - The Ideal Stocking Stuffer myusername/twitter ✖ part a: 1234 (expected: 282749) ✖ part b: 5678 (expected: 9962624)
6.17s 2015/11 - Corporate Policy wim/github ✔ part a: vzbxxyzz ✔ part b: vzcaabcc
6.26s 2015/11 - Corporate Policy wim/google ✔ part a: cqjxxyzz ✔ part b: cqkaabcc
4.69s 2015/11 - Corporate Policy wim/reddit ✔ part a: hxbxxyzz ✔ part b: hxcaabcc
5.75s 2015/11 - Corporate Policy wim/twitter ✔ part a: hxbxxyzz ✔ part b: hxcaabcc
0.11s 2015/11 - Corporate Policy myusername/github ✖ part a: 1234 (expected: vzbxxyzz) ✖ part b: 5678 (expected: vzcaabcc)
0.12s 2015/11 - Corporate Policy myusername/google ✖ part a: 1234 (expected: cqjxxyzz) ✖ part b: 5678 (expected: cqkaabcc)
0.11s 2015/11 - Corporate Policy myusername/reddit ✖ part a: 1234 (expected: hxbxxyzz) ✖ part b: 5678 (expected: hxcaabcc)
0.12s 2015/11 - Corporate Policy myusername/twitter ✖ part a: 1234 (expected: hxbxxyzz) ✖ part b: 5678 (expected: hxcaabcc)
How to hook into your code:
The aoc
runner uses setuptools' dynamic discovery of services and plugins feature to locate and run your code.
Define your plugin's entry point in setup.py
. The group name to use is "adventofcode.user":
# setup.py
from setuptools import setup
setup(
...
entry_points={"adventofcode.user": ["myusername = mypackage:mysolve"]},
)
Change mypackage
to whatever package or module name is used to import your stuff.
The name mysolve
should resolve to a callable in your package's namespace which accepts three named arguments year
, day
, data
(any order ok) and returns two values, e.g.:
def mysolve(year, day, data):
...
return part_a_answer, part_b_answer
Inside the entry-point you can do whatever you need in order to delegate to your code. For example, write out data to a scratch file then run a script, or import a function and just pass in the data directly as an argument. The only requirement is that this entry-point should return a tuple of two values, with the answers for that day's puzzle, the rest is up to you. You could fork this repo and edit it, or just write your own plugin manually.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file advent_of_code_sample-0.1-py2.py3-none-any.whl
.
File metadata
- Download URL: advent_of_code_sample-0.1-py2.py3-none-any.whl
- Upload date:
- Size: 5.0 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.2 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.7.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cf0fd2642c47058e362bb6fdce3a84f812b9e83ce91bb9842c48a8474a7add68 |
|
MD5 | fc7ea8cfdc3e54c93a4556b51e17aeb8 |
|
BLAKE2b-256 | 6bad63afa3eb7b5b2ad4fbe4ea20c591b4694b9e616583f05cd6d00d52215069 |