1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
use crate::account::KeyedAccount; use crate::pubkey::Pubkey; use std; /// Reasons a program might have rejected an instruction. #[derive(Debug, PartialEq, Eq, Clone)] pub enum ProgramError { /// The program instruction returned an error GenericError, /// The arguments provided to a program instruction where invalid InvalidArgument, /// An instruction resulted in an account with a negative balance /// The difference from InsufficientFundsForFee is that the transaction was executed by the /// contract ResultWithNegativeLamports, /// Program's instruction lamport balance does not equal the balance after the instruction UnbalancedInstruction, /// Program modified an account's program id ModifiedProgramId, /// Program spent the lamports of an account that doesn't belong to it ExternalAccountLamportSpend, /// Program modified the userdata of an account that doesn't belong to it ExternalAccountUserdataModified, /// An account's userdata contents was invalid InvalidUserdata, /// An account's userdata was too small UserdataTooSmall, /// SystemInstruction::Assign was attempted on an account unowned by the system program AssignOfUnownedAccount, /// CustomError allows on-chain programs to implement program-specific error types and see /// them returned by the Solana runtime. A CustomError may be any type that is serialized /// to a Vec of bytes, max length 32 bytes. Any CustomError Vec greater than this length will /// be truncated by the runtime. CustomError(Vec<u8>), } impl std::fmt::Display for ProgramError { fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result { write!(f, "error") } } impl std::error::Error for ProgramError {} // All native programs export a symbol named process() pub const ENTRYPOINT: &str = "process"; // Native program ENTRYPOINT prototype pub type Entrypoint = unsafe extern "C" fn( program_id: &Pubkey, keyed_accounts: &mut [KeyedAccount], data: &[u8], tick_height: u64, ) -> Result<(), ProgramError>; // Convenience macro to define the native program entrypoint. Supply a fn to this macro that // conforms to the `Entrypoint` type signature. #[macro_export] macro_rules! solana_entrypoint( ($entrypoint:ident) => ( #[no_mangle] pub extern "C" fn process( program_id: &Pubkey, keyed_accounts: &mut [KeyedAccount], data: &[u8], tick_height: u64 ) -> Result<(), ProgramError> { $entrypoint(program_id, keyed_accounts, data, tick_height) } ) );