pub len: TextUnit,
}
-macro_rules! match_literal_kind {
- ($kind:expr) => {
- match $kind {
- ra_rustc_lexer::LiteralKind::Int { .. } => INT_NUMBER,
- ra_rustc_lexer::LiteralKind::Float { .. } => FLOAT_NUMBER,
- ra_rustc_lexer::LiteralKind::Char { .. } => CHAR,
- ra_rustc_lexer::LiteralKind::Byte { .. } => BYTE,
- ra_rustc_lexer::LiteralKind::Str { .. } => STRING,
- ra_rustc_lexer::LiteralKind::ByteStr { .. } => BYTE_STRING,
- ra_rustc_lexer::LiteralKind::RawStr { .. } => RAW_STRING,
- ra_rustc_lexer::LiteralKind::RawByteStr { .. } => RAW_BYTE_STRING,
- }
- };
+fn match_literal_kind(kind: ra_rustc_lexer::LiteralKind) -> SyntaxKind {
+ match kind {
+ ra_rustc_lexer::LiteralKind::Int { .. } => INT_NUMBER,
+ ra_rustc_lexer::LiteralKind::Float { .. } => FLOAT_NUMBER,
+ ra_rustc_lexer::LiteralKind::Char { .. } => CHAR,
+ ra_rustc_lexer::LiteralKind::Byte { .. } => BYTE,
+ ra_rustc_lexer::LiteralKind::Str { .. } => STRING,
+ ra_rustc_lexer::LiteralKind::ByteStr { .. } => BYTE_STRING,
+ ra_rustc_lexer::LiteralKind::RawStr { .. } => RAW_STRING,
+ ra_rustc_lexer::LiteralKind::RawByteStr { .. } => RAW_BYTE_STRING,
+ }
}
/// Break a string up into its component tokens
}
}
ra_rustc_lexer::TokenKind::RawIdent => IDENT,
- ra_rustc_lexer::TokenKind::Literal { kind, .. } => match_literal_kind!(kind),
+ ra_rustc_lexer::TokenKind::Literal { kind, .. } => match_literal_kind(kind),
ra_rustc_lexer::TokenKind::Lifetime { .. } => LIFETIME,
ra_rustc_lexer::TokenKind::Semi => SEMI,
ra_rustc_lexer::TokenKind::Comma => COMMA,
return None;
}
let kind = match t.kind {
- ra_rustc_lexer::TokenKind::Literal { kind, .. } => match_literal_kind!(kind),
+ ra_rustc_lexer::TokenKind::Literal { kind, .. } => match_literal_kind(kind),
_ => return None,
};
Some(Token { kind, len: TextUnit::from_usize(t.len) })