mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-13 18:41:05 +00:00
Reorganising the repository - external renames and moves (#4074)
* Adding first rough ouline of the repository structure * Remove old CI stuff * add title * formatting fixes * move node-exits job's script to scripts dir * Move docs into subdir * move to bin * move maintainence scripts, configs and helpers into its own dir * add .local to ignore * move core->client * start up 'test' area * move test client * move test runtime * make test move compile * Add dependencies rule enforcement. * Fix indexing. * Update docs to reflect latest changes * Moving /srml->/paint * update docs * move client/sr-* -> primitives/ * clean old readme * remove old broken code in rhd * update lock * Step 1. * starting to untangle client * Fix after merge. * start splitting out client interfaces * move children and blockchain interfaces * Move trie and state-machine to primitives. * Fix WASM builds. * fixing broken imports * more interface moves * move backend and light to interfaces * move CallExecutor * move cli off client * moving around more interfaces * re-add consensus crates into the mix * fix subkey path * relieve client from executor * starting to pull out client from grandpa * move is_decendent_of out of client * grandpa still depends on client directly * lemme tests pass * rename srml->paint * Make it compile. * rename interfaces->client-api * Move keyring to primitives. * fixup libp2p dep * fix broken use * allow dependency enforcement to fail * move fork-tree * Moving wasm-builder * make env * move build-script-utils * fixup broken crate depdencies and names * fix imports for authority discovery * fix typo * update cargo.lock * fixing imports * Fix paths and add missing crates * re-add missing crates
This commit is contained in:
committed by
Bastian Köcher
parent
becc3b0a4f
commit
60e5011c72
@@ -0,0 +1,110 @@
|
||||
= Structure
|
||||
:Author: Substrate developers
|
||||
:Revision: 0.3.0
|
||||
:toc:
|
||||
:sectnums:
|
||||
|
||||
|
||||
== Overview
|
||||
|
||||
Substrate is split into multiple levels with increasing opinion and decreasing flexibility:
|
||||
|
||||
* primitives
|
||||
* client
|
||||
* PAINT (formerly `paint`)
|
||||
|
||||
Putting all these components together we have:
|
||||
|
||||
* Integration Tests
|
||||
* Node
|
||||
* Node template
|
||||
* Subkey
|
||||
|
||||
=== Runtime
|
||||
|
||||
* _found in_: `/primitives`
|
||||
* _crates prefix_: `sp-`
|
||||
* _constrains_:
|
||||
** must be `[no_std]`
|
||||
** crates may not (dev-)depend on crates in other subfolders of this repo
|
||||
|
||||
In the lowest level, substrate defines primitives, interfaces and traits to implement any on-chain substrate transition system and its interactions with the outside world. This is the lowest level of abstraction and opinion everything else builds upon.
|
||||
|
||||
=== Client
|
||||
|
||||
* _found in_: `/client`
|
||||
* _crates prefix_: `substrate-`
|
||||
* _constrains_:
|
||||
** crates may not (dev-)depend on any `paint-`-crates
|
||||
|
||||
In the client you can find a set of crates to construct the outer substrate-node, implementing outer runtime interfaces, thus it depends on `runtime`. It provides the outer building blocks like transaction queue, networking layer, database backend, full* and light-client support.
|
||||
|
||||
=== PAINT (formerly `paint`)
|
||||
|
||||
* _found in_: `/paint`
|
||||
* _crates prefix_: `paint-`
|
||||
* _constrains_:
|
||||
** all crates that go on chain, must be `[no_std]`
|
||||
** must not (dev-)depend on anything in `/client`
|
||||
|
||||
PAINT, the Parity Application Interface for Network-wide Transitions, is a set of modules implementing specific transition functions and features one (might) want to have in their runtime.
|
||||
|
||||
=== integration tests
|
||||
|
||||
* _found in_: `/test`
|
||||
* _crates prefix_: `substrate-test`
|
||||
* _constrains_:
|
||||
** only helpers may be published
|
||||
** purely testing crates must be `publish = false`
|
||||
|
||||
All tests that have to pull (dev)-dependencies out of their substree and would thus break the dependency rules, are considered intergration tests and should be stored in here. Only helper-crates in here shall be published, everything else is expected to be non-publish.
|
||||
|
||||
=== Binaries and template
|
||||
|
||||
* _found in_: `/bin`
|
||||
|
||||
We also provide some binaries pulling from the components creating full applications.
|
||||
|
||||
==== Node
|
||||
|
||||
* _found in_: `/bin/node`
|
||||
|
||||
The default (testing) application pulling together our recommended setup of substrate-client with a wasm-contracts-supporting paint-runtime. The node pulls it all together, constructs the (upgradable) runtime and wires up the client around it. You can find an example client, which includes a full wasm-contracts chain in `node`. This is also what is being build and run if you do `cargo run`.
|
||||
|
||||
|
||||
==== Node Template
|
||||
|
||||
* _found in_: `/bin/node-template`
|
||||
|
||||
We also provide a template to get you started building your own node.
|
||||
|
||||
==== Subkey
|
||||
|
||||
* _found in_: `/bin/subkey`
|
||||
|
||||
Subkey is a client library to generate keys and sign transactions to send to a substrate node.
|
||||
|
||||
== Internal Dependency Tree
|
||||
|
||||
[ditaa]
|
||||
....
|
||||
+---------------+ +----------------+
|
||||
| | | |
|
||||
| runtime +<------+ paint |
|
||||
| | | |
|
||||
+------+-----+--+ +-------------+--+
|
||||
^ ^ ^
|
||||
| +----------------+ |
|
||||
| | |
|
||||
+------+--------+ | |
|
||||
| | | |
|
||||
| client | +--+-------+--------+
|
||||
| +<---------+ |
|
||||
+---------------+ | |
|
||||
| test /bin/* |
|
||||
| |
|
||||
| |
|
||||
+-------------------+
|
||||
|
||||
....
|
||||
|
||||
Reference in New Issue
Block a user