Go to file
Dan Albert ffeac298a2
Move from gitbook to docusaurus, build docs in Travis CI (#10970)
* fix: ignore unknown fields in more RPC responses

* Remove mdbook infrastructure

* Delete gitattributes and other theme related items

Move all docs to /docs folder to support Docusaurus

* all docs need to be moved to /docs

* can be changed in the future

Add Docusaurus infrastructure

* initialize docusaurus repo

Remove trailing whitespace, add support for eslint

Change Docusaurus configuration to support `src`

* No need to rename the folder! Change a setting and we're all good to
go.

* Fixing rebase items

* Remove unneccessary markdown file, fix type

* Some fonts are hard to read. Others, not so much. Rubik, you've been
sidelined. Roboto, into the limelight!

* As much as we all love tutorials, I think we all can navigate around a
markdown file. Say goodbye, `mdx.md`.

* Setup deployment infrastructure

* Move docs job from buildkite to travic

* Fix travis config

* Add vercel token to travis config

* Only deploy docs after merge

* Docker rust env

* Revert "Docker rust env"

This reverts commit f84bc208e807aab1c0d97c7588bbfada1fedfa7c.

* Build CLI usage from docker

* Pacify shellcheck

* Run job on PR and new commits for publication

* Update README

* Fix svg image building

* shellcheck

Co-authored-by: Michael Vines <mvines@gmail.com>
Co-authored-by: Ryan Shea <rmshea@users.noreply.github.com>
Co-authored-by: publish-docs.sh <maintainers@solana.com>
2020-07-11 05:11:07 +00:00
.buildkite Buildkite pipeline overhaul 2 (#10529) 2020-06-11 17:34:13 -07:00
.github Stalebot: Exempt 'blocked' label (#10268) 2020-05-27 11:20:45 -07:00
.travis Export unconditionally 2020-06-14 23:31:10 -07:00
account-decoder Explicit spl-memo version (#11003) 2020-07-11 03:41:53 +00:00
accounts-bench chore(deps): bump rayon from 1.3.0 to 1.3.1 (#10605) 2020-07-01 08:09:28 -07:00
banking-bench chore(deps): bump rayon from 1.3.0 to 1.3.1 (#10605) 2020-07-01 08:09:28 -07:00
bench-exchange chore(deps): bump rayon from 1.3.0 to 1.3.1 (#10605) 2020-07-01 08:09:28 -07:00
bench-streamer Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
bench-tps chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
ci Move from gitbook to docusaurus, build docs in Travis CI (#10970) 2020-07-11 05:11:07 +00:00
clap-utils Add generic is_parsable() input validator. 2020-06-15 09:30:39 -07:00
cli chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
cli-config Permit users to assign labels to account addresses 2020-06-18 18:46:49 +00:00
client getConfirmedBlocks now has an upper limit on slot range 2020-07-10 12:18:31 -07:00
core Simplify use of SendTransactionService (#10999) 2020-07-11 01:14:41 +00:00
crate-features Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
docs Move from gitbook to docusaurus, build docs in Travis CI (#10970) 2020-07-11 05:11:07 +00:00
dos chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
download-utils Move BankForks to solana_runtime (#10637) 2020-06-17 15:27:03 +00:00
explorer chore(deps): bump @types/react from 16.9.41 to 16.9.42 in /explorer (#10998) 2020-07-10 19:45:47 +00:00
faucet chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
genesis Move BankForks to solana_runtime (#10637) 2020-06-17 15:27:03 +00:00
genesis-programs Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
gossip Refactor gossip code from one huge function (#10701) 2020-06-18 22:20:52 -07:00
install chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
keygen Remove fee-payer guesswork from Message and Transaction (#10776) 2020-06-24 14:52:38 -06:00
ledger Add block time placeholder to getConfirmedBlock 2020-07-10 14:47:11 +00:00
ledger-tool Add --print-account-stats/--snapshot-archive-path arguments to ledger-tool (#10945) 2020-07-08 09:32:11 -07:00
local-cluster Consistently create temp dirs under ledger/farf (#10848) 2020-07-01 11:38:59 +09:00
log-analyzer Bump serde from 1.0.111 to 1.0.112 2020-06-15 07:58:16 -07:00
logger Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
measure Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
merkle-tree Fix typos (#10675) 2020-06-17 20:54:52 -07:00
metrics Switch to using weighted repair in RepairService (#10735) 2020-07-10 05:52:54 +00:00
multinode-demo Allow pre-existing stake accounts in multinode-demo/delegate-stake.sh 2020-06-16 15:45:25 -06:00
net Steal dumoulin from colo for TdS 2020-07-03 20:30:44 +00:00
net-shaper Bump serde from 1.0.111 to 1.0.112 2020-06-15 07:58:16 -07:00
net-utils chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
notifier Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
perf chore(deps): bump bincode from 1.2.1 to 1.3.1 (#10867) 2020-07-09 00:08:05 +00:00
poh-bench Add poh-bench (#10707) 2020-06-24 15:51:52 -07:00
programs Fix warnings (#10992) 2020-07-10 20:02:55 +00:00
ramp-tps Remove fee-payer guesswork from Message and Transaction (#10776) 2020-06-24 14:52:38 -06:00
rayon-threadlimit Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
remote-wallet chore(deps): bump hidapi from 1.2.2 to 1.2.3 (#10866) 2020-07-01 08:08:47 -07:00
runtime Simplify use of SendTransactionService (#10999) 2020-07-11 01:14:41 +00:00
scripts Make test-checks.sh helpful and cargo-for-all-lock-files.sh useful (#10906) 2020-07-03 18:08:12 +09:00
sdk spl memo linking windows (#11000) 2020-07-10 18:39:52 -07:00
stake-accounts Rename Client methods to match proposed BanksClient (#10793) 2020-06-25 03:35:38 +00:00
stake-monitor Update struct prefixes to Ui (#10874) 2020-07-01 20:06:40 +00:00
stake-o-matic Add MB validators to SOM (#10977) 2020-07-09 23:43:48 +00:00
streamer Reduce responder error prints (#10664) 2020-06-18 13:30:55 -07:00
sys-tuner Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
system-test Steal dumoulin from colo for TdS 2020-07-03 20:30:44 +00:00
tokens Rename Client methods to match proposed BanksClient (#10793) 2020-06-25 03:35:38 +00:00
transaction-status Explicit spl-memo version (#11003) 2020-07-11 03:41:53 +00:00
upload-perf Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
validator Decouple genesis fetch and snapshot fetch (#10931) 2020-07-06 16:09:12 -07:00
version Introduce automatic ABI maintenance mechanism (2/2; rollout) (#8012) 2020-07-06 20:22:23 +09:00
vote-signer Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
watchtower Update struct prefixes to Ui (#10874) 2020-07-01 20:06:40 +00:00
web3.js fix: ignore unknown fields in more RPC responses 2020-07-11 03:39:49 +00:00
.clippy.toml
.codecov.yml
.gitbook.yaml Add staking guide to docs (#10609) 2020-06-24 09:25:35 -06:00
.gitignore Generate CLI usage (#8637) 2020-03-04 17:44:30 -07:00
.mergify.yml Gate automerge on Travis 2020-07-08 10:36:38 -07:00
.travis.yml Move from gitbook to docusaurus, build docs in Travis CI (#10970) 2020-07-11 05:11:07 +00:00
CONTRIBUTING.md
Cargo.lock spl memo linking windows (#11000) 2020-07-10 18:39:52 -07:00
Cargo.toml Add account-decoder utilities (#10846) 2020-07-01 04:55:11 +00:00
LICENSE Change documentation introduction to indicate Foundation IP transfer (#10440) 2020-06-13 14:41:05 -07:00
README.md Update link 2020-04-18 15:11:55 -07:00
RELEASE.md Change release docs to use CI when bumping the version (#10856) 2020-06-30 12:58:46 -07:00
fetch-perf-libs.sh Simd poh (#10604) 2020-06-16 23:03:26 -07:00
run.sh Support ad-hoc genesis args in run.sh (#9697) 2020-04-23 22:48:53 -07:00

README.md

Solana

Solana crate Solana documentation Build status codecov

Building

1. Install rustc, cargo and rustfmt.

$ curl https://sh.rustup.rs -sSf | sh
$ source $HOME/.cargo/env
$ rustup component add rustfmt

If your rustc version is lower than 1.39.0, please update it:

$ rustup update

On Linux systems you may need to install libssl-dev, pkg-config, zlib1g-dev, etc. On Ubuntu:

$ sudo apt-get update
$ sudo apt-get install libssl-dev libudev-dev pkg-config zlib1g-dev llvm clang

2. Download the source code.

$ git clone https://github.com/solana-labs/solana.git
$ cd solana

3. Build.

$ cargo build

4. Run a minimal local cluster.

$ ./run.sh

Testing

Run the test suite:

$ cargo test

Starting a local testnet

Start your own testnet locally, instructions are in the online docs.

Accessing the remote testnet

  • testnet - public stable testnet accessible via devnet.solana.com. Runs 24/7

Benchmarking

First install the nightly build of rustc. cargo bench requires use of the unstable features only available in the nightly build.

$ rustup install nightly

Run the benchmarks:

$ cargo +nightly bench

Release Process

The release process for this project is described here.

Code coverage

To generate code coverage statistics:

$ scripts/coverage.sh
$ open target/cov/lcov-local/index.html

Why coverage? While most see coverage as a code quality metric, we see it primarily as a developer productivity metric. When a developer makes a change to the codebase, presumably it's a solution to some problem. Our unit-test suite is how we encode the set of problems the codebase solves. Running the test suite should indicate that your change didn't infringe on anyone else's solutions. Adding a test protects your solution from future changes. Say you don't understand why a line of code exists, try deleting it and running the unit-tests. The nearest test failure should tell you what problem was solved by that code. If no test fails, go ahead and submit a Pull Request that asks, "what problem is solved by this code?" On the other hand, if a test does fail and you can think of a better way to solve the same problem, a Pull Request with your solution would most certainly be welcome! Likewise, if rewriting a test can better communicate what code it's protecting, please send us that patch!

Disclaimer

All claims, content, designs, algorithms, estimates, roadmaps, specifications, and performance measurements described in this project are done with the author's best effort. It is up to the reader to check and validate their accuracy and truthfulness. Furthermore nothing in this project constitutes a solicitation for investment.