@nguyenhuu/adventofcode v1.1.1
Advent of Code Runner
A CLI tool to help you run and test your Advent of Code solutions across different programming languages.
Features
- ๐ Run solutions in multiple languages (Python, JavaScript, Java, C++, Ruby)
- ๐ Watch mode for automatic re-runs
- ๐จ Beautiful terminal UI with spinners and colors
- ๐ก Auto-fetch puzzle inputs
- ๐งช Test your solutions with sample/real inputs
- ๐ Track your progress and performance
Installation
You can use the tool in two ways:
Option 1: Using npx (Recommended)
# Run directly without installation
npx @nguyenhuu/adventofcode
# Or with specific command
npx @nguyenhuu/adventofcode --year 2024 --day 1 --part 1 --language pythonOption 2: Global Installation
# Install globally
npm install -g @nguyenhuu/adventofcode
# Run the tool
adventofcodeSetup
Save your session cookie into .env file in the root folder:
SESSION=f8fe3ed61...The
sessioncookie can be found in Developer Tools > Application tab > Cookies >https://adventofcode.com(requires login)The CLI requires your Advent of Code session token to:
- Fetch puzzle inputs for your account
- Display your username and star count
- Submit your answers to the Advent of Code website
Usage
Basic Examples
# Using npx
npx @nguyenhuu/adventofcode --year 2024 --day 1 --part 1 --language python
# Or with global installation
adventofcode --year 2024 --day 1 --part 1 --language pythonInteractive Mode
# Using npx
npx @nguyenhuu/adventofcode
# Or with global installation
adventofcode
# The tool will prompt for missing information:
? Select programming language: (Use arrow keys)
โฏ Python
Javascript
Java
C++
Ruby
? Select year: 2024
? Select day: 1
? Select part: (Use arrow keys)
โฏ Part 1
Part 2 Submitting Solutions
- Run your solution
- Press
uto submit the result - The tool will:
- Submit your answer
- Show if it's correct
- Display your progress
Options
--year: The year of the challenge (e.g., 2024)--day: The day of the challenge (1-25)--part: The part of the challenge (1 or 2)--language: Programming language (python, javascript, java, cpp, golang, ruby)--disable-telemetry: Disable anonymous usage tracking--help: Show help information
Hotkeys
- s: Use sample.txt as input
- i: Use input.txt as input
- u: Submit the most recent result
- 1-9: Select part
- c: Clear terminal
- q: Quit program
- x: Terminate solution
- Enter: Re-run solution
- h: Show help
Folder Structure
current/
โโโ 2023/
โ โโโ day1/
โ โโโ sample.txt
โ โโโ part1.py
โโโ .env
Telemetry
This application collects anonymous usage data to help improve the user experience. The data collected includes:
- Event types (execution, submission, input fetch, key press)
- Basic context (year, day, part, language, input mode)
- Application version and platform
No personal information is collected. The data is used to:
- Understand usage patterns
- Identify common issues
- Guide future improvements
Opting Out
You can opt out of telemetry in two ways:
Using the command line option:
--disable-telemetryUsing an environment variable:
DISABLE_TELEMETRY=true
Development
Prerequisites
- Node.js >= 20
- pnpm >= 10
Setup
This project uses pnpm for package management. If you haven't installed pnpm yet, you can do so globally with:
npm install -g pnpmThen, install the project dependencies:
pnpm install# Clone the repository
git clone https://github.com/nguyenhuuit/adventofcode-runner.git
cd adventofcode-runner
# Install dependencies
pnpm install
# Build the project
pnpm run buildAvailable Scripts
pnpm start: Builds the project and runs the main script.pnpm start:dev: Runs the project in development mode.pnpm lint: Lints the source files.pnpm lint:fix: Lints and fixes issues in the source files.pnpm format: Formats the source files using Prettier.pnpm format:check: Checks if the source files are formatted correctly.pnpm test: Runs the tests using Jest.
Project Structure
src/
โโโ components/ # React components for UI
โโโ drivers/ # Language-specific drivers
โโโ hooks/ # React hooks
โโโ utils/ # Utility functionsContributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'feat: add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
6 months ago
7 months ago
7 months ago
7 months ago
6 months ago
7 months ago
7 months ago
7 months ago
7 months ago
6 months ago
7 months ago
6 months ago
7 months ago
7 months ago
6 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
6 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
7 months ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago