Table of Contents
    Scroll to Top
    Edit Page

    Program File Structure

    Info

    This is a beta version of the Solana Toolkit, and is still a WIP. Please post all feedback as a GitHub issue here.

    Typically Solana smart contracts (aka programs) workspaces will be have the following file structure:

    .
    ├── app
    ├── migrations
    ├── node_modules
    ├── programs
    ├── target
    └── tests

    The main program is the lib.rs file, which lives insides the programs directory, as shown below:

    .
    ├── app
    ├── migrations
    ├── node_modules
    ├── programs
        ├── src
            ├── lib.rs
    ├── target
    └── tests

    As the program gets more cumbersome, you'll typically want to separate the logic into multiple files, as shown below:

    ├── programs
        ├── src
            ├── state.rs
            ├── instructions
                ├── instruction_1.rs
                ├── instruction_2.rs
                ├── instruction_3.rs
            ├── lib.rs
            ├── constants.rs
            ├── error.rs
            ├── mod.rs

    For native rust program development, you need to explicitly write out the entrypoint and processor for the program, so you'll need a few more files:

    ├── program.rs
       ├── src.rs
       ├──assertions.rs
       ├──entrypoint.rs
       ├──error.rs
       ├──instruction.rs
       ├──lib.rs
       ├──processor.rs
       ├──state.rs
       ├──utils.rs
       ├── Cargo.toml
       ├── keypair.json
       ├── README.md