An ink! Playground which provides a Browser based IDE for editing Smart Contracts written in ink!.
(Planned) Features:
- Uses the Monaco editor
- Implements a WebAssembly version of Rust Analyzer for code editing
- Allows saving and sharing of Smart Contract code
- Implements a one click compile functionality of ink! Smart Contracts to WASM which is provided by a backend service
git clone clone https://github.com/paritytech/ink-playground
cd ink-playground
make install
make test
make build
Parses Crates and CrateGraph (the package dependency graph) of a Rust Project into a JSON file for Rust Analyzer(=RA) and provides a library for (de-)serialization of these data structures which can be referenced by a WASM implementation of RA.
Enter:
gh clone https://github.com/paritytech/ink-playground
cd ink-playground
cargo run -p crate-extractor -- create -i <input> -o <output>
Where <input>
points to the Cargo.toml
of the project you which to analyze and <output>
denotes the path to the resulting ".json" file. Both are optional parameters and default to /Cargo.toml
and ./change.json
.
We want to analyze Rust projects with the Rust Analyzer IDE which we compile to WebAssembly.
This CLI tool allows to extract the data of a Rust Cargo project into a .json file which is then processed by Rust
analyzer. We need this since the dependencies which are usually involved when loading data into Rust analyzers database are accessing the file system and calling rustc. Those dependencies are not available for WebAssembly, hence the corresponding crates won’t compile to WASM.
It uses the following two crates:
crate_extractor
creates the actual JSON file which contains the project data and writes it to the hard drivechange_json
handles the conversion from the RA specific data structures to serializable objects and vice-versa
When we use the Rust analyzer in e.g. Visual Studio code, the IDE
crate provides most of its functionalities as auto completion and syntax highlighting. However, when RA processes the source code of a Rust project it collects most of the required data through the project_model
crate by scanning the project structure on a hard drive. It gathers the required data from the hard disk of your computer and transfers it into the Change
object. RA then sends this change object to the Database
and contains the precise instructions on how to update the RA database with the required project data.
We visualize his process, in a strongly simplified way, in Fig.1 below:
Fig.1 The way how RA loads a Rust project into its database
Here, all the crates which are colored in red won’t compile to WebAssembly. This is because of the access to the local file system but also since it involves various calls to rustc and also because of many other non-compatible dependencies.
However, all the tools which are provided by the IDE crate compile flawlessly as well as the RA Database to which also the Change object belongs, as same as all the other dependencies of these crates which are abstracted away in Fig. 1.
The crate_extractor crate is creating the Change
object by utilizing the project_model
crate similarly then the Rust Analyzer
crate does it in Fig 1. But then, instead of sending it to the Rust Analyzer database, it uses the change_json
crate to parse it to JSON. The change_json
crate defines its own JSON structure which is (de-)serializable by Serde JSON, as well as the required tools to convert the Change
object to its corresponding JSON structure and vice-versa, see Fig. 2 below for a visualization of this interaction:
Fig.2 How this repo extracts Cargo Crate data into a JSON structure
While the crate_extractor
crate is using various dependencies which won’t compile to WASM, we can’t use it in a WebAssembly version of Rust Analyzer. However, the change_json
crate consumes just a bare minimum of basic dependencies like the RA Database and therefore compiles to WASM.
We visualize the way it is used to provide a Rust projects source code and dependency graph to a WASM implementation of Rust Analyzer in Fig. 3 below:
Fig.3 The WASM version of RA can utilize `change_json` to receive the crate deps