hopper-framework 0.1.0

Zero-copy state framework for Solana. Typed account architecture, phased execution, validation graphs, zero-copy collections, layout evolution, and cross-program interfaces. Built on Hopper Native. no_std, no_alloc, no proc macros required.
Documentation
//! `#[account(realloc = ...)]` without an explicit `realloc_zero`
//! policy must be rejected. Newly-appended bytes contain whatever
//! was in the allocator's memory; leaving the policy implicit is a
//! subtle way to leak cross-instruction state. Hopper requires the
//! caller to opt-in to zeroing (or explicitly declare that leaving
//! garbage is acceptable for their protocol).

use hopper::prelude::*;
use hopper::{context, state};

#[state(disc = 1, version = 1)]
#[derive(Copy, Clone)]
#[repr(C)]
pub struct Vault {
    pub balance: WireU64,
}

#[context]
pub struct ReallocNoZero {
    pub payer: AccountView,

    #[account(realloc = 128, realloc_payer = payer)]
    pub vault: Vault,
}

fn main() {}