Improve macro limit error and move to const

This commit is contained in:
Jonas Schievink 2020-12-10 17:50:56 +01:00
parent a6c8098113
commit 614e5a2272

View file

@ -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, &macro_arg.0); let ExpandResult { value: tt, err } = macro_rules.0.expand(db, lazy_id, &macro_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,
)); ));
} }