Skip to main content

tools for working with chiklisp language; compiler, repl, python and wasm bindings

Project description

klvm_tools_rs

GitHub Coverage Status Build Crate Build Wheels

PyPI Crates.io

Theory of operation of the modern compiler: ./HOW_CHIKLISP_IS_COMPILED.md

This repo can be installed via cargo

cargo install klvm_tools_rs

or via pip

pip install klvm_tools_rs@git+https://github.com/Chik-Network/klvm_tools_rs.git@e17412032aa7d3b8b1d1f931893fb5802eee626a

Note: pip installs a subset of the tools installed by cargo, including brun, run, opc and opd.

The most current version of the language is in the nightly branch:

[nightly](https://github.com/Chik-Network/klvm_tools_rs/tree/nightly)

To install from a specific branch:

cargo install --no-default-features --git 'https://github.com/Chik-Network/klvm_tools_rs' --branch nightly

To install a git checkout into your current python environment (must be in some kind of venv or conda environment):

git clone https://github.com/Chik-Network/klvm_tools_rs
cd klvm_tools_rs
maturin develop

Install from PYPI:

pip install -i https://pypi.chiknetwork.com/nightlies/ klvm_tools_rs

Most people still compile chiklisp via python. One way to set up compilation in that way is like this:

import json
from klvm_tools_rs import compile_klvm

def compile_module_with_symbols(include_paths,source):
    path_obj = Path(source)
    file_path = path_obj.parent
    file_stem = path_obj.stem
    target_file = file_path / (file_stem + ".klvm.hex")
    sym_file = file_path / (file_stem + ".sym")
    compile_result = compile_klvm(source, str(target_file.absolute()), include_paths, True)
    symbols = compile_result['symbols']
    if len(symbols) != 0:
        with open(str(sym_file.absolute()),'w') as symfile:
            symfile.write(json.dumps(symbols))

The command line tools provided:

- run -- Compiles KLVM code from chiklisp

Most commonly, you'll compile chiklisp like this:

  ./target/debug/run -O -i include_dir chiklisp.clsp

'run' outputs the code resulting from compiling the program, or an error.

- repl -- Accepts chiklisp forms and expressions and produces results
          interactively.
          
Run like:

  ./target/debug/repl
  
Example session:

>>> (defmacro assert items
   (if (r items)
       (list if (f items) (c assert (r items)) (q . (x)))
     (f items)
     )
   )
(q)
>>> (assert 1 1 "hello")
(q . hello)
>>> (assert 1 0 "bye")
failed: CompileErr(Srcloc { file: "*macros*", line: 2, col: 26, until: Some(Until { line: 2, col: 82 }) }, "klvm raise in (8) (())")
>>> 

- cldb -- Stepwise run chiklisp programs with program readable yaml output.

  ./target/debug/cldb '(mod (X) (x X))' '(4)'
  ---
  - Arguments: (() (4))
    Operator: "4"
    Operator-Location: "*command*(1):11"
    Result-Location: "*command*(1):11"
    Row: "0"
    Value: (() 4)
  - Env: "4"
    Env-Args: ()
    Operator: "2"
    Operator-Location: "*command*(1):11"
    Result-Location: "*command*(1):13"
    Row: "1"
    Value: "4"
  - Arguments: (4)
    Failure: klvm raise in (8 5) (() 4)
    Failure-Location: "*command*(1):11"
    Operator: "8"
    Operator-Location: "*command*(1):13"

- brun -- Runs a "binary" program.  Instead of serving as a chiklisp
  compiler, instead runs klvm programs.

As 'brun' from the python code:

$ ./target/debug/run '(mod (X) (defun fact (N X) (if (> 2 X) N (fact (* X N) (- X 1)))) (fact 1 X))'
(a (q 2 2 (c 2 (c (q . 1) (c 5 ())))) (c (q 2 (i (> (q . 2) 11) (q . 5) (q 2 2 (c 2 (c (* 11 5) (c (- 11 (q . 1)) ()))))) 1) 1))
$ ./target/debug/brun '(a (q 2 2 (c 2 (c (q . 1) (c 5 ())))) (c (q 2 (i (> (q . 2) 11) (q . 5) (q 2 2 (c 2 (c (* 11 5) (c (- 11 (q . 1)) ()))))) 1) 1))' '(5)'
120

- opc -- crush klvm s-expression form to hex.

As 'opc' from the python code.

opc '(a (q 2 2 (c 2 (c (q . 1) (c 5 ())))) (c (q 2 (i (> (q . 2) 11) (q . 5) (q 2 2 (c 2 (c (* 11 5) (c (- 11 (q . 1)) ()))))) 1) 1))'
ff02ffff01ff02ff02ffff04ff02ffff04ffff0101ffff04ff05ff8080808080ffff04ffff01ff02ffff03ffff15ffff0102ff0b80ffff0105ffff01ff02ff02ffff04ff02ffff04ffff12ff0bff0580ffff04ffff11ff0bffff010180ff808080808080ff0180ff018080

- opd -- disassemble hex to s-expression form.

As 'opd' from the python code.

opd 'ff02ffff01ff02ff02ffff04ff02ffff04ffff0101ffff04ff05ff8080808080ffff04ffff01ff02ffff03ffff15ffff0102ff0b80ffff0105ffff01ff02ff02ffff04ff02ffff04ffff12ff0bff0580ffff04ffff11ff0bffff010180ff808080808080ff0180ff018080'
(a (q 2 2 (c 2 (c (q . 1) (c 5 ())))) (c (q 2 (i (> (q . 2) 11) (q . 5) (q 2 2 (c 2 (c (* 11 5) (c (- 11 (q . 1)) ()))))) 1) 1))

History

This is a second-hand port of chik's klvm tools to rust via the work of ChikMineJP porting to typescript. This would have been a lot harder to get to where it is without prior work mapping out the types of various semi-dynamic things (thanks, ChikMineJP).

Some reasons for doing this are:

  • Chik switched the klvm implementation to rust: klvm_rs, and this code may both pick up speed and track klvm better being in the same language.

  • I wrote a new compiler with a simpler, less intricate structure that should be easier to improve and verify in the future in ocaml: ochiklisp.

  • Also it's faster even in this unoptimized form.

All acceptance tests i've brought over so far work, and more are being added. As of now, I'm not aware of anything that shouldn't be authentic when running these command line tools from klvm_tools in their equivalents in this repository

  • opc

  • opd

  • run

  • brun

  • repl

argparse was ported to javascript and I believe I have faithfully reproduced it as it is used in cmds, so command line parsing should work similarly in all three versions.

The directory structure is expected to be:

src/classic  <-- any ported code with heritage pointing back to
                 the original chik repo.
                
src/compiler <-- a newer compiler (ochiklisp) with a simpler
                 structure.  Select new style compilation by
                 including a `(include *standard-cl-21*)`
                 form in your toplevel `mod` form.

Mac M1

Use cargo build --no-default-features due to differences in how mac m1 and other platforms handle python extensions.

Use with chik-blockchain

# Activate your venv, then
$ maturin develop --release

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

klvm_tools_rs-0.4.0.tar.gz (552.4 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

klvm_tools_rs-0.4.0-cp39-abi3-win_amd64.whl (1.4 MB view details)

Uploaded CPython 3.9+Windows x86-64

klvm_tools_rs-0.4.0-cp39-abi3-musllinux_1_1_x86_64.whl (1.5 MB view details)

Uploaded CPython 3.9+musllinux: musl 1.1+ x86-64

klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_x86_64.whl (1.5 MB view details)

Uploaded CPython 3.9+manylinux: glibc 2.28+ x86-64

klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_aarch64.whl (1.5 MB view details)

Uploaded CPython 3.9+manylinux: glibc 2.28+ ARM64

klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_x86_64.whl (1.4 MB view details)

Uploaded CPython 3.9+macOS 13.0+ x86-64

klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_arm64.whl (1.3 MB view details)

Uploaded CPython 3.9+macOS 13.0+ ARM64

File details

Details for the file klvm_tools_rs-0.4.0.tar.gz.

File metadata

  • Download URL: klvm_tools_rs-0.4.0.tar.gz
  • Upload date:
  • Size: 552.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for klvm_tools_rs-0.4.0.tar.gz
Algorithm Hash digest
SHA256 55c3ea8be46bbc5f05d8106cd323296fd51f92e69cbc949f11cd5c8df7de33a0
MD5 d02d166d86b72387446b08734de400ff
BLAKE2b-256 5fac4eb1643c142a55d88329b4fb581874f5bc6e4f630c66722a063ff9e43e3e

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0.tar.gz:

Publisher: build-test.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file klvm_tools_rs-0.4.0-cp39-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for klvm_tools_rs-0.4.0-cp39-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 1eac8a48dceb72a657037e69d1e0bcb6ab142c260b65c7d1dcc1f4785b20e4c0
MD5 8f2abf81394dd36a303d1f3bc115e522
BLAKE2b-256 cfacd654647e752c2566ae03f612a89b958c2b5295361f6b2c864a7bdc4bb0d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0-cp39-abi3-win_amd64.whl:

Publisher: build-test.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file klvm_tools_rs-0.4.0-cp39-abi3-musllinux_1_1_x86_64.whl.

File metadata

File hashes

Hashes for klvm_tools_rs-0.4.0-cp39-abi3-musllinux_1_1_x86_64.whl
Algorithm Hash digest
SHA256 d7e271b2ef0059290d45d24d41bede1655dd00013df96b7a65bec5695825a112
MD5 dcab7fff65928746359abbe9978bf189
BLAKE2b-256 6e759cba6f88267ba4b9ff28814086610f3aed432dfe4cded3f44544735b0ab5

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0-cp39-abi3-musllinux_1_1_x86_64.whl:

Publisher: build-test.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 23fbbbfc0f19c7dded78298cf94b3cc1035a07fefabf1ae680875e54ff33cece
MD5 379d12cfa9041a088ef893e09817b06d
BLAKE2b-256 1a4d0ff8ac7be09284c742ef447f4ad1adfd500247a5c1d4579e57a13da6e1c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_x86_64.whl:

Publisher: build-test.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 98457fb5c93dcd77625f5ac0ab45a7fc74d1e6827fc77e3c4d43ae4383935a75
MD5 f8212398807b6b63898b3f5d96b3806c
BLAKE2b-256 1003a0208d19e3f87b34ba2e3b17fd136f6855a6e2cc54e01d1f5d1d47712559

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0-cp39-abi3-manylinux_2_28_aarch64.whl:

Publisher: build-arm64-wheels.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 83d5e97bbb5b3d0da04685f77e1f5b40f60e67cb9d61ddce546cee30b073bd21
MD5 c2556a564a1965f32d2fbcfce7cfc9ca
BLAKE2b-256 b2e5d1e26b1a18a2229b4e06f1cddd8515bb7eb5c4cbd4b225f18c96c38d6dca

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_x86_64.whl:

Publisher: build-test.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_arm64.whl.

File metadata

File hashes

Hashes for klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_arm64.whl
Algorithm Hash digest
SHA256 df60d35c6285e7bc156ad692fb19ea800aea6ee76b7fcc790e0adfc9bdcdb5cf
MD5 a48dc8083394dd1815f37da9df5d73fe
BLAKE2b-256 ff51858505961e14f7c1b23169c8ab81e58627454bcc3e78ef0a87f7bbc42769

See more details on using hashes here.

Provenance

The following attestation bundles were made for klvm_tools_rs-0.4.0-cp39-abi3-macosx_13_0_arm64.whl:

Publisher: build-m1-wheel.yml on Chik-Network/klvm_tools_rs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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