Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/salvobonsma/aoc-ts
https://github.com/salvobonsma/aoc-ts
Last synced: 18 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/salvobonsma/aoc-ts
- Owner: salvobonsma
- Created: 2024-12-01T03:17:50.000Z (about 1 month ago)
- Default Branch: main
- Last Pushed: 2024-12-02T00:04:02.000Z (about 1 month ago)
- Last Synced: 2024-12-02T01:19:34.485Z (about 1 month ago)
- Language: TypeScript
- Size: 45.9 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# ts-aoc-starter
## Video On How To Use This Starter
[Watch the video](https://www.youtube.com/watch?v=st6Yq-19bW8)
## Running the Puzzles
Provide your solution to the first part of everyday in the `day-X/a.ts` file (where `X` is the day number!):
`ts
import { runSolution } from '../utils.ts';/** provide your solution as the return of this function */
export async function day1a(data: string[]) {
console.log(data);
return 0;
}await runSolution(day1a);
`Copy and paste your unique actual data set into the `day-X/a.data.txt` file. To run your solution against this data set, you can run:
- `nx day-X-a`
- or `nx X-a`
- or `nx X`.You can copy and paste the sample data given in the problem into the `day-X/a.data.sample.txt` file, and run it with the command:
- `nx day-X-a-sample`
- or `nx X-a-sample`
- or `nx X-sample`.If you want to provide an additional data set, you can create a file following the format: `day-X/a.data.{DATA_SET_NAME}.txt`. You can then run your solution against this data set with the command:
- `nx day-X-a-{DATA_SET_NAME}`
- or `nx X-a-{DATA_SET_NAME}`
- or `nx X-{DATA_SET_NAME}`.Usually, each day is split into two parts, in this template, we call it "part A" and "part B". A `day-X/b.ts` file has been provided for you for the second half of each day, as well as a matching set of `data.txt` files for part B. You can run these with the command: `nx day-X-b` or `nx X-b` (note that `nx X` will always only run 'part A'). The same rules apply for providing sample and additional data sets for part B.
Usually part B builds on the solution for part A. Obviously, if it makes sense, you can just continue to create your solution in the 'part A' files and work on from there, ignoring the 'part B' files.
## File Watching
Every command above supports a `watch-` version of the command as well. For example, if you'd like to run your command: `nx day-1-a-sample` and have it re-run whenever a file is saved, you can run the command: `nx watch-day-1-a-sample`.