37 releases (17 breaking)

0.18.0 Nov 28, 2024
0.17.0 Apr 3, 2024
0.16.0 Mar 27, 2024
0.8.5 Dec 4, 2023
0.1.0 Jul 6, 2023

#1 in #drink

32 downloads per month

Apache-2.0 and GPL-3.0-only

105KB
2K SLoC

DRink! CLI

https://github.com/Cardinal-Cryptography/drink/assets/27450471/4a45ef8a-a7ec-4a2f-84ab-0a2a36c1cb4e

We provide this simple command line tool to help you play with your local contracts in a convenient way.

Dependencies

The only requirement for running DRInk! is having Rust installed. The code was tested with version 1.70. All other dependencies are managed by Cargo and will be installed upon running cargo build or cargo run.

Running DRInk! CLI

When you run the binary (cargo run --release) you'll see a DRink! TUI. You can also choose to start from a specific path by supplying the --path argument like:

cargo run --release -- --path <absolute path to e.g. example/flipper>

CLI modes

In a somewhat Vim-inspired way, the drink-cli allows you to work in two modes: the Managing mode and the Drinking mode.

Managing mode

This is the default mode, facilitating high-level interactions with the TUI itself. At any point, you can enter it by pressing the Esc key. Once in the Managing mode:

  • Press h to see a list of available commands with their brief descriptions;
  • Press q to quit the TUI;
  • Press i to enter the Drinking mode.

Drinking mode

This is the mode where you can interact with your environment and type your commands inside the User input field. When in Managing mode, you can enter the Drinking mode by pressing 'i' on your keyboard.

You have several commands at your disposal (you can list them in the Managing mode by pressing the 'h' key):

  • cd and clear will, just like their Bash counterparts, change the directory and clear the output, respectively. You will see the current working directory as the first entry in the Current environment pane;
  • build command will build a contract from the sources in the current directory;
  • deploy command will deploy a contract from the current directory. Note that if your constructor takes arguments, you will need to supply them to this command, like: deploy true in the case of the Flipper example;
  • by pressing Tab you can switch between all deployed contracts (with automatic directory change);
  • call command will call a contract with the given message. Again, if the message takes arguments, they need to be supplied here;
  • next-block command will advance the current block number;
  • add-tokens command will add tokens to the given account.

Dependencies

~53–70MB
~1.5M SLoC