mirror of
https://github.com/rust-lang/rustlings.git
synced 2025-01-09 20:03:24 +03:00
Compare commits
8 commits
b7289e59aa
...
dc5c72bc19
Author | SHA1 | Date | |
---|---|---|---|
dc5c72bc19 | |||
0ce5d9d4d7 | |||
37fcbeb596 | |||
2f071c97b0 | |||
9664f4357c | |||
74ae506603 | |||
2965867338 | |||
e63e668d86 |
85
README.md
85
README.md
|
@ -21,9 +21,12 @@ Before installing Rustlings, you need to have _Rust installed_.
|
||||||
Visit [www.rust-lang.org/tools/install](https://www.rust-lang.org/tools/install) for further instructions on installing Rust.
|
Visit [www.rust-lang.org/tools/install](https://www.rust-lang.org/tools/install) for further instructions on installing Rust.
|
||||||
This'll also install _Cargo_, Rust's package/project manager.
|
This'll also install _Cargo_, Rust's package/project manager.
|
||||||
|
|
||||||
🐧 If you're on Linux, make sure you've installed `gcc` (for a linker). Deb: `sudo apt install build-essential gcc`. Dnf: `sudo dnf install gcc`.
|
> 🐧 If you're on Linux, make sure you've installed `gcc` (for a linker).
|
||||||
|
>
|
||||||
|
> Deb: `sudo apt install gcc`.
|
||||||
|
> Dnf: `sudo dnf install gcc`.
|
||||||
|
|
||||||
🍎 If you're on MacOS, make sure you've installed Xcode and its developer tools by typing `xcode-select --install`.
|
> 🍎 If you're on MacOS, make sure you've installed Xcode and its developer tools by running `xcode-select --install`.
|
||||||
|
|
||||||
### Installing Rustlings
|
### Installing Rustlings
|
||||||
|
|
||||||
|
@ -35,15 +38,16 @@ The following command will download and compile Rustlings:
|
||||||
cargo install rustlings@6.0.0-beta.3
|
cargo install rustlings@6.0.0-beta.3
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Troubleshooting
|
<details>
|
||||||
|
<summary><strong>If the installation fails…</strong> (<em>click to expand</em>)</summary>
|
||||||
If the installation fails…
|
|
||||||
|
|
||||||
<!-- TODO: Remove @6.0.0-beta.x -->
|
<!-- TODO: Remove @6.0.0-beta.x -->
|
||||||
|
|
||||||
- Make sure you have the latest Rust version by running `rustup update`.
|
- Make sure you have the latest Rust version by running `rustup update`
|
||||||
- Try adding the `--locked` flag: `cargo install rustlings --locked`
|
- Try adding the `--locked` flag: `cargo install rustlings@6.0.0-beta.3 --locked`
|
||||||
- Otherwise, please [report an issue](https://github.com/rust-lang/rustlings/issues/new).
|
- Otherwise, please [report the issue](https://github.com/rust-lang/rustlings/issues/new)
|
||||||
|
|
||||||
|
</details>
|
||||||
|
|
||||||
### Initialization
|
### Initialization
|
||||||
|
|
||||||
|
@ -53,7 +57,7 @@ After installing Rustlings, run the following command to initialize the `rustlin
|
||||||
rustlings init
|
rustlings init
|
||||||
```
|
```
|
||||||
|
|
||||||
Now, go into the newly initialized directory and run Rustlings for further instructions on getting started with the exercises:
|
Now, go into the newly initialized directory and launch Rustlings for further instructions on getting started with the exercises:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
cd rustlings/
|
cd rustlings/
|
||||||
|
@ -62,45 +66,40 @@ rustlings
|
||||||
|
|
||||||
## Doing exercises
|
## Doing exercises
|
||||||
|
|
||||||
The exercises are sorted by topic and can be found in the subdirectory `rustlings/exercises/<topic>`.
|
The exercises are sorted by topic and can be found in the subdirectory `exercises/<topic>`.
|
||||||
For every topic there is an additional README file with some resources to get you started on the topic.
|
For every topic, there is an additional `README.md` file with some resources to get you started on the topic.
|
||||||
We really recommend that you have a look at them before you start.
|
We highly recommend that you have a look at them before you start 📚️
|
||||||
|
|
||||||
The task is simple.
|
|
||||||
Most exercises contain an error that keeps them from compiling, and it's up to you to fix it!
|
Most exercises contain an error that keeps them from compiling, and it's up to you to fix it!
|
||||||
Some exercises are also run as tests, but Rustlings handles them all the same.
|
Some exercises contain tests that need to pass for the exercise to be done ✅
|
||||||
To run the exercises in the recommended order, execute:
|
|
||||||
|
|
||||||
```bash
|
### Watch Mode
|
||||||
rustlings
|
|
||||||
```
|
|
||||||
|
|
||||||
This will try to verify the completion of every exercise in a predetermined order (what we think is best for newcomers).
|
After [initialization](#initialization), Rustlings can be launched by simply running the command `rustlings`.
|
||||||
It will also rerun automatically every time you change a file in the `exercises/` directory.
|
|
||||||
|
|
||||||
In case you want to go by your own order, or want to only verify a single exercise, you can run:
|
This will start the _watch mode_ which walks you through the exercises in a predefined order (what we think is best for newcomers).
|
||||||
|
It will rerun the current exercise automatically every time you change the exercise's file in the `exercises/` directory.
|
||||||
|
|
||||||
```bash
|
<details>
|
||||||
rustlings run EXERCISE_NAME
|
<summary><strong>If detecting file changes in the <code>exercises/</code> directory fails…</strong> (<em>click to expand</em>)</summary>
|
||||||
```
|
|
||||||
|
|
||||||
Or simply use the following command to run the next pending exercise in the course:
|
> You can add the **`--manual-run`** flag (`rustlings --manual-run`) to manually rerun the current exercise by entering `r` or `run` in the watch mode.
|
||||||
|
>
|
||||||
|
> Please [report the issue](https://github.com/rust-lang/rustlings/issues/new) with some information about your operating system and whether you run Rustlings in a container or virtual machine (e.g. WSL).
|
||||||
|
|
||||||
```bash
|
</details>
|
||||||
rustlings run
|
|
||||||
```
|
|
||||||
|
|
||||||
In case you get stuck, you can run the following command to get a hint for your exercise:
|
### Exercise List
|
||||||
|
|
||||||
```bash
|
In the [watch mode](#watch-mode) (after launching `rustlings`), you can enter `l` or `list` to open the interactive exercise list.
|
||||||
rustlings hint EXERCISE_NAME
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also get the hint for the next pending exercise with the following command:
|
The list allows you to…
|
||||||
|
|
||||||
```bash
|
- See the status of all exercises (done or pending)
|
||||||
rustlings hint
|
- `c`: Continue at another exercise (temporarily skip some exercises or go back to a previous one)
|
||||||
```
|
- `r`: Reset status and file of an exercise (you need to _reload/reopen_ its file in your editor afterwards)
|
||||||
|
|
||||||
|
See the footer of the list for all possible keys.
|
||||||
|
|
||||||
## Continuing On
|
## Continuing On
|
||||||
|
|
||||||
|
@ -111,25 +110,15 @@ Continue practicing your Rust skills by building your own projects, contributing
|
||||||
|
|
||||||
## Uninstalling Rustlings
|
## Uninstalling Rustlings
|
||||||
|
|
||||||
If you want to remove Rustlings from your system, there are two steps.
|
If you want to remove Rustlings from your system, run the following command:
|
||||||
|
|
||||||
1️⃣ Remove the `rustlings` directory that was created by `rustlings init`:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
rm -r rustlings
|
|
||||||
```
|
|
||||||
|
|
||||||
2️⃣ Run `cargo uninstall` to remove the `rustlings` binary:
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
cargo uninstall rustlings
|
cargo uninstall rustlings
|
||||||
```
|
```
|
||||||
|
|
||||||
That's it!
|
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
See [CONTRIBUTING.md](https://github.com/rust-lang/rustlings/blob/main/CONTRIBUTING.md).
|
See [CONTRIBUTING.md](https://github.com/rust-lang/rustlings/blob/main/CONTRIBUTING.md) 🔗
|
||||||
|
|
||||||
## Contributors ✨
|
## Contributors ✨
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue