Skip to main content

A tool to convert MultiversX Smart Contract ABI files into Markdown documentation.

Project description

abi-markdowner

abi-markdowner is a Python tool that converts MultiversX Smart Contract ABI (Application Binary Interface) files into structured and detailed Markdown documentation. This makes it easy to document, share, and understand smart contracts.

Features

  • Convert ABI to Markdown: Generates comprehensive Markdown documentation from smart contract ABI files.
  • Customizable Output: Organizes endpoints, views, events, and types with detailed descriptions and formatted tables.
  • Matrix-Style Input/Output Tables: Automatically formats function inputs and outputs into a clear matrix with support for optional and multi-value parameters.
  • Automatic Table of Contents: Includes a TOC for easy navigation within the generated documentation.
  • Deployment Links: Supports including multiple mainnet and devnet addresses with customizable labels from a deployments.json file.

Installation

Install abi-markdowner using pip:

pip install abi-markdowner

Usage

Simply run the tool from your SC main directory:

abi-markdowner

Alternatively, you can pass another project directory as argument. For more information, check the Parameters section.

Parameters

  • --sc-path:

    (Optional - default is the current working directory)

    Specify the path to your smart contract project containing the Cargo.toml and optionally the deployments.json files. The ABI file will be read from the output directory within this path.

  • --output-file:

    (Optional - default is README.md in the sc-path directory)

    Specify the output file path for the generated Markdown.

  • --cargo-toml:

    (Optional - default is Cargo.toml in the sc-path directory)

    Specify the path to the Cargo.toml file.

  • --deployments-json:

    (Optional - default is deployments.json in the sc-path directory)

    Specify the path to the deployments.json file containing deployment addresses.

Important: ABI file is obtained from the /output folder in the sc-path directory.

Execution example

abi-markdowner --sc-path path_to_sc/

This will generate a Markdown document summarizing your smart contract's structure, including types, endpoints, views, and events, along with links to the specified deployment addresses.

Example of deployments.json file

The existence of this file is not mandatory. If found, a Links section will be created in the documentation.

Here’s an example of how your deployments.json file can be structured:

{
  "mainnet": [
    {
      "address": "erd1qqqqqqqqqqqqqpgqvc7gdl0p4s97guh498wgz75k8sav6sjfjlwqh679jy",
      "label": "Shard 0"
    },
    {
      "address": "erd1qqqqqqqqqqqqqpgqhe8t5jewej70zupmh44jurgn29psua5l2jps3ntjj3",
      "label": "Shard 1"
    }
  ],
  "devnet": [
    {
      "address": "erd1qqqqqqqqqqqqqpgqvn9ew0wwn7a3pk053ezex98497hd4exqdg0q8v2e0c"
    }
  ]
}

The above would result in something similar to the following:

Links
    - Mainnet Deployments:
        - Shard 0: erd1qqqqqqqqqqqqqpgqvc7gdl0p4s97guh498wgz75k8sav6sjfjlwqh679jy
        - Shard 1: erd1qqqqqqqqqqqqqpgqhe8t5jewej70zupmh44jurgn29psua5l2jps3ntjj3
    - Devnet Deployments:
        - Address: erd1qqqqqqqqqqqqqpgqvn9ew0wwn7a3pk053ezex98497hd4exqdg0q8v2e0c

Tests

Tests have not been added yet.

License

abi-markdowner is licensed under the MIT License. See the LICENSE file for more information.

Contributing

Contributions are welcome! Please fork the repository and submit a pull request.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

abi_markdowner-0.1.7.tar.gz (7.5 kB view details)

Uploaded Source

Built Distribution

abi_markdowner-0.1.7-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file abi_markdowner-0.1.7.tar.gz.

File metadata

  • Download URL: abi_markdowner-0.1.7.tar.gz
  • Upload date:
  • Size: 7.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for abi_markdowner-0.1.7.tar.gz
Algorithm Hash digest
SHA256 99ab2a154ab9e98a74764a93083b5e70c084ce6154d3c0b308e4013f12f988a3
MD5 ba3f37ebb0a0ffe17a0b7b7ea7a24855
BLAKE2b-256 e7ee1b98b0ae2ccd9a15507f29bf45ce841780771472397252c7a18c4f400a3a

See more details on using hashes here.

File details

Details for the file abi_markdowner-0.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for abi_markdowner-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 8bf9a3f33d3f2c4ac1b4aced3883932655754a6e137bf1982cf9b6fe91509f33
MD5 5816bad894b851e30c964c694cee98d2
BLAKE2b-256 70baef1d0db6c4dab46979f84207a6da4be7e9dc2a2f2d869c7b1657209f5e71

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page