Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve the UX of README command codeblocks #698

Merged
merged 1 commit into from
Oct 18, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 8 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,15 @@ demonstrate how to package your buildpack and how to build an application image
### Development Environment Setup

In addition to the libcnb crate, we need some tools to compile, package and run the buildpack. These steps only need to
be carried out once and don't need to be repeated for each buildpack you will write.
be carried out once and don't need to be repeated for each buildpack you will write.

#### libcnb Cargo Command

Start by installing [libcnb-cargo](https://crates.io/crates/libcnb-cargo), which provides the `libcnb` Cargo command
that we will use later to package our buildpack:

```shell
$ cargo install libcnb-cargo
cargo install libcnb-cargo
```

#### Cross-compilation prerequisites
Expand All @@ -42,7 +42,7 @@ up your environment depending on your host platform, but we always need the appr
we can install with `rustup`:

```shell
$ rustup target add x86_64-unknown-linux-musl
rustup target add x86_64-unknown-linux-musl
```

#### Docker
Expand All @@ -62,14 +62,13 @@ After we've successfully set up our development environment, we can move on and
buildpack. First, we create a new binary crate with Cargo:

```shell
$ cargo new my-buildpack
Created binary (application) `my-buildpack` package
cargo new my-buildpack
```

Then, add the `libcnb` dependency to your project's `Cargo.toml`:

```shell
$ cargo add libcnb
cargo add libcnb
```

Note: If you get an error about `cargo add` not being a supported command, make sure you are
Expand Down Expand Up @@ -177,7 +176,7 @@ your development environment, you have access to the `libcnb` Cargo command that

In your project directory, run `cargo libcnb package` to start packaging:

```shell
```console
$ cargo libcnb package
🚚 Preparing package directory...
🖥️ Gathering Cargo configuration (for x86_64-unknown-linux-musl)
Expand Down Expand Up @@ -208,7 +207,7 @@ You might have seen in the output that we're now ready to run our buildpack loca
with `pack`. Before we can do this, we need an application to build. Since our buildpack does not interact with the
application code at all, we just create an empty directory and use that as our application:

```shell
```console
$ mkdir bogus-app
$ pack build my-image --buildpack packaged/x86_64-unknown-linux-musl/debug/libcnb-examples_my-buildpack --path bogus-app --builder heroku/builder:22
...
Expand Down Expand Up @@ -241,7 +240,7 @@ Successfully built image my-image
The newly created Docker image can be run in the same way as you would a Docker image created via `docker build`.
If all went well, you should see our "Hello World!" message in your terminal:

```shell
```console
$ docker run my-image
Hello World!
```
Expand Down
6 changes: 3 additions & 3 deletions libcnb-cargo/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,15 @@ A Cargo command for managing buildpacks written with [libcnb.rs](https://github.
## Installation

```shell
$ cargo install libcnb-cargo
cargo install libcnb-cargo
```

## Usage

Currently, there is only one sub-command: `package`. It allows users to package their
Rust buildpack in a spec-compliant manner and helps with cross-compilation.

```shell
```console
$ cargo libcnb package --help
Packages a libcnb.rs Cargo project as a Cloud Native Buildpack

Expand All @@ -30,7 +30,7 @@ Options:
Using it is fairly simple, run `cargo libcnb package` inside the buildpack's
project directory:

```shell
```console
$ cargo libcnb package
🚚 Preparing package directory...
🖥️ Gathering Cargo configuration (for x86_64-unknown-linux-musl)
Expand Down