Giter VIP home page Giter VIP logo

advent-of-code-typescript-starter's Introduction

Advent of Code Typescript Starter

A template for Advent of Code written in Typescript with Node.

Usage

The project use Node.js as javascript runtime, esbuild as typescript transpiler and swc with Jest for testing.

$ git clone https://github.com/ljgago/advent-of-code-typescript-starter aoc-typescript
$ cd aoc-typescript

# install dependencies
$ npm install

# check syntax with eslint
$ npm run lint day01

# run tests for day01
$ npm test day01

# run the day01
# npm start day01

Generate

You can generate all necesary files for use in the event with a simple command:

$ npm run gen day01

This command generate these files:

* creating src/day01/resources/input.txt
* creating src/day01/index.ts
* creating src/day01/main.ts
* creating src/day01/part1.ts
* creating src/day01/part2.ts
* creating src/day01/README.md
* creating test/day01.test.ts
  • /src/day01/resources/input.txt: the input data.
  • /src/day01/index.ts: export the modules for testing.
  • /src/day01/main.ts: the main module.
  • /src/day01/part1.ts: solution for part 1.
  • /src/day01/part2.ts: solution for part 2.
  • /src/day01/README.md: you can write the challenge statement.
  • /tests/day01.test.ts: the module where you write the tests.

Config

You can configure the automatic input download from the Advent of Code session token.

For dowload the inputs from web, you needs to set the environment var AOC_SESSION. You can to get the session token from the cookie web browser.

Also can you set the AOC_YEAR to select a certain year. (It is not mandatory use the AOC_YEAR, the npm run gen can get the year automatically)

You can set an .env file with these variables.

Folder structure:

├── src
│   └── day01
│       ├── index.ts
│       ├── main.ts
│       ├── part1.ts
│       ├── part2.ts
│       ├── README.md
│       └── resources
│           └── input.txt
└── test
    └── day01.test.ts

Happy coding!

MIT License

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.