Nessuna descrizione

Claire xyz ef2d13172b remove extra line 3 settimane fa
.github 4df3a91d8d Add CI workflow 1 mese fa
crates 87f4ebc764 refactor: share common instruction in linker/assembler/disassembler 3 settimane fa
dist 26c0123319 version bump 1 mese fa
examples b4d292feb9 fix: examples build 3 settimane fa
src 4df3a91d8d Add CI workflow 1 mese fa
tests 4df3a91d8d Add CI workflow 1 mese fa
.gitignore 3810c78a7c gitignore 1 mese fa
.npmignore 892eb02ea0 Add crates.io metadata for publishing 1 mese fa
CONTRIBUTING.md ad486f2706 chore: fix clippy lints, apply cargo fmt, add licenses 1 mese fa
Cargo.toml ef2d13172b remove extra line 3 settimane fa
LICENSE-APACHE ad486f2706 chore: fix clippy lints, apply cargo fmt, add licenses 1 mese fa
LICENSE-MIT ad486f2706 chore: fix clippy lints, apply cargo fmt, add licenses 1 mese fa
Makefile 4254b64f6e add Makefile target to test examples 1 mese fa
README.md ad486f2706 chore: fix clippy lints, apply cargo fmt, add licenses 1 mese fa
package.json c157c96604 cleanup wasm 1 mese fa
rustfmt.toml 4df3a91d8d Add CI workflow 1 mese fa

README.md

Table of Contents

sbpf

A simple scaffold to bootstrap sBPF Assembly programs.

Installation

cargo install --git https://github.com/blueshift-gg/sbpf.git

Usage

To view all the commands you can run, type sbpf help. Here are the available commands:

  • init: Create a new project scaffold.
  • build: Compile into a Solana program executable.
  • deploy: Build and deploy the program.
  • test: Test the deployed program.
  • e2e: Build, deploy, and test a program.
  • clean: Clean up build and deploy artifacts.
  • help: Print this message or the help of the given subcommand(s).

    Usage: sbpf <COMMAND>
    
    Commands:
    init    Create a new project scaffold
    build   Compile into a Solana program executable
    deploy  Build and deploy the program
    test    Test deployed program
    e2e     Build, deploy and test a program
    clean   Clean up build and deploy artifacts
    help    Print this message or the help of the given subcommand(s)
    
    Options:
    -h, --help     Print help
    -V, --version  Print version
    

Command Details

Initialize a Project

To create a new project, use the sbpf init command. By default, it initializes a project with Rust tests using Mollusk. You can also initialize a project with TypeScript tests using the --ts-tests option.

sbpf init --help
Create a new project scaffold

Usage: sbpf init [OPTIONS] [NAME]

Arguments:
  [NAME]  The name of the project to create

Options:
  -t, --ts-tests  Initialize with TypeScript tests instead of Mollusk Rust tests
  -h, --help      Print help information
  -V, --version   Print version information
Examples
Create a new project with Rust tests (default)
sbpf init my-project
Create a new project with TypeScript tests
sbpf init my-project --ts-tests

After initializing the project, you can navigate into the project directory and use other commands to build, deploy, and test your program.

Advanced Usage

You can override the default linker with a custom linker file by including it in the src directory with the same name as your program. For example:

src/example/example.s
src/example/example.ld

License

Licensed under either of

at your option.

Contributing

PRs welcome!