# Guess That Lang!
[![Share Your High Score](https://img.shields.io/badge/-Share%20Your%20High%20Score!-blue?style=for-the-badge&logo=github&logoColor=black)](https://github.com/Lioness100/guess-that-lang/discussions/6)
CLI game to see how fast you can guess the language of a code block!
_If you like
the game, please consider giving a ⭐!_
![Game Demo](https://user-images.githubusercontent.com/65814829/183973036-c283d147-8061-40c8-a306-916801d6c9bc.gif)
Code is retrieved from either random repos or random gists on GitHub
using any of the top 24* most popular languages from the [Stack Overflow 2022
Developer
Survey](https://survey.stackoverflow.co/2022/#most-popular-technologies-language).
*VBA is replaced with Dockerfile
The code is then processed in a number of ways to make the
experience more enjoyable.
## Installation
Using Prebuilt Binaries
-
With Bash
```sh
curl -fsSL "https://bina.egoist.dev/Lioness100/guess-that-lang" | sh
```
> Using [Bina](https://bina.egoist.dev/)
-
Manual Installation
Prebuilt binaries are available for Windows, Linux, and macOS and can be found
attached to the [latest release](https://github.com/Lioness100/guess-that-lang/releases/latest).
Building From Source
> ⚠️ Rust 1.63.0 or higher is required to build. Rust can be updated with `rustup update`.
Install [Rust](https://www.rust-lang.org/tools/install) and then run:
```sh
cargo install guess-that-lang
```
## Usage
It's strongly recommended to provide a [Github personal access token](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token). This will
allow the game to make more Github requests before getting ratelimited. [Click
here to make
one](https://github.com/settings/tokens/new?description=Guess%20That%20Lang) (no
scopes are required).
> ⚠️ Resizing the terminal window while playing will cause the game to go a bit
> wonky.
```sh
# Tokens will be stored in a config file so you only need to input them once.
guess-that-lang --token "XXX" # or -t
# Get code from gists rather than repos.
# Repos generally provide better code quality, but gists require less API calls.
guess-that-lang --provider gists # or -p
# Wait 5 seconds after showing the options before starting to reveal code. (Default: 1500)
guess-that-lang --wait 5000 # or -w
# Reveal lines in random order instead of top to bottom. (Default: false)
guess-that-lang --shuffle # or -s
# Theme overrides will be stored in a config file so you only need to input them once.
guess-that-lang --theme dark
guess-that-lang --theme light
```
## Acknowledgements
This game takes heavy inspiration from both
[guessthiscode](https://guessthiscode.com) and
[stripcode](https://github.com/benawad/stripcode).
## Contributing
I'm a beginner at Rust, so if you see any code that can be improved or have any
general ideas, please let
me know! Feel free to open an issue or a pull request.