Skip to content
This repository has been archived by the owner on Feb 1, 2024. It is now read-only.
/ ink-playground Public archive

Browser Based Playground for editing, sharing & compiling ink! Smart Contracts

License

Notifications You must be signed in to change notification settings

use-ink/ink-playground

Repository files navigation

ink! Playground

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

Table of Contents

Getting started

git clone clone https://github.com/paritytech/ink-playground

cd ink-playground

make install

make test

make build

Implemented features:

crate-extractor

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.

Usage:

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.

Description

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 drive
  • change_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:

Rust Analyzer

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:

Cli Tool

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:

WASM Setup for RA

Fig.3 The WASM version of RA can utilize `change_json` to receive the crate deps