Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Error redesign #1462

Merged
merged 119 commits into from
Feb 20, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
119 commits
Select commit Hold shift + click to select a range
6ab5f86
WIP
paul-schaaf Feb 17, 2022
c1b7ffb
accounts work
paul-schaaf Feb 17, 2022
fefeee9
WIP
paul-schaaf Feb 17, 2022
c699deb
WIP
paul-schaaf Feb 17, 2022
26099aa
WIP
paul-schaaf Feb 17, 2022
826061e
constraints
paul-schaaf Feb 17, 2022
b158759
constraints
paul-schaaf Feb 17, 2022
31d63cb
constraints
paul-schaaf Feb 17, 2022
bbf4c93
WIP
paul-schaaf Feb 17, 2022
ff49753
LANG COMPILES
paul-schaaf Feb 17, 2022
d4c6133
fmt and clippy
paul-schaaf Feb 17, 2022
8093770
require!
paul-schaaf Feb 17, 2022
b2621c3
WIP
paul-schaaf Feb 17, 2022
dee9580
WIP
paul-schaaf Feb 17, 2022
d476718
WIP
paul-schaaf Feb 17, 2022
0903b06
WIP
paul-schaaf Feb 17, 2022
d5b840b
WIP
paul-schaaf Feb 17, 2022
3a433f4
WIP
paul-schaaf Feb 17, 2022
e7f1fcf
WIP
paul-schaaf Feb 17, 2022
5677031
LANG AND BARE-BONES PROGRAM COMPILES
paul-schaaf Feb 17, 2022
fe0a48f
basic program now also works with build-bpf instead of just build
paul-schaaf Feb 17, 2022
ea5edcd
WIP
paul-schaaf Feb 17, 2022
ffb113e
remove program id from error for now
paul-schaaf Feb 18, 2022
c5dc814
error! now returns Error instead of Err(Error)
paul-schaaf Feb 18, 2022
c501266
remove unused code
paul-schaaf Feb 18, 2022
bf1f0ad
error_with_account_name
paul-schaaf Feb 18, 2022
37c9998
ProgramErrorWithoutOrigin and errors from types
paul-schaaf Feb 18, 2022
fe460c3
fix spl token
paul-schaaf Feb 18, 2022
25815bb
add todo
paul-schaaf Feb 18, 2022
573f507
make client compile
paul-schaaf Feb 18, 2022
211e59f
clippy
paul-schaaf Feb 18, 2022
4e12959
dont use format to error_name
paul-schaaf Feb 19, 2022
34dbacb
error_without_origin for DeclaredProgramIdMismatch error
paul-schaaf Feb 19, 2022
fe050d6
add all error structures to prelude
paul-schaaf Feb 19, 2022
8087460
fix tests
paul-schaaf Feb 19, 2022
234ca57
adjust idl creation to use error_codes instead of error attribute
paul-schaaf Feb 19, 2022
5667345
fix error tests
paul-schaaf Feb 19, 2022
08a48d4
fmt
paul-schaaf Feb 19, 2022
8671951
add todos
paul-schaaf Feb 19, 2022
aa64f5a
fix basic4
paul-schaaf Feb 19, 2022
32a20dc
fmt
paul-schaaf Feb 19, 2022
0810228
fix cashiers-check
paul-schaaf Feb 19, 2022
11b8a77
error_with_account_name for all constraint errors
paul-schaaf Feb 19, 2022
a772cfc
fix compile errors
paul-schaaf Feb 19, 2022
5411764
fix basic3 example
paul-schaaf Feb 19, 2022
fbd8037
fmt
paul-schaaf Feb 19, 2022
121080a
fix interface test
paul-schaaf Feb 19, 2022
6a51b4a
fix chat tests
paul-schaaf Feb 19, 2022
365fce1
close now uses error_without_origin
paul-schaaf Feb 19, 2022
646a60d
try_account ix deser now uses error_without_origin
paul-schaaf Feb 19, 2022
65f6126
fix lockup test
paul-schaaf Feb 19, 2022
c56e401
ido pool
paul-schaaf Feb 19, 2022
ea4532c
fix misc test
paul-schaaf Feb 19, 2022
0f8d1ec
fix multisig test
paul-schaaf Feb 19, 2022
cf42ee4
fix swap test
paul-schaaf Feb 19, 2022
51706fa
AnchorResult -> Result
paul-schaaf Feb 19, 2022
ef4cd3f
entry function use ProgramResult with full path
paul-schaaf Feb 19, 2022
ecd9cb8
anchor_lang::Result -> Result
paul-schaaf Feb 19, 2022
9b944b6
fmt
paul-schaaf Feb 19, 2022
70b19ea
clippy
paul-schaaf Feb 19, 2022
59d0f7f
fmt
paul-schaaf Feb 19, 2022
a72c384
add Result<()> spl crate compile
paul-schaaf Feb 19, 2022
0152d9a
spl dex crate compile
paul-schaaf Feb 19, 2022
c4f7468
fix tests
paul-schaaf Feb 19, 2022
10553cb
fix composite test
paul-schaaf Feb 19, 2022
0fe7409
fmt
paul-schaaf Feb 19, 2022
1761d57
fix events test
paul-schaaf Feb 19, 2022
ac83700
fix examples tests
paul-schaaf Feb 19, 2022
207857d
fix more tests
paul-schaaf Feb 19, 2022
5528173
revert custom-coder back to master
paul-schaaf Feb 19, 2022
599461f
Merge branch 'master' into error-redesign
paul-schaaf Feb 19, 2022
e953f17
fix floats test
paul-schaaf Feb 19, 2022
64ab4c0
run all test except those with submodules
paul-schaaf Feb 19, 2022
7eb0d06
fix interface tests
paul-schaaf Feb 19, 2022
8deaeff
fix TODOs
paul-schaaf Feb 19, 2022
571210d
fix todos
paul-schaaf Feb 19, 2022
61eb0eb
fix todos
paul-schaaf Feb 19, 2022
f9323f3
fix todo
paul-schaaf Feb 19, 2022
17290eb
remove todo
paul-schaaf Feb 19, 2022
ddae8c6
fmt
paul-schaaf Feb 19, 2022
1946f2f
fix auctionhouse tests
paul-schaaf Feb 19, 2022
c5fca8a
swap was already working
paul-schaaf Feb 19, 2022
a98b228
fix cfo test
paul-schaaf Feb 19, 2022
6f111e1
add docs todo
paul-schaaf Feb 19, 2022
fdf6578
error_codes -> error_code
paul-schaaf Feb 19, 2022
bce05b1
move error parsing into syn crate
paul-schaaf Feb 19, 2022
2630cdd
refactor error
paul-schaaf Feb 20, 2022
30cbcb9
update docs
paul-schaaf Feb 20, 2022
5abac35
fix error macro
paul-schaaf Feb 20, 2022
064e527
add require! test
paul-schaaf Feb 20, 2022
21f3281
Fix error test
paul-schaaf Feb 20, 2022
283f43c
lang: add bail! macro
paul-schaaf Feb 20, 2022
ef2f181
docs
paul-schaaf Feb 20, 2022
2bb6be8
lang: fix ProgramError logging
paul-schaaf Feb 20, 2022
43a200f
tests: add tests for error logging
paul-schaaf Feb 20, 2022
007eafc
ci: turn off fail-fast for matrix
paul-schaaf Feb 20, 2022
7647c04
lang: remove TODO
paul-schaaf Feb 20, 2022
e6ea718
fmt
paul-schaaf Feb 20, 2022
39209ca
ts: ts library can now also parse real tx errors instead of just simu…
paul-schaaf Feb 20, 2022
c8904ae
tests: fix error tests
paul-schaaf Feb 20, 2022
69f89a3
tests: add sleep to errors test to allow logs to come in
paul-schaaf Feb 20, 2022
13dcede
tests: fix sleep
paul-schaaf Feb 20, 2022
3692e9c
tests fix sleep placement
paul-schaaf Feb 20, 2022
39e1719
remove dead todo
paul-schaaf Feb 20, 2022
c99d335
docs: changelog
paul-schaaf Feb 20, 2022
22fbe6c
lang: add with_source method on Error type so ProgramErrors can be en…
paul-schaaf Feb 20, 2022
c83e28f
lang: remove error_without_origin
paul-schaaf Feb 20, 2022
34ea949
pe.into() -> Into::into
paul-schaaf Feb 20, 2022
93b6bd3
.into() -> Error::from()
paul-schaaf Feb 20, 2022
a7ae6ae
bail! -> err!
paul-schaaf Feb 20, 2022
d85a310
tests: use err!
paul-schaaf Feb 20, 2022
62b9902
lang: use .map_err again in close
paul-schaaf Feb 20, 2022
88e4510
lang: import anchor_lang::Result
paul-schaaf Feb 20, 2022
9f40e76
tests: fix lockup test
paul-schaaf Feb 20, 2022
aeca9a3
try not using Error::from
armaniferrante Feb 20, 2022
0148808
Update lang/attribute/interface/src/lib.rs
armaniferrante Feb 20, 2022
68c5188
fmt import
armaniferrante Feb 20, 2022
9dc873b
fmt more imports
armaniferrante Feb 20, 2022
a3bb227
update submodule pointers
armaniferrante Feb 20, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion lang/attribute/state/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ pub fn state(
fn size(&self) -> anchor_lang::Result<u64> {
Ok(8 + self
.try_to_vec()
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::AccountDidNotSerialize))?
armaniferrante marked this conversation as resolved.
Show resolved Hide resolved
.map_err(|_| anchor_lang::error::ErrorCode::AccountDidNotSerialize)?
.len() as u64)
}
}
Expand Down
2 changes: 1 addition & 1 deletion lang/syn/src/codegen/accounts/try_accounts.rs
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ pub fn generate(accs: &AccountsStruct) -> proc_macro2::TokenStream {
let __Args {
#(#field_names),*
} = __Args::deserialize(&mut ix_data)
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
}
}
};
Expand Down
2 changes: 1 addition & 1 deletion lang/syn/src/codegen/program/cpi.rs
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
let ix = {
let ix = instruction::#ix_variant;
let mut ix_data = AnchorSerialize::try_to_vec(&ix)
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotSerialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotSerialize)?;
let mut data = #sighash_tts.to_vec();
data.append(&mut ix_data);
let accounts = ctx.to_account_metas(None);
Expand Down
2 changes: 1 addition & 1 deletion lang/syn/src/codegen/program/dispatch.rs
Original file line number Diff line number Diff line change
Expand Up @@ -114,7 +114,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
})
.collect();
let fallback_fn = gen_fallback(program).unwrap_or(quote! {
Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionFallbackNotFound))
Err(anchor_lang::error::ErrorCode::InstructionFallbackNotFound.into())
});
quote! {
/// Performs method dispatch.
Expand Down
4 changes: 2 additions & 2 deletions lang/syn/src/codegen/program/entry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ use quote::quote;
pub fn generate(program: &Program) -> proc_macro2::TokenStream {
let name: proc_macro2::TokenStream = program.name.to_string().to_camel_case().parse().unwrap();
let fallback_maybe = dispatch::gen_fallback(program).unwrap_or(quote! {
Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionMissing))
Err(anchor_lang::error::ErrorCode::InstructionMissing.into())
});
quote! {
#[cfg(not(feature = "no-entrypoint"))]
Expand Down Expand Up @@ -64,7 +64,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
msg!("anchor-debug is active");
}
if *program_id != ID {
return Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::DeclaredProgramIdMismatch));
return Err(anchor_lang::error::ErrorCode::DeclaredProgramIdMismatch.into());
}
if data.len() < 8 {
return #fallback_maybe;
Expand Down
27 changes: 12 additions & 15 deletions lang/syn/src/codegen/program/handlers.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
let mut data: &[u8] = idl_ix_data;

let ix = anchor_lang::idl::IdlInstruction::deserialize(&mut data)
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;

match ix {
anchor_lang::idl::IdlInstruction::Create { data_len } => {
Expand Down Expand Up @@ -66,7 +66,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
#[inline(never)]
#[cfg(feature = "no-idl")]
pub fn __idl_dispatch(program_id: &Pubkey, accounts: &[AccountInfo], idl_ix_data: &[u8]) -> anchor_lang::Result<()> {
Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::IdlInstructionStub))
Err(anchor_lang::error::ErrorCode::IdlInstructionStub.into())
}

// One time IDL account initializer. Will faill on subsequent
Expand All @@ -81,7 +81,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
anchor_lang::prelude::msg!("Instruction: IdlCreateAccount");

if program_id != accounts.program.key {
return Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::IdlInstructionInvalidProgram));
return Err(anchor_lang::error::ErrorCode::IdlInstructionInvalidProgram.into());
}
// Create the IDL's account.
let from = accounts.from.key;
Expand Down Expand Up @@ -212,7 +212,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {

// Deserialize instruction data.
let ix = instruction::state::#ix_name::deserialize(&mut &ix_data[..])
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
let instruction::state::#variant_arm = ix;

let mut __bumps = std::collections::BTreeMap::new();
Expand Down Expand Up @@ -291,7 +291,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {

// Deserialize instruction data.
let ix = instruction::state::#ix_name::deserialize(&mut &ix_data[..])
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
let instruction::state::#variant_arm = ix;

let mut __bumps = std::collections::BTreeMap::new();
Expand Down Expand Up @@ -399,7 +399,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {

// Deserialize instruction.
let ix = instruction::state::#ix_name::deserialize(&mut &ix_data[..])
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
let instruction::state::#variant_arm = ix;

// Bump collector.
Expand All @@ -408,7 +408,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
// Load state.
let mut remaining_accounts: &[AccountInfo] = accounts;
if remaining_accounts.is_empty() {
return Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::AccountNotEnoughKeys));
return Err(anchor_lang::error::ErrorCode::AccountNotEnoughKeys.into());
}
let loader: anchor_lang::accounts::loader::Loader<#mod_name::#name> = anchor_lang::accounts::loader::Loader::try_accounts(program_id, &mut remaining_accounts, &[], &mut __bumps)?;

Expand Down Expand Up @@ -455,8 +455,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {

// Deserialize instruction.
let ix = instruction::state::#ix_name::deserialize(&mut &ix_data[..])
.map_err(|_|
anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
let instruction::state::#variant_arm = ix;

// Bump collector.
Expand All @@ -465,7 +464,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
// Load state.
let mut remaining_accounts: &[AccountInfo] = accounts;
if remaining_accounts.is_empty() {
return Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::AccountNotEnoughKeys));
return Err(anchor_lang::error::ErrorCode::AccountNotEnoughKeys.into());
}
let mut state: anchor_lang::accounts::state::ProgramState<#state_ty> = anchor_lang::accounts::state::ProgramState::try_accounts(
program_id,
Expand Down Expand Up @@ -567,7 +566,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
let deserialize_instruction = quote! {
#args_struct
let ix = Args::deserialize(&mut &ix_data[..])
.map_err(|_| anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize))?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
let Args {
#(#ix_arg_names),*
} = ix;
Expand All @@ -593,7 +592,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {
// Deserialize the program state account.
let mut remaining_accounts: &[AccountInfo] = accounts;
if remaining_accounts.is_empty() {
return Err(anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::AccountNotEnoughKeys));
return Err(anchor_lang::error::ErrorCode::AccountNotEnoughKeys.into());
}
let mut state: anchor_lang::accounts::state::ProgramState<#state_ty> = anchor_lang::accounts::state::ProgramState::try_accounts(
program_id,
Expand Down Expand Up @@ -707,9 +706,7 @@ pub fn generate(program: &Program) -> proc_macro2::TokenStream {

// Deserialize data.
let ix = instruction::#ix_name::deserialize(&mut &ix_data[..])
.map_err(|_|
anchor_lang::error::Error::from(anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)
)?;
.map_err(|_| anchor_lang::error::ErrorCode::InstructionDidNotDeserialize)?;
let instruction::#variant_arm = ix;

// Bump collector.
Expand Down