2021-05-24 14:47:01 -05:00
|
|
|
//! Mapping between `TokenId`s and the token's position in macro definitions or inputs.
|
|
|
|
|
2021-08-21 11:06:03 -05:00
|
|
|
use std::hash::Hash;
|
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
use syntax::TextRange;
|
|
|
|
use tt::Span;
|
|
|
|
|
|
|
|
// pub type HirFile = u32;
|
|
|
|
// pub type FileRange = (HirFile, TextRange);
|
|
|
|
// Option<MacroCallId>, LocalSyntaxContet
|
|
|
|
// pub type SyntaxContext = ();
|
|
|
|
// pub type LocalSyntaxContext = u32;
|
|
|
|
|
|
|
|
/// Maps absolute text ranges for the corresponding file to the relevant span data.
|
|
|
|
#[derive(Debug, PartialEq, Eq, Clone, Hash)]
|
|
|
|
// FIXME: Rename to SpanMap
|
|
|
|
pub struct TokenMap<S> {
|
|
|
|
// FIXME: This needs to be sorted by (FileId, AstId)
|
|
|
|
// Then we can do a binary search on the file id,
|
|
|
|
// then a bin search on the ast id
|
|
|
|
pub span_map: Vec<(TextRange, S)>,
|
|
|
|
// span_map2: rustc_hash::FxHashMap<TextRange, usize>,
|
2021-05-24 11:43:42 -05:00
|
|
|
}
|
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
impl<S> Default for TokenMap<S> {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self { span_map: Vec::new() }
|
2021-05-24 11:43:42 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
impl<S: Span> TokenMap<S> {
|
2021-05-24 11:43:42 -05:00
|
|
|
pub(crate) fn shrink_to_fit(&mut self) {
|
2023-09-29 05:37:57 -05:00
|
|
|
self.span_map.shrink_to_fit();
|
2022-02-08 11:13:18 -06:00
|
|
|
}
|
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
pub(crate) fn insert(&mut self, range: TextRange, span: S) {
|
|
|
|
self.span_map.push((range, span));
|
2021-05-24 11:43:42 -05:00
|
|
|
}
|
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
pub fn ranges_with_span(&self, span: S) -> impl Iterator<Item = TextRange> + '_ {
|
|
|
|
self.span_map.iter().filter_map(
|
|
|
|
move |(range, s)| {
|
|
|
|
if s == &span {
|
|
|
|
Some(*range)
|
|
|
|
} else {
|
|
|
|
None
|
|
|
|
}
|
|
|
|
},
|
|
|
|
)
|
2021-05-24 11:43:42 -05:00
|
|
|
}
|
2023-07-13 02:17:07 -05:00
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
pub fn span_for_range(&self, range: TextRange) -> Option<S> {
|
|
|
|
self.span_map.iter().find_map(|(r, s)| if r == &range { Some(s.clone()) } else { None })
|
2023-07-13 02:17:07 -05:00
|
|
|
}
|
2023-07-31 10:12:17 -05:00
|
|
|
|
2023-09-29 05:37:57 -05:00
|
|
|
// pub fn ranges_by_token(
|
|
|
|
// &self,
|
|
|
|
// token_id: tt::TokenId,
|
|
|
|
// kind: SyntaxKind,
|
|
|
|
// ) -> impl Iterator<Item = TextRange> + '_ {
|
|
|
|
// self.entries
|
|
|
|
// .iter()
|
|
|
|
// .filter(move |&&(tid, _)| tid == token_id)
|
|
|
|
// .filter_map(move |(_, range)| range.by_kind(kind))
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub(crate) fn remove_delim(&mut self, idx: usize) {
|
|
|
|
// // FIXME: This could be accidentally quadratic
|
|
|
|
// self.entries.remove(idx);
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub fn entries(&self) -> impl Iterator<Item = (tt::TokenId, TextRange)> + '_ {
|
|
|
|
// self.entries.iter().filter_map(|&(tid, tr)| match tr {
|
|
|
|
// TokenTextRange::Token(range) => Some((tid, range)),
|
|
|
|
// TokenTextRange::Delimiter(_) => None,
|
|
|
|
// })
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub fn filter(&mut self, id: impl Fn(tt::TokenId) -> bool) {
|
|
|
|
// self.entries.retain(|&(tid, _)| id(tid));
|
|
|
|
// }
|
|
|
|
// pub fn synthetic_token_id(&self, token_id: tt::TokenId) -> Option<SyntheticTokenId> {
|
|
|
|
// self.synthetic_entries.iter().find(|(tid, _)| *tid == token_id).map(|(_, id)| *id)
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub fn first_range_by_token(
|
|
|
|
// &self,
|
|
|
|
// token_id: tt::TokenId,
|
|
|
|
// kind: SyntaxKind,
|
|
|
|
// ) -> Option<TextRange> {
|
|
|
|
// self.ranges_by_token(token_id, kind).next()
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub(crate) fn insert(&mut self, token_id: tt::TokenId, relative_range: TextRange) {
|
|
|
|
// self.entries.push((token_id, TokenTextRange::Token(relative_range)));
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub(crate) fn insert_synthetic(&mut self, token_id: tt::TokenId, id: SyntheticTokenId) {
|
|
|
|
// self.synthetic_entries.push((token_id, id));
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub(crate) fn insert_delim(
|
|
|
|
// &mut self,
|
|
|
|
// token_id: tt::TokenId,
|
|
|
|
// open_relative_range: TextRange,
|
|
|
|
// close_relative_range: TextRange,
|
|
|
|
// ) -> usize {
|
|
|
|
// let res = self.entries.len();
|
|
|
|
// let cover = open_relative_range.cover(close_relative_range);
|
|
|
|
|
|
|
|
// self.entries.push((token_id, TokenTextRange::Delimiter(cover)));
|
|
|
|
// res
|
|
|
|
// }
|
|
|
|
|
|
|
|
// pub(crate) fn update_close_delim(&mut self, idx: usize, close_relative_range: TextRange) {
|
|
|
|
// let (_, token_text_range) = &mut self.entries[idx];
|
|
|
|
// if let TokenTextRange::Delimiter(dim) = token_text_range {
|
|
|
|
// let cover = dim.cover(close_relative_range);
|
|
|
|
// *token_text_range = TokenTextRange::Delimiter(cover);
|
|
|
|
// }
|
|
|
|
// }
|
2021-05-24 11:43:42 -05:00
|
|
|
}
|