Skip to content

Commit f5fb0a8

Browse files
authored
README: Update with memo-specific info (#45)
#### Problem The memo program now lives here, but the documentation is mostly still the generated content. #### Summary of changes Update the README with: * more specific program info * program and docs badges * doc link * audit link
1 parent 526ec64 commit f5fb0a8

File tree

1 file changed

+29
-33
lines changed

1 file changed

+29
-33
lines changed

README.md

Lines changed: 29 additions & 33 deletions
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,28 @@
1-
# Memo
1+
# SPL Memo Program
22

33
<a href="https://github.com/solana-program/memo/actions/workflows/main.yml"><img src="https://img.shields.io/github/actions/workflow/status/solana-program/memo/main.yml?logo=GitHub" /></a>
4+
<a href="https://crates.io/crates/spl-memo"><img src="https://img.shields.io/crates/v/spl-memo?logo=rust" /></a>
5+
[![Docs.rs](https://docs.rs/spl-memo/badge.svg?logo=rust)]
6+
<a href="https://crates.io/crates/spl-memo-client"><img src="https://img.shields.io/crates/v/spl-memo-client?logo=rust" /></a>
47
<a href="https://explorer.solana.com/address/MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr"><img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fraw.githubusercontent.com%2Fsolana-program%2Fmemo%2Fmain%2Fprogram%2Fidl.json&query=%24.version&label=program&logo=&color=9945FF" /></a>
58
<a href="https://www.npmjs.com/package/@solana-program/memo"><img src="https://img.shields.io/npm/v/%40solana-program%2Fmemo?logo=npm&color=377CC0" /></a>
6-
<a href="https://crates.io/crates/spl-memo-client"><img src="https://img.shields.io/crates/v/spl-memo-client?logo=rust" /></a>
79

8-
This template should help get you started developing Solana programs. Let's walk through this generated program repository and see what's included.
10+
A simple program that validates a string of UTF-8 encoded characters and logs it
11+
in the transaction log. The program also verifies that any accounts provided are
12+
signers of the transaction, and if so, logs their addresses. It can be used to
13+
record a string on-chain, stored in the instruction data of a successful
14+
transaction, and optionally verify the originator.
15+
16+
This code was moved from the
17+
[solana-program-library](https://github.com/solana-labs/solana-program-library/tree/master/memo)
18+
and is now maintained in this repo.
19+
20+
Full documentation is available at https://spl.solana.com/memo
21+
22+
## Audit
23+
24+
The [security-audits repo](https://github.com/solana-labs/security-audits) contains
25+
all past and present program audits.
926

1027
## Project setup
1128

@@ -15,13 +32,12 @@ The first thing you'll want to do is install NPM dependencies which will allow y
1532
pnpm install
1633
```
1734

18-
## Managing programs
35+
## Program
1936

20-
You'll notice a `program` folder in the root of this repository. This is where your generated Solana program is located.
37+
The `program` folder in the root of this repository contains the program
38+
implementation.
2139

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

2642
```sh
2743
pnpm programs:build
@@ -32,24 +48,24 @@ pnpm programs:lint
3248

3349
## Generating IDLs
3450

35-
You may use the following command to generate the IDLs for your programs.
51+
You may use the following command to generate the IDLs.
3652

3753
```sh
3854
pnpm generate:idls
3955
```
4056

41-
Depending on your program's framework, this will either use Shank or Anchor to generate the IDLs.
42-
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.
57+
Note that, to ensure IDLs are generated using the correct framework version, the
58+
specific version used by the program will be downloaded and used locally.
4359

4460
## Generating clients
4561

46-
Once your programs' IDLs have been generated, you can generate clients for them using the following command.
62+
Once the program's IDL has been generated, you can generate clients for them using the following command.
4763

4864
```sh
4965
pnpm generate:clients
5066
```
5167

52-
Alternatively, you can use the `generate` script to generate both the IDLs and the clients at once.
68+
Alternatively, you can use the `generate` script to generate both the IDL and the clients at once.
5369

5470
```sh
5571
pnpm generate
@@ -81,23 +97,3 @@ Finally, you may stop the local validator using the following command.
8197
```sh
8298
pnpm validator:stop
8399
```
84-
85-
## Using external programs in your validator
86-
87-
If your program requires any external programs to be running, you'll want to in your local validator.
88-
89-
You can do this by adding their program addresses to the `program-dependencies` array in the `Cargo.toml` of your program.
90-
91-
```toml
92-
program-dependencies = [
93-
"metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s",
94-
"noopb9bkMVfRPU8AsbpTUg8AQkHtKwMYZiFUjNRtMmV",
95-
]
96-
```
97-
98-
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.
99-
100-
```sh
101-
pnpm programs:build
102-
pnpm validator:restart
103-
```

0 commit comments

Comments
 (0)