-
This project uses
jq
command-line tool to allowmakefile
to read variables fromconfig.json
. Please ensure it's installed.$ brew install jq
-
This project uses Git submodules to manage dependencies. To install and build these dependencies, you'll need to run the following command from the root directory of the project:
$ npm run setup
This command will initialize and update the Git submodules, which will download the necessary dependencies for the project, then build them. It will also create a required
config.json
with necessary configuration variables to run the project.
Once the dependencies are installed, you should be able to run the project. If you encounter any issues during the installation process, please refer to the project's documentation or contact the project maintainer for assistance.
Run this command to locally compile an XRPL Hook source file (inside ./hook-src) from .c to .wasm code and install it onto an account by submitting a SetHook
transaction:
$ npm run build-set-hooks
Here is what each command does in the background:
wasmcc
- compiles a Hook source file (C code) to WebAssembly (WASM) code. For example,./hook-src/starter.c
compiles to./build/starter.wasm
wasm-opt
- optimizes the WASM code./build/starter.wasm
hook-cleaner
- cleans it by removing unnecessary additional exportsguard_checker
- this checks if any guard violation has occurred in the Hooks code before submitting it inSetHook
transaction. For more information, visit this link- Converts the compiled WASM to hexadecimal characters then submits it as payload in a
SetHook
transaction