Skip to content

Commit

Permalink
lang, ts: Namespace state discriminator (#320)
Browse files Browse the repository at this point in the history
  • Loading branch information
armaniferrante authored May 25, 2021
1 parent 52628bc commit e122936
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 13 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ incremented for features.
## Breaking Changes

* lang: `#[account(associated)]` now requires `init` to be provided to create an associated account. If not provided, then the address will be assumed to exist, and a constraint will be added to ensure its correctness ([#318](https://github.com/project-serum/anchor/pull/318)).
* lang, ts: Change account discriminator pre-image of the `#[state]` account discriminator to be namespaced by "state:". This change should only be noticed by library maintainers ([#320](https://github.com/project-serum/anchor/pull/320)).
* lang, ts: Change domain delimiters for the pre-image of the instruciton sighash to be a single colon `:` to be consistent with accounts. This change should only be noticed by library maintainers.

## [0.6.0] - 2021-05-23
Expand Down
28 changes: 19 additions & 9 deletions lang/attribute/account/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,14 +57,24 @@ pub fn account(
args: proc_macro::TokenStream,
input: proc_macro::TokenStream,
) -> proc_macro::TokenStream {
let namespace = args.to_string().replace("\"", "");
let is_zero_copy = match args.into_iter().next() {
None => false,
Some(tt) => match tt {
proc_macro::TokenTree::Literal(_) => false,
_ => namespace == "zero_copy",
},
};
let mut namespace = "".to_string();
let mut is_zero_copy = false;
if args.to_string().split(",").collect::<Vec<_>>().len() > 2 {
panic!("Only two args are allowed to the account attribute.")
}
for arg in args.to_string().split(",") {
let ns = arg
.to_string()
.replace("\"", "")
.chars()
.filter(|c| !c.is_whitespace())
.collect();
if ns == "zero_copy" {
is_zero_copy = true;
} else {
namespace = ns;
}
}

let account_strct = parse_macro_input!(input as syn::ItemStruct);
let account_name = &account_strct.ident;
Expand All @@ -73,7 +83,7 @@ pub fn account(
// Namespace the discriminator to prevent collisions.
let discriminator_preimage = {
// For now, zero copy accounts can't be namespaced.
if is_zero_copy || namespace.is_empty() {
if namespace.is_empty() {
format!("account:{}", account_name.to_string())
} else {
format!("{}:{}", namespace, account_name.to_string())
Expand Down
4 changes: 2 additions & 2 deletions lang/attribute/state/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -71,8 +71,8 @@ pub fn state(
};

let attribute = match is_zero_copy {
false => quote! {#[account]},
true => quote! {#[account(zero_copy)]},
false => quote! {#[account("state")]},
true => quote! {#[account("state", zero_copy)]},
};

proc_macro::TokenStream::from(quote! {
Expand Down
3 changes: 1 addition & 2 deletions ts/src/coder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -340,7 +340,6 @@ class IdlCoder {
case "publicKey": {
return borsh.publicKey(fieldName);
}
// TODO: all the other types that need to be exported by the borsh package.
default: {
// @ts-ignore
if (field.type.vec) {
Expand Down Expand Up @@ -452,7 +451,7 @@ export async function accountDiscriminator(name: string): Promise<Buffer> {
// Calculates unique 8 byte discriminator prepended to all anchor state accounts.
export async function stateDiscriminator(name: string): Promise<Buffer> {
// @ts-ignore
return Buffer.from(sha256.digest(`account:${name}`)).slice(0, 8);
return Buffer.from(sha256.digest(`state:${name}`)).slice(0, 8);
}

export function eventDiscriminator(name: string): Buffer {
Expand Down

0 comments on commit e122936

Please sign in to comment.