diff options
author | Divy Srivastava <dj.srivastava23@gmail.com> | 2022-11-10 03:53:31 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-11-10 17:23:31 +0530 |
commit | bc33a4b2e06dd5518e0d1bbf7b538d0b00df214d (patch) | |
tree | e139e95178892521ecb5807959e324422ed29045 /ops/attrs.rs | |
parent | 92764c0decb370b0f8a78770314ceda7228d315f (diff) |
refactor(ops): Rewrite fast call optimizer and codegen (#16514)
Diffstat (limited to 'ops/attrs.rs')
-rw-r--r-- | ops/attrs.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/ops/attrs.rs b/ops/attrs.rs new file mode 100644 index 000000000..95374ef36 --- /dev/null +++ b/ops/attrs.rs @@ -0,0 +1,37 @@ +// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license. +use syn::{ + parse::{Parse, ParseStream}, + punctuated::Punctuated, + Error, Ident, Result, Token, +}; + +#[derive(Copy, Clone, Debug, Default)] +pub struct Attributes { + pub is_unstable: bool, + pub is_v8: bool, + pub must_be_fast: bool, + pub deferred: bool, +} + +impl Parse for Attributes { + fn parse(input: ParseStream) -> Result<Self> { + let vars = Punctuated::<Ident, Token![,]>::parse_terminated(input)?; + + let vars: Vec<_> = vars.iter().map(Ident::to_string).collect(); + let vars: Vec<_> = vars.iter().map(String::as_str).collect(); + for var in vars.iter() { + if !["unstable", "v8", "fast", "deferred"].contains(var) { + return Err(Error::new( + input.span(), + "invalid attribute, expected one of: unstable, v8, fast, deferred", + )); + } + } + Ok(Self { + is_unstable: vars.contains(&"unstable"), + is_v8: vars.contains(&"v8"), + must_be_fast: vars.contains(&"fast"), + deferred: vars.contains(&"deferred"), + }) + } +} |