mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-28 12:55:11 +00:00
convert punts and literals
This commit is contained in:
parent
c09c6fc97c
commit
3bd4560d6e
4 changed files with 127 additions and 20 deletions
|
@ -221,12 +221,24 @@ fn convert_tt(tt: &SyntaxNode) -> Option<tt::Subtree> {
|
||||||
if child == first_child || child == last_child || child.kind().is_trivia() {
|
if child == first_child || child == last_child || child.kind().is_trivia() {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
let child = if child.kind() == TOKEN_TREE {
|
let child: tt::TokenTree = if child.kind() == TOKEN_TREE {
|
||||||
convert_tt(child)?.into()
|
convert_tt(child)?.into()
|
||||||
} else if child.kind().is_keyword() {
|
} else if child.kind().is_keyword() || child.kind() == IDENT {
|
||||||
let text = child.leaf_text().unwrap().clone();
|
let text = child.leaf_text().unwrap().clone();
|
||||||
tt::Leaf::from(tt::Ident { text }).into()
|
tt::Leaf::from(tt::Ident { text }).into()
|
||||||
|
} else if child.kind().is_punct() {
|
||||||
|
// FIXME: multibyte tokens
|
||||||
|
tt::Leaf::from(tt::Punct {
|
||||||
|
char: child.text().char_at(0)?,
|
||||||
|
})
|
||||||
|
.into()
|
||||||
|
} else if child.kind().is_literal() {
|
||||||
|
tt::Leaf::from(tt::Literal {
|
||||||
|
text: child.leaf_text().unwrap().clone(),
|
||||||
|
})
|
||||||
|
.into()
|
||||||
} else {
|
} else {
|
||||||
|
log::error!("unknown kind: {:?}", child);
|
||||||
return None;
|
return None;
|
||||||
};
|
};
|
||||||
token_trees.push(child)
|
token_trees.push(child)
|
||||||
|
|
|
@ -24,6 +24,7 @@ Grammar(
|
||||||
["/", "SLASH"],
|
["/", "SLASH"],
|
||||||
["^", "CARET"],
|
["^", "CARET"],
|
||||||
["%", "PERCENT"],
|
["%", "PERCENT"],
|
||||||
|
["_", "UNDERSCORE"],
|
||||||
],
|
],
|
||||||
// Tokens for which the longest match must be chosen (e.g. `..` is a DOTDOT, but `.` is a DOT)
|
// Tokens for which the longest match must be chosen (e.g. `..` is a DOTDOT, but `.` is a DOT)
|
||||||
multi_byte_tokens: [
|
multi_byte_tokens: [
|
||||||
|
@ -99,20 +100,21 @@ Grammar(
|
||||||
"default",
|
"default",
|
||||||
"union",
|
"union",
|
||||||
],
|
],
|
||||||
tokens: [
|
literals: [
|
||||||
"ERROR",
|
|
||||||
"IDENT",
|
|
||||||
"UNDERSCORE",
|
|
||||||
"WHITESPACE",
|
|
||||||
"INT_NUMBER",
|
"INT_NUMBER",
|
||||||
"FLOAT_NUMBER",
|
"FLOAT_NUMBER",
|
||||||
"LIFETIME",
|
|
||||||
"CHAR",
|
"CHAR",
|
||||||
"BYTE",
|
"BYTE",
|
||||||
"STRING",
|
"STRING",
|
||||||
"RAW_STRING",
|
"RAW_STRING",
|
||||||
"BYTE_STRING",
|
"BYTE_STRING",
|
||||||
"RAW_BYTE_STRING",
|
"RAW_BYTE_STRING",
|
||||||
|
],
|
||||||
|
tokens: [
|
||||||
|
"ERROR",
|
||||||
|
"IDENT",
|
||||||
|
"WHITESPACE",
|
||||||
|
"LIFETIME",
|
||||||
"COMMENT",
|
"COMMENT",
|
||||||
"SHEBANG",
|
"SHEBANG",
|
||||||
],
|
],
|
||||||
|
|
|
@ -36,6 +36,7 @@ pub enum SyntaxKind {
|
||||||
SLASH,
|
SLASH,
|
||||||
CARET,
|
CARET,
|
||||||
PERCENT,
|
PERCENT,
|
||||||
|
UNDERSCORE,
|
||||||
DOT,
|
DOT,
|
||||||
DOTDOT,
|
DOTDOT,
|
||||||
DOTDOTDOT,
|
DOTDOTDOT,
|
||||||
|
@ -103,19 +104,18 @@ pub enum SyntaxKind {
|
||||||
AUTO_KW,
|
AUTO_KW,
|
||||||
DEFAULT_KW,
|
DEFAULT_KW,
|
||||||
UNION_KW,
|
UNION_KW,
|
||||||
ERROR,
|
|
||||||
IDENT,
|
|
||||||
UNDERSCORE,
|
|
||||||
WHITESPACE,
|
|
||||||
INT_NUMBER,
|
INT_NUMBER,
|
||||||
FLOAT_NUMBER,
|
FLOAT_NUMBER,
|
||||||
LIFETIME,
|
|
||||||
CHAR,
|
CHAR,
|
||||||
BYTE,
|
BYTE,
|
||||||
STRING,
|
STRING,
|
||||||
RAW_STRING,
|
RAW_STRING,
|
||||||
BYTE_STRING,
|
BYTE_STRING,
|
||||||
RAW_BYTE_STRING,
|
RAW_BYTE_STRING,
|
||||||
|
ERROR,
|
||||||
|
IDENT,
|
||||||
|
WHITESPACE,
|
||||||
|
LIFETIME,
|
||||||
COMMENT,
|
COMMENT,
|
||||||
SHEBANG,
|
SHEBANG,
|
||||||
SOURCE_FILE,
|
SOURCE_FILE,
|
||||||
|
@ -275,6 +275,79 @@ impl SyntaxKind {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn is_punct(self) -> bool {
|
||||||
|
match self {
|
||||||
|
| SEMI
|
||||||
|
| COMMA
|
||||||
|
| L_PAREN
|
||||||
|
| R_PAREN
|
||||||
|
| L_CURLY
|
||||||
|
| R_CURLY
|
||||||
|
| L_BRACK
|
||||||
|
| R_BRACK
|
||||||
|
| L_ANGLE
|
||||||
|
| R_ANGLE
|
||||||
|
| AT
|
||||||
|
| POUND
|
||||||
|
| TILDE
|
||||||
|
| QUESTION
|
||||||
|
| DOLLAR
|
||||||
|
| AMP
|
||||||
|
| PIPE
|
||||||
|
| PLUS
|
||||||
|
| STAR
|
||||||
|
| SLASH
|
||||||
|
| CARET
|
||||||
|
| PERCENT
|
||||||
|
| UNDERSCORE
|
||||||
|
| DOT
|
||||||
|
| DOTDOT
|
||||||
|
| DOTDOTDOT
|
||||||
|
| DOTDOTEQ
|
||||||
|
| COLON
|
||||||
|
| COLONCOLON
|
||||||
|
| EQ
|
||||||
|
| EQEQ
|
||||||
|
| FAT_ARROW
|
||||||
|
| EXCL
|
||||||
|
| NEQ
|
||||||
|
| MINUS
|
||||||
|
| THIN_ARROW
|
||||||
|
| LTEQ
|
||||||
|
| GTEQ
|
||||||
|
| PLUSEQ
|
||||||
|
| MINUSEQ
|
||||||
|
| PIPEEQ
|
||||||
|
| AMPEQ
|
||||||
|
| CARETEQ
|
||||||
|
| SLASHEQ
|
||||||
|
| STAREQ
|
||||||
|
| PERCENTEQ
|
||||||
|
| AMPAMP
|
||||||
|
| PIPEPIPE
|
||||||
|
| SHL
|
||||||
|
| SHR
|
||||||
|
| SHLEQ
|
||||||
|
| SHREQ
|
||||||
|
=> true,
|
||||||
|
_ => false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn is_literal(self) -> bool {
|
||||||
|
match self {
|
||||||
|
| INT_NUMBER
|
||||||
|
| FLOAT_NUMBER
|
||||||
|
| CHAR
|
||||||
|
| BYTE
|
||||||
|
| STRING
|
||||||
|
| RAW_STRING
|
||||||
|
| BYTE_STRING
|
||||||
|
| RAW_BYTE_STRING
|
||||||
|
=> true,
|
||||||
|
_ => false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) fn info(self) -> &'static SyntaxInfo {
|
pub(crate) fn info(self) -> &'static SyntaxInfo {
|
||||||
match self {
|
match self {
|
||||||
SEMI => &SyntaxInfo { name: "SEMI" },
|
SEMI => &SyntaxInfo { name: "SEMI" },
|
||||||
|
@ -299,6 +372,7 @@ impl SyntaxKind {
|
||||||
SLASH => &SyntaxInfo { name: "SLASH" },
|
SLASH => &SyntaxInfo { name: "SLASH" },
|
||||||
CARET => &SyntaxInfo { name: "CARET" },
|
CARET => &SyntaxInfo { name: "CARET" },
|
||||||
PERCENT => &SyntaxInfo { name: "PERCENT" },
|
PERCENT => &SyntaxInfo { name: "PERCENT" },
|
||||||
|
UNDERSCORE => &SyntaxInfo { name: "UNDERSCORE" },
|
||||||
DOT => &SyntaxInfo { name: "DOT" },
|
DOT => &SyntaxInfo { name: "DOT" },
|
||||||
DOTDOT => &SyntaxInfo { name: "DOTDOT" },
|
DOTDOT => &SyntaxInfo { name: "DOTDOT" },
|
||||||
DOTDOTDOT => &SyntaxInfo { name: "DOTDOTDOT" },
|
DOTDOTDOT => &SyntaxInfo { name: "DOTDOTDOT" },
|
||||||
|
@ -366,19 +440,18 @@ impl SyntaxKind {
|
||||||
AUTO_KW => &SyntaxInfo { name: "AUTO_KW" },
|
AUTO_KW => &SyntaxInfo { name: "AUTO_KW" },
|
||||||
DEFAULT_KW => &SyntaxInfo { name: "DEFAULT_KW" },
|
DEFAULT_KW => &SyntaxInfo { name: "DEFAULT_KW" },
|
||||||
UNION_KW => &SyntaxInfo { name: "UNION_KW" },
|
UNION_KW => &SyntaxInfo { name: "UNION_KW" },
|
||||||
ERROR => &SyntaxInfo { name: "ERROR" },
|
|
||||||
IDENT => &SyntaxInfo { name: "IDENT" },
|
|
||||||
UNDERSCORE => &SyntaxInfo { name: "UNDERSCORE" },
|
|
||||||
WHITESPACE => &SyntaxInfo { name: "WHITESPACE" },
|
|
||||||
INT_NUMBER => &SyntaxInfo { name: "INT_NUMBER" },
|
INT_NUMBER => &SyntaxInfo { name: "INT_NUMBER" },
|
||||||
FLOAT_NUMBER => &SyntaxInfo { name: "FLOAT_NUMBER" },
|
FLOAT_NUMBER => &SyntaxInfo { name: "FLOAT_NUMBER" },
|
||||||
LIFETIME => &SyntaxInfo { name: "LIFETIME" },
|
|
||||||
CHAR => &SyntaxInfo { name: "CHAR" },
|
CHAR => &SyntaxInfo { name: "CHAR" },
|
||||||
BYTE => &SyntaxInfo { name: "BYTE" },
|
BYTE => &SyntaxInfo { name: "BYTE" },
|
||||||
STRING => &SyntaxInfo { name: "STRING" },
|
STRING => &SyntaxInfo { name: "STRING" },
|
||||||
RAW_STRING => &SyntaxInfo { name: "RAW_STRING" },
|
RAW_STRING => &SyntaxInfo { name: "RAW_STRING" },
|
||||||
BYTE_STRING => &SyntaxInfo { name: "BYTE_STRING" },
|
BYTE_STRING => &SyntaxInfo { name: "BYTE_STRING" },
|
||||||
RAW_BYTE_STRING => &SyntaxInfo { name: "RAW_BYTE_STRING" },
|
RAW_BYTE_STRING => &SyntaxInfo { name: "RAW_BYTE_STRING" },
|
||||||
|
ERROR => &SyntaxInfo { name: "ERROR" },
|
||||||
|
IDENT => &SyntaxInfo { name: "IDENT" },
|
||||||
|
WHITESPACE => &SyntaxInfo { name: "WHITESPACE" },
|
||||||
|
LIFETIME => &SyntaxInfo { name: "LIFETIME" },
|
||||||
COMMENT => &SyntaxInfo { name: "COMMENT" },
|
COMMENT => &SyntaxInfo { name: "COMMENT" },
|
||||||
SHEBANG => &SyntaxInfo { name: "SHEBANG" },
|
SHEBANG => &SyntaxInfo { name: "SHEBANG" },
|
||||||
SOURCE_FILE => &SyntaxInfo { name: "SOURCE_FILE" },
|
SOURCE_FILE => &SyntaxInfo { name: "SOURCE_FILE" },
|
||||||
|
@ -559,6 +632,7 @@ impl SyntaxKind {
|
||||||
'/' => SLASH,
|
'/' => SLASH,
|
||||||
'^' => CARET,
|
'^' => CARET,
|
||||||
'%' => PERCENT,
|
'%' => PERCENT,
|
||||||
|
'_' => UNDERSCORE,
|
||||||
_ => return None,
|
_ => return None,
|
||||||
};
|
};
|
||||||
Some(tok)
|
Some(tok)
|
||||||
|
|
|
@ -23,7 +23,7 @@ pub enum SyntaxKind {
|
||||||
{% for kw in concat(a=keywords, b=contextual_keywords) %}
|
{% for kw in concat(a=keywords, b=contextual_keywords) %}
|
||||||
{{kw | upper}}_KW,
|
{{kw | upper}}_KW,
|
||||||
{%- endfor -%}
|
{%- endfor -%}
|
||||||
{% for t in concat(a=tokens, b=nodes) %}
|
{% for t in concat(a=literals, b=tokens, c=nodes) %}
|
||||||
{{t}},
|
{{t}},
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
}
|
}
|
||||||
|
@ -40,6 +40,25 @@ impl SyntaxKind {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn is_punct(self) -> bool {
|
||||||
|
match self {
|
||||||
|
{%- for t in concat(a=single_byte_tokens, b=multi_byte_tokens) %}
|
||||||
|
| {{t.1}}
|
||||||
|
{%- endfor %}
|
||||||
|
=> true,
|
||||||
|
_ => false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn is_literal(self) -> bool {
|
||||||
|
match self {
|
||||||
|
{%- for t in literals %}
|
||||||
|
| {{t}}
|
||||||
|
{%- endfor %}
|
||||||
|
=> true,
|
||||||
|
_ => false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) fn info(self) -> &'static SyntaxInfo {
|
pub(crate) fn info(self) -> &'static SyntaxInfo {
|
||||||
match self {
|
match self {
|
||||||
{%- for t in concat(a=single_byte_tokens, b=multi_byte_tokens) %}
|
{%- for t in concat(a=single_byte_tokens, b=multi_byte_tokens) %}
|
||||||
|
@ -48,7 +67,7 @@ impl SyntaxKind {
|
||||||
{% for kw in concat(a=keywords, b=contextual_keywords) %}
|
{% for kw in concat(a=keywords, b=contextual_keywords) %}
|
||||||
{{kw | upper}}_KW => &SyntaxInfo { name: "{{kw | upper}}_KW" },
|
{{kw | upper}}_KW => &SyntaxInfo { name: "{{kw | upper}}_KW" },
|
||||||
{%- endfor -%}
|
{%- endfor -%}
|
||||||
{% for t in concat(a=tokens, b=nodes) %}
|
{% for t in concat(a=literals, b=tokens, c=nodes) %}
|
||||||
{{t}} => &SyntaxInfo { name: "{{t}}" },
|
{{t}} => &SyntaxInfo { name: "{{t}}" },
|
||||||
{%- endfor %}
|
{%- endfor %}
|
||||||
TOMBSTONE => &SyntaxInfo { name: "TOMBSTONE" },
|
TOMBSTONE => &SyntaxInfo { name: "TOMBSTONE" },
|
||||||
|
|
Loading…
Reference in a new issue