Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docusaurus: plutus exe #6743

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

docusaurus: plutus exe #6743

wants to merge 1 commit into from

Conversation

bezirg
Copy link
Contributor

@bezirg bezirg commented Dec 11, 2024

Pre-submit checklist:

  • Branch
    • Tests are provided (if possible)
    • Commit sequence broadly makes sense
    • Key commits have useful messages
    • Changelog fragments have been written (if appropriate)
    • Relevant tickets are mentioned in commit messages
    • Formatting, PNG optimization, etc. are updated
  • PR
    • (For external contributions) Corresponding issue exists and is linked in the description
    • Targeting master unless this is a cherry-pick backport
    • Self-reviewed the diff
    • Useful pull request description
    • Reviewer requested


# Running and Debugging Compiled Code

You can run compiled code locally (without the need of a Cardano Node)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the for most people, the most useful functionality of the executable is optimizing UPLC. This should be made clear at the beginning. Debugging, on the other hand, should be de-emphasized, since we don't really have a working debugger.

The initial examples should also focus on how to use it for UPLC optimization, before talking about anything else.

In the following example we check a program written in the PIR (Plutus Intermediate Representation) language:

``` shell
$ echo "(program 1.1.0 (lam x (con integer) (lam y (con integer) x)))" > const.pir
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For each thing the executable can do (compiling, checking etc.), the first examples should be UPLC (unless the thing doesn't apply to UPLC). TPLC and PIR examples are optional, and if you prefer to include them, they should come after the UPLC examples.


``` shell
$ echo "(program 1.1.0 (lam x (con integer) (lam y (con integer) x)))" > const.pir
$ plutus const.pir
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So if you run plutus without any flag, it performs static checks? That's a weird default, and isn't clear from the help message.

@@ -13,7 +13,7 @@ is hosted on the [Releases] page. Alternatively, you can build the tool specific
for your platform using Nix:

``` shell
nix build FIXME
$ nix build .#cabalProject.x86_64-linux.hsPkgs.plutus-core.components.exes.plutus
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd wrap it in double-quotes just in case there are readers with zsh shell... (# is a beginning of comment there)

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It seems to work fine from here. I just installed zsh and fired this command and it works? 🤷‍♂️

Copy link
Contributor

@ana-pantilie ana-pantilie left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for writing this up! The debugger is definitely cool, but I agree with Ziyang, the docs should be uplc focused and I see that there's currently nothing about how to run just optimisations on an input uplc program.

doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
doc/docusaurus/docs/using-plutus-tx/running-debugging.md Outdated Show resolved Hide resolved
using Nix, specifically for your platform:

``` shell
$ nix build .#cabalProject.$(nix eval nixpkgs#stdenv.buildPlatform.system).hsPkgs.plutus-core.components.exes.plutus
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • Without the $ I can copy-paste this line easier.
  • With double quotes around the argument I am protected from zsh mis-interpreting it as a comment.
Suggested change
$ nix build .#cabalProject.$(nix eval nixpkgs#stdenv.buildPlatform.system).hsPkgs.plutus-core.components.exes.plutus
nix build ".#cabalProject.$(nix eval nixpkgs#stdenv.buildPlatform.system).hsPkgs.plutus-core.components.exes.plutus"

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I suspect that without the shell specifier this fenced code block will also have the "Copy To Clipboard" button.

@bezirg bezirg force-pushed the bezirg/plutus-exe-doc branch from e38502d to 38aca62 Compare January 8, 2025 15:48
@bezirg bezirg force-pushed the bezirg/plutus-exe-doc branch from 38aca62 to deb4c4b Compare January 9, 2025 11:32
@bezirg bezirg force-pushed the bezirg/plutus-exe-doc branch from deb4c4b to 72cca84 Compare January 9, 2025 12:44
@bezirg bezirg force-pushed the bezirg/plutus-exe-doc branch from 72cca84 to 7251e48 Compare January 9, 2025 21:14
@bezirg bezirg marked this pull request as ready for review January 9, 2025 21:15
@bezirg bezirg requested a review from zliu41 January 9, 2025 21:15
Copy link
Member

@zliu41 zliu41 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good. I suggest placing the debugging section after the converting section, and noting that the debugger is in a very preliminary stage and all it can do right now is to trace the evaluation of a UPLC program.

Also can you work with Lorenzo to publish the executable as part of our releases? We currently publish the old executables, which we can continue to do, until we are ready to deprecate the old executables. And if we do that, it would also be useful to add a quick note in this doc about the differences between the old and the new executables.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants