From 6e4480c8effc54360e19d131afcf7859c933f2c7 Mon Sep 17 00:00:00 2001 From: Aryeh Hillman Date: Tue, 7 May 2024 17:31:53 -0700 Subject: [PATCH] Implement reading `SyntaxKind` from strings --- Cargo.lock | 58 +++++++++++++++++++++++++++++++++++++++++++++------- Cargo.toml | 2 ++ src/kinds.rs | 15 +++++++++++++- 3 files changed, 67 insertions(+), 8 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 353f276..48f270d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -209,6 +209,12 @@ version = "0.12.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" +[[package]] +name = "heck" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" + [[package]] name = "hermit-abi" version = "0.1.19" @@ -345,18 +351,18 @@ dependencies = [ [[package]] name = "proc-macro2" -version = "1.0.40" +version = "1.0.82" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dd96a1e8ed2596c337f8eae5f24924ec83f5ad5ab21ea8e455d3566c69fbcaf7" +checksum = "8ad3d49ab951a01fbaafe34f2ec74122942fe18a3f9814c3268f1bb72042131b" dependencies = [ "unicode-ident", ] [[package]] name = "quote" -version = "1.0.20" +version = "1.0.36" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3bcdf212e9776fbcb2d23ab029360416bb1706b1aea2d1a5ba002727cbcab804" +checksum = "0fa76aaf39101c457836aec0ce2316dbdc3ab723cdda1c6bd4e6ad4208acaca7" dependencies = [ "proc-macro2", ] @@ -413,6 +419,8 @@ dependencies = [ "criterion", "expect-test", "rowan", + "strum", + "strum_macros", ] [[package]] @@ -434,6 +442,12 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2" +[[package]] +name = "rustversion" +version = "1.0.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "092474d1a01ea8278f69e6a358998405fae5b8b963ddaeb2b0b04a128bf1dfb0" + [[package]] name = "ryu" version = "1.0.10" @@ -479,7 +493,7 @@ checksum = "6f2122636b9fe3b81f1cb25099fcf2d3f542cdb1d45940d56c713158884a05da" dependencies = [ "proc-macro2", "quote", - "syn", + "syn 1.0.98", ] [[package]] @@ -493,6 +507,25 @@ dependencies = [ "serde", ] +[[package]] +name = "strum" +version = "0.26.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5d8cec3501a5194c432b2b7976db6b7d10ec95c253208b45f83f7136aa985e29" + +[[package]] +name = "strum_macros" +version = "0.26.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c6cf59daf282c0a494ba14fd21610a0325f9f90ec9d1231dea26bcb1d696c946" +dependencies = [ + "heck", + "proc-macro2", + "quote", + "rustversion", + "syn 2.0.61", +] + [[package]] name = "syn" version = "1.0.98" @@ -504,6 +537,17 @@ dependencies = [ "unicode-ident", ] +[[package]] +name = "syn" +version = "2.0.61" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c993ed8ccba56ae856363b1845da7266a7cb78e1d146c8a32d54b45a8b831fc9" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + [[package]] name = "text-size" version = "1.1.0" @@ -573,7 +617,7 @@ dependencies = [ "log", "proc-macro2", "quote", - "syn", + "syn 1.0.98", "wasm-bindgen-shared", ] @@ -595,7 +639,7 @@ checksum = "7d94ac45fcf608c1f45ef53e748d35660f168490c10b23704c7779ab8f5c3048" dependencies = [ "proc-macro2", "quote", - "syn", + "syn 1.0.98", "wasm-bindgen-backend", "wasm-bindgen-shared", ] diff --git a/Cargo.toml b/Cargo.toml index 9ee294f..f10bf7d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -14,6 +14,8 @@ name = "all-packages" [dependencies] rowan = "0.15.0" +strum = "0.26.2" +strum_macros = "0.26.2" [dev-dependencies] criterion = "0.3.0" diff --git a/src/kinds.rs b/src/kinds.rs index 69035a1..7ffdd34 100644 --- a/src/kinds.rs +++ b/src/kinds.rs @@ -1,4 +1,6 @@ -#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] +use strum_macros::EnumString; + +#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, EnumString)] #[repr(u16)] #[allow(non_camel_case_types)] pub enum SyntaxKind { @@ -134,3 +136,14 @@ impl SyntaxKind { matches!(self, TOKEN_COMMENT | TOKEN_ERROR | TOKEN_WHITESPACE) } } + +#[cfg(test)] +mod tests { + use crate::SyntaxKind; + + #[test] + fn try_from() { + let kind = SyntaxKind::try_from("TOKEN_COMMENT").unwrap(); + assert_eq!(kind, SyntaxKind::TOKEN_COMMENT); + } +}