Skip to content

Commit

Permalink
Write generated READMEs
Browse files Browse the repository at this point in the history
  • Loading branch information
lorisleiva committed Mar 7, 2024
1 parent dfff36a commit c67062b
Show file tree
Hide file tree
Showing 8 changed files with 166 additions and 11 deletions.
5 changes: 5 additions & 0 deletions .changeset/funny-lamps-relax.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"create-solana-program": patch
---

Write generated READMEs
109 changes: 107 additions & 2 deletions template/base/README.md.njk
Original file line number Diff line number Diff line change
@@ -1,6 +1,34 @@
# {{ programName | titleCase }}

TODO
{# TODO: Uncomment when CI is generated. #}
{# <a href="https://github.com/{{ organizationName }}/{{ programName }}/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/{{ organizationName }}/{{ programName }}/main.yml?logo=GitHub" /></a> #}
<a href="https://explorer.solana.com/address/{{ programAddress }}"><img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fraw.githubusercontent.com%2F{{ organizationName }}%2F{{ programName }}%2Fmain%2Fprogram%2Fidl.json&query=%24.version&label=program%20version&logo=&color=9945FF" /></a>
{% if clients.includes('js') %}
<a href="https://www.npmjs.com/package/@{{ organizationName }}/{{ jsClientPackageName }}"><img src="https://img.shields.io/npm/v/%40{{ organizationName }}%2F{{ jsClientPackageName }}?logo=npm&color=377CC0" /></a>
{% endif %}
{% if clients.includes('rust') %}
<a href="https://crates.io/crates/{{ rustClientCrateName }}"><img src="https://img.shields.io/crates/v/{{ rustClientCrateName }}?logo=rust" /></a>
{% else %}
<a href="https://crates.io/crates/{{ programCrateName }}"><img src="https://img.shields.io/crates/v/{{ programCrateName }}?logo=rust" /></a>
{% endif %}

This template should help get you started developing Solana programs. Let's walk through this generated program repository and see what's included.

## Project setup

The first thing you'll want to do is install NPM dependencies which will allow you to access all the scripts and tools provided by this template.

```sh
{{ getNpmCommand("install") }}
```

## Managing programs

You'll notice a `program` folder in the root of this repository. This is where your generated Solana program is located.

Whilst only one program gets generated, not that you can have as many programs as you like in this repository.
Whenever you add a new program folder to this repository, remember to add it to the `members` array of your root `Cargo.toml` file.
That way, your programs will be recognized by the following scripts that allow you to build, test, format and lint your programs respectively.

```sh
{{ getNpmCommand("programs:build") }}
Expand All @@ -9,4 +37,81 @@ TODO
{{ getNpmCommand("programs:lint") }}
```

TODO
## Generating IDLs

You may use the following command to generate the IDLs for your programs.

```sh
{{ getNpmCommand("generate:idls") }}
```

Depending on your program's framework, this will either use Shank or Anchor to generate the IDLs.
Note that, to ensure IDLs are generated using the correct framework version, the specific version used by the program will be downloaded and used locally.

{% if clients.length > 0 %}
## Generating clients

Once your programs' IDLs have been generated, you can generate clients for them using the following command.

```sh
{{ getNpmCommand("generate:clients") }}
```

Alternatively, you can use the `generate` script to generate both the IDLs and the clients at once.

```sh
{{ getNpmCommand("generate") }}
```

## Managing clients

The following clients are available for your programs. You may use the following links to learn more about each client.

{% for client in clients %}
{% if ['js'].includes(client) %}
- [{{ client | upper }} client](./clients/{{ client }})
{% else %}
- [{{ client | titleCase }} client](./clients/{{ client }})
{% endif %}
{% endfor %}

## Starting and stopping the local validator

The following script is available to start your local validator.

```sh
{{ getNpmCommand("validator") }}
```

By default, if a local validator is already running, the script will be skipped. You may use the `--restart` flag to force the validator to restart.

```sh
{{ getNpmCommand("validator", "--restart") }}
```

Finally, you may stop the local validator using the following command.

```sh
{{ getNpmCommand("validator:stop") }}
```

## Using external programs in your validator

If your program requires any external programs to be running, you'll want to in your local validator.

You can do this by adding their program addresses to the `program-dependencies` array in the `Cargo.toml` of your program.

```toml
program-dependencies = [
"metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s",
"noopb9bkMVfRPU8AsbpTUg8AQkHtKwMYZiFUjNRtMmV",
]
```

Next time you build your program and run your validator, these external programs will automatically be fetched from mainnet and used in your local validator.

```sh
{{ getNpmCommand("programs:build") }}
{{ getNpmCommand("validator", "--restart") }}
```
{% endif %}
3 changes: 0 additions & 3 deletions template/clients/js/clients/js/README.md

This file was deleted.

38 changes: 38 additions & 0 deletions template/clients/js/clients/js/README.md.njk
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
# JavaScript client

A generated JavaScript library for the {{ programName | titleCase }} program.

## Getting started

To build and test your JavaScript client from the root of the repository, you may use the following command.

```sh
{{ getNpmCommand("clients:js:test") }}
```

This will start a new local validator, if one is not already running, and run the tests for your JavaScript client.

## Available client scripts.

Alternatively, you can go into the client directory and run the tests directly.

```sh
# Build your programs and start the validator.
{{ getNpmCommand("programs:build") }}
{{ getNpmCommand("validator") }}

# Go into the client directory and run the tests.
cd clients/js
{{ getNpmCommand("install") }}
{{ getNpmCommand("build") }}
{{ getNpmCommand("test") }}
```

You may also use the following scripts to lint and/or format your JavaScript client.

```sh
{{ getNpmCommand("lint") }}
{{ getNpmCommand("lint:fix") }}
{{ getNpmCommand("format") }}
{{ getNpmCommand("format:fix") }}
```
3 changes: 0 additions & 3 deletions template/clients/rust/clients/rust/README.md

This file was deleted.

13 changes: 13 additions & 0 deletions template/clients/rust/clients/rust/README.md.njk
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# Rust client

A generated Rust library for the {{ programName | titleCase }} program.

## Getting started

To build and test your Rust client from the root of the repository, you may use the following command.

```sh
{{ getNpmCommand("clients:js:test") }}
```

This will start a new local validator, if one is not already running, and run the tests for your Rust client.
3 changes: 0 additions & 3 deletions template/programs/counter-shank/program/README.md

This file was deleted.

3 changes: 3 additions & 0 deletions template/programs/counter-shank/program/README.md.njk
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# {{ programName | titleCase }}

Your generated Solana program. Have fun!

0 comments on commit c67062b

Please sign in to comment.