From de2b8120fd80d3dca558235fd38c4d2abe75ff4c Mon Sep 17 00:00:00 2001 From: Kirpal Grewal Date: Fri, 15 Nov 2024 15:02:00 +0000 Subject: [PATCH 1/2] simplify why cargo exists --- src/doc/src/guide/why-cargo-exists.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/doc/src/guide/why-cargo-exists.md b/src/doc/src/guide/why-cargo-exists.md index 2081944f7ab..b9532dc6136 100644 --- a/src/doc/src/guide/why-cargo-exists.md +++ b/src/doc/src/guide/why-cargo-exists.md @@ -5,7 +5,7 @@ In Rust, as you may know, a library or executable program is called a [*crate*][def-crate]. Crates are compiled using the Rust compiler, `rustc`. When starting with Rust, the first source code most people encounter -is that of the venerable “hello world” program, which they compile by invoking +is that of the classic “hello world” program, which they compile by invoking `rustc` directly: ```console @@ -18,15 +18,15 @@ Note that the above command required that we specify the file name explicitly. If we were to directly use `rustc` to compile a different program, a different command line invocation would be required. If we needed to specify any specific compiler flags or include external dependencies, then the -needed command would be even more specific (and elaborate). +needed command would be even more specific (and complex). Furthermore, most non-trivial programs will likely have dependencies on external libraries, and will therefore also depend transitively on *their* dependencies. Obtaining the correct versions of all the necessary dependencies -and keeping them up to date would be laborious and error-prone if done by +and keeping them up to date would be hard and error-prone if done by hand. -Rather than work only with crates and `rustc`, we can avoid the manual tedium +Rather than work only with crates and `rustc`, we can avoid the difficulties involved with performing the above tasks by introducing a higher-level ["*package*"][def-package] abstraction and by using a [*package manager*][def-package-manager]. @@ -51,9 +51,9 @@ we show later, the same command can be used to build different [*artifacts*][def-artifact], regardless of their names. Rather than invoke `rustc` directly, we can instead invoke something generic such as `cargo build` and let cargo worry about constructing the correct `rustc` -invocation. Furthermore, Cargo will automatically fetch from a -[*registry*][def-registry] any dependencies we have defined for our artifact, -and arrange for them to be incorporated into our build as needed. +invocation. Furthermore, Cargo will automatically fetch any dependencies +we have defined for our artifact from a [*registry*][def-registry], +and arrange for them to be added into our build as needed. It is only a slight exaggeration to say that once you know how to build one Cargo-based project, you know how to build *all* of them. From e95c5a82c5a9ec63fe14a2183d8cc6ab125d2840 Mon Sep 17 00:00:00 2001 From: Kirpal Grewal Date: Fri, 15 Nov 2024 15:12:35 +0000 Subject: [PATCH 2/2] dependencies typo --- src/doc/src/guide/dependencies.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/doc/src/guide/dependencies.md b/src/doc/src/guide/dependencies.md index cbb3ba115d0..150b5f31d4f 100644 --- a/src/doc/src/guide/dependencies.md +++ b/src/doc/src/guide/dependencies.md @@ -13,7 +13,7 @@ To depend on a library hosted on [crates.io], add it to your `Cargo.toml`. If your `Cargo.toml` doesn't already have a `[dependencies]` section, add that, then list the [crate][def-crate] name and version that you would like to -use. This example adds a dependency of the `time` crate: +use. This example adds a dependency on the `time` crate: ```toml [dependencies] @@ -67,7 +67,7 @@ Our `Cargo.lock` contains the exact information about which revision of all of these dependencies we used. Now, if `regex` gets updated, we will still build with the same revision until -we choose to `cargo update`. +we choose to run `cargo update`. You can now use the `regex` library in `main.rs`.