2019-03-11 16:35:25 -06:00
|
|
|
use bincode::serialize;
|
2018-12-14 20:39:10 -08:00
|
|
|
use log::*;
|
2018-12-03 13:32:31 -08:00
|
|
|
use solana_sdk::account::KeyedAccount;
|
2018-11-17 17:02:14 -08:00
|
|
|
use solana_sdk::pubkey::Pubkey;
|
2019-03-11 16:35:25 -06:00
|
|
|
use solana_sdk::solana_entrypoint;
|
2019-03-18 10:05:03 -06:00
|
|
|
use solana_sdk::transaction::InstructionError;
|
2018-11-02 17:32:54 -07:00
|
|
|
|
|
|
|
mod token_program;
|
|
|
|
|
2018-11-13 18:38:51 -08:00
|
|
|
solana_entrypoint!(entrypoint);
|
2018-11-17 17:02:14 -08:00
|
|
|
fn entrypoint(
|
|
|
|
program_id: &Pubkey,
|
|
|
|
info: &mut [KeyedAccount],
|
|
|
|
input: &[u8],
|
|
|
|
_tick_height: u64,
|
2019-03-18 10:05:03 -06:00
|
|
|
) -> Result<(), InstructionError> {
|
2018-12-14 12:36:50 -08:00
|
|
|
solana_logger::setup();
|
2018-11-02 17:32:54 -07:00
|
|
|
|
2019-03-11 16:35:25 -06:00
|
|
|
token_program::TokenProgram::process(program_id, info, input).map_err(|e| {
|
|
|
|
error!("error: {:?}", e);
|
2019-03-18 10:05:03 -06:00
|
|
|
InstructionError::CustomError(serialize(&e).unwrap())
|
2018-12-03 13:32:31 -08:00
|
|
|
})
|
2018-11-02 17:32:54 -07:00
|
|
|
}
|