mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 11:55:04 +00:00
Improve macro limit error and move to const
This commit is contained in:
parent
a6c8098113
commit
614e5a2272
1 changed files with 9 additions and 3 deletions
|
@ -13,6 +13,12 @@ use crate::{
|
||||||
MacroFile, ProcMacroExpander,
|
MacroFile, ProcMacroExpander,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// Total limit on the number of tokens produced by any macro invocation.
|
||||||
|
///
|
||||||
|
/// If an invocation produces more tokens than this limit, it will not be stored in the database and
|
||||||
|
/// an error will be emitted.
|
||||||
|
const TOKEN_LIMIT: usize = 262144;
|
||||||
|
|
||||||
#[derive(Debug, Clone, Eq, PartialEq)]
|
#[derive(Debug, Clone, Eq, PartialEq)]
|
||||||
pub enum TokenExpander {
|
pub enum TokenExpander {
|
||||||
MacroRules(mbe::MacroRules),
|
MacroRules(mbe::MacroRules),
|
||||||
|
@ -227,10 +233,10 @@ fn macro_expand_with_arg(
|
||||||
let ExpandResult { value: tt, err } = macro_rules.0.expand(db, lazy_id, ¯o_arg.0);
|
let ExpandResult { value: tt, err } = macro_rules.0.expand(db, lazy_id, ¯o_arg.0);
|
||||||
// Set a hard limit for the expanded tt
|
// Set a hard limit for the expanded tt
|
||||||
let count = tt.count();
|
let count = tt.count();
|
||||||
if count > 262144 {
|
if count > TOKEN_LIMIT {
|
||||||
return ExpandResult::str_err(format!(
|
return ExpandResult::str_err(format!(
|
||||||
"Total tokens count exceed limit : count = {}",
|
"macro invocation exceeds token limit: produced {} tokens, limit is {}",
|
||||||
count
|
count, TOKEN_LIMIT,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue