mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 05:38:46 +00:00
Reduce string copying
This commit is contained in:
parent
5b86ff3e91
commit
f1ffd14922
1 changed files with 16 additions and 14 deletions
|
@ -414,7 +414,7 @@ trait TokenConvertor {
|
||||||
fn id_alloc(&mut self) -> &mut TokenIdAlloc;
|
fn id_alloc(&mut self) -> &mut TokenIdAlloc;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> SrcToken for (RawToken, &'a str) {
|
impl<'a> SrcToken for (&'a RawToken, &'a str) {
|
||||||
fn kind(&self) -> SyntaxKind {
|
fn kind(&self) -> SyntaxKind {
|
||||||
self.0.kind
|
self.0.kind
|
||||||
}
|
}
|
||||||
|
@ -431,7 +431,7 @@ impl<'a> SrcToken for (RawToken, &'a str) {
|
||||||
impl RawConvertor<'_> {}
|
impl RawConvertor<'_> {}
|
||||||
|
|
||||||
impl<'a> TokenConvertor for RawConvertor<'a> {
|
impl<'a> TokenConvertor for RawConvertor<'a> {
|
||||||
type Token = (RawToken, &'a str);
|
type Token = (&'a RawToken, &'a str);
|
||||||
|
|
||||||
fn convert_doc_comment(&self, token: &Self::Token) -> Option<Vec<tt::TokenTree>> {
|
fn convert_doc_comment(&self, token: &Self::Token) -> Option<Vec<tt::TokenTree>> {
|
||||||
convert_doc_comment(&doc_comment(token.1))
|
convert_doc_comment(&doc_comment(token.1))
|
||||||
|
@ -442,11 +442,11 @@ impl<'a> TokenConvertor for RawConvertor<'a> {
|
||||||
let range = TextRange::at(self.offset, token.len);
|
let range = TextRange::at(self.offset, token.len);
|
||||||
self.offset += token.len;
|
self.offset += token.len;
|
||||||
|
|
||||||
Some(((*token, &self.text[range]), range))
|
Some(((token, &self.text[range]), range))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn peek(&self) -> Option<Self::Token> {
|
fn peek(&self) -> Option<Self::Token> {
|
||||||
let token = self.inner.as_slice().get(0).cloned();
|
let token = self.inner.as_slice().get(0);
|
||||||
|
|
||||||
token.map(|it| {
|
token.map(|it| {
|
||||||
let range = TextRange::at(self.offset, it.len);
|
let range = TextRange::at(self.offset, it.len);
|
||||||
|
@ -601,17 +601,16 @@ impl<'a> TtTreeSink<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn delim_to_str(d: Option<tt::DelimiterKind>, closing: bool) -> SmolStr {
|
fn delim_to_str(d: Option<tt::DelimiterKind>, closing: bool) -> &'static str {
|
||||||
let texts = match d {
|
let texts = match d {
|
||||||
Some(tt::DelimiterKind::Parenthesis) => "()",
|
Some(tt::DelimiterKind::Parenthesis) => "()",
|
||||||
Some(tt::DelimiterKind::Brace) => "{}",
|
Some(tt::DelimiterKind::Brace) => "{}",
|
||||||
Some(tt::DelimiterKind::Bracket) => "[]",
|
Some(tt::DelimiterKind::Bracket) => "[]",
|
||||||
None => return "".into(),
|
None => return "",
|
||||||
};
|
};
|
||||||
|
|
||||||
let idx = closing as usize;
|
let idx = closing as usize;
|
||||||
let text = &texts[idx..texts.len() - (1 - idx)];
|
&texts[idx..texts.len() - (1 - idx)]
|
||||||
text.into()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> TreeSink for TtTreeSink<'a> {
|
impl<'a> TreeSink for TtTreeSink<'a> {
|
||||||
|
@ -626,22 +625,25 @@ impl<'a> TreeSink for TtTreeSink<'a> {
|
||||||
|
|
||||||
let mut last = self.cursor;
|
let mut last = self.cursor;
|
||||||
for _ in 0..n_tokens {
|
for _ in 0..n_tokens {
|
||||||
|
let tmp_str: SmolStr;
|
||||||
if self.cursor.eof() {
|
if self.cursor.eof() {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
last = self.cursor;
|
last = self.cursor;
|
||||||
let text: SmolStr = match self.cursor.token_tree() {
|
let text: &str = match self.cursor.token_tree() {
|
||||||
Some(tt::TokenTree::Leaf(leaf)) => {
|
Some(tt::TokenTree::Leaf(leaf)) => {
|
||||||
// Mark the range if needed
|
// Mark the range if needed
|
||||||
let (text, id) = match leaf {
|
let (text, id) = match leaf {
|
||||||
tt::Leaf::Ident(ident) => (ident.text.clone(), ident.id),
|
tt::Leaf::Ident(ident) => (&ident.text, ident.id),
|
||||||
tt::Leaf::Punct(punct) => {
|
tt::Leaf::Punct(punct) => {
|
||||||
assert!(punct.char.is_ascii());
|
assert!(punct.char.is_ascii());
|
||||||
let char = &(punct.char as u8);
|
let char = &(punct.char as u8);
|
||||||
let text = std::str::from_utf8(std::slice::from_ref(char)).unwrap();
|
tmp_str = SmolStr::new_inline(
|
||||||
(SmolStr::new_inline(text), punct.id)
|
std::str::from_utf8(std::slice::from_ref(char)).unwrap(),
|
||||||
|
);
|
||||||
|
(&tmp_str, punct.id)
|
||||||
}
|
}
|
||||||
tt::Leaf::Literal(lit) => (lit.text.clone(), lit.id),
|
tt::Leaf::Literal(lit) => (&lit.text, lit.id),
|
||||||
};
|
};
|
||||||
let range = TextRange::at(self.text_pos, TextSize::of(text.as_str()));
|
let range = TextRange::at(self.text_pos, TextSize::of(text.as_str()));
|
||||||
self.token_map.insert(id, range);
|
self.token_map.insert(id, range);
|
||||||
|
@ -672,7 +674,7 @@ impl<'a> TreeSink for TtTreeSink<'a> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
self.buf += &text;
|
self.buf += &text;
|
||||||
self.text_pos += TextSize::of(text.as_str());
|
self.text_pos += TextSize::of(text);
|
||||||
}
|
}
|
||||||
|
|
||||||
let text = SmolStr::new(self.buf.as_str());
|
let text = SmolStr::new(self.buf.as_str());
|
||||||
|
|
Loading…
Reference in a new issue