#puzzle #condition #wallet

chik-puzzles

Chik primitives needed for building wallets

8 breaking releases

0.20.1 Feb 6, 2025
0.17.0 Feb 6, 2025
0.10.0 Jul 11, 2024

#50 in #condition

Download history 14/week @ 2024-12-07 4/week @ 2024-12-14 850/week @ 2025-02-01 103/week @ 2025-02-08 109/week @ 2025-02-15 145/week @ 2025-02-22 115/week @ 2025-03-01 11/week @ 2025-03-08 5/week @ 2025-03-15 49/week @ 2025-03-22

181 downloads per month
Used in 13 crates (7 directly)

Apache-2.0

375KB
960 lines

Chik Puzzles

This is a collection of the standard Chik puzzles. These are the puzzles which are deployed on chain and therefore cannot change.

This repository tracks the source code, the compiled hex, and a hash of the compiled hex to ensure continuity.

All puzzles are kept in the puzzles folder as both a .clsp and .clsp.hex file.

The Python and Rust bindings are created by running generate_chiklisp_constants.py

Adding Bindings for a New Puzzle

  1. Add the .clsp and .clsp.hex files into the programs folder.
  2. Add the puzzle name, path, and shatree hash into the list in generate_chiklisp_constants.py.
  3. Run generate_chiklisp_constants.py.
  4. Commit your changes, including to the outputted programs.py and programs.rs.

Testing

This project is managed with poetry for Python and cargo for Rust.

To run the Python tests:

python -m venv venv

pip install poetry
. ./venv/bin/activate
poetry install
pytest chik_puzzles_py/tests

If you're on Windows activate the venv with . venv\Scripts\activate instead

To run the Rust tests:

cargo test --all

Dependencies