mirror of
https://github.com/zed-industries/zed.git
synced 2025-02-07 11:11:30 +00:00
Apply questionable changes to make things compile
This commit is contained in:
parent
10765d69f4
commit
05dc672c2a
2 changed files with 65 additions and 30 deletions
|
@ -301,7 +301,7 @@ impl FoldMap {
|
||||||
|
|
||||||
fn sync(&self, inlay_snapshot: InlaySnapshot, inlay_edits: Vec<InlayEdit>) -> Vec<FoldEdit> {
|
fn sync(&self, inlay_snapshot: InlaySnapshot, inlay_edits: Vec<InlayEdit>) -> Vec<FoldEdit> {
|
||||||
let buffer = &inlay_snapshot.buffer;
|
let buffer = &inlay_snapshot.buffer;
|
||||||
let mut snapshot = self.inlay_snapshot.lock();
|
let snapshot = self.inlay_snapshot.lock();
|
||||||
|
|
||||||
let mut new_snapshot = snapshot.clone();
|
let mut new_snapshot = snapshot.clone();
|
||||||
if new_snapshot.version != inlay_snapshot.version {
|
if new_snapshot.version != inlay_snapshot.version {
|
||||||
|
@ -315,7 +315,14 @@ impl FoldMap {
|
||||||
let mut cursor = transforms.cursor::<usize>();
|
let mut cursor = transforms.cursor::<usize>();
|
||||||
cursor.seek(&0, Bias::Right, &());
|
cursor.seek(&0, Bias::Right, &());
|
||||||
|
|
||||||
while let Some(mut edit) = inlay_edits_iter.next() {
|
while let Some(inlay_edit) = inlay_edits_iter.next() {
|
||||||
|
// TODO kb is this right?
|
||||||
|
let mut edit = Edit {
|
||||||
|
old: inlay_snapshot.to_buffer_offset(inlay_edit.old.start)
|
||||||
|
..inlay_snapshot.to_buffer_offset(inlay_edit.old.end),
|
||||||
|
new: inlay_snapshot.to_buffer_offset(inlay_edit.new.start)
|
||||||
|
..inlay_snapshot.to_buffer_offset(inlay_edit.new.end),
|
||||||
|
};
|
||||||
new_transforms.append(cursor.slice(&edit.old.start, Bias::Left, &()), &());
|
new_transforms.append(cursor.slice(&edit.old.start, Bias::Left, &()), &());
|
||||||
edit.new.start -= edit.old.start - cursor.start();
|
edit.new.start -= edit.old.start - cursor.start();
|
||||||
edit.old.start = *cursor.start();
|
edit.old.start = *cursor.start();
|
||||||
|
@ -327,12 +334,18 @@ impl FoldMap {
|
||||||
loop {
|
loop {
|
||||||
edit.old.end = *cursor.start();
|
edit.old.end = *cursor.start();
|
||||||
|
|
||||||
if let Some(next_edit) = inlay_edits_iter.peek() {
|
if let Some(next_inlay_edit) = inlay_edits_iter.peek() {
|
||||||
if next_edit.old.start > edit.old.end {
|
if next_inlay_edit.old.start > inlay_snapshot.to_inlay_offset(edit.old.end) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
let next_edit = inlay_edits_iter.next().unwrap();
|
let next_inlay_edit = inlay_edits_iter.next().unwrap();
|
||||||
|
let next_edit = Edit {
|
||||||
|
old: inlay_snapshot.to_buffer_offset(next_inlay_edit.old.start)
|
||||||
|
..inlay_snapshot.to_buffer_offset(next_inlay_edit.old.end),
|
||||||
|
new: inlay_snapshot.to_buffer_offset(next_inlay_edit.new.start)
|
||||||
|
..inlay_snapshot.to_buffer_offset(next_inlay_edit.new.end),
|
||||||
|
};
|
||||||
delta += next_edit.new.len() as isize - next_edit.old.len() as isize;
|
delta += next_edit.new.len() as isize - next_edit.old.len() as isize;
|
||||||
|
|
||||||
if next_edit.old.end >= edit.old.end {
|
if next_edit.old.end >= edit.old.end {
|
||||||
|
@ -347,12 +360,12 @@ impl FoldMap {
|
||||||
|
|
||||||
edit.new.end = ((edit.new.start + edit.old.len()) as isize + delta) as usize;
|
edit.new.end = ((edit.new.start + edit.old.len()) as isize + delta) as usize;
|
||||||
|
|
||||||
let anchor = buffer.anchor_before(inlay_snapshot.to_buffer_offset(edit.new.start));
|
let anchor = buffer.anchor_before(edit.new.start);
|
||||||
let mut folds_cursor = self.folds.cursor::<Fold>();
|
let mut folds_cursor = self.folds.cursor::<Fold>();
|
||||||
folds_cursor.seek(&Fold(anchor..Anchor::max()), Bias::Left, &buffer);
|
folds_cursor.seek(&Fold(anchor..Anchor::max()), Bias::Left, &buffer);
|
||||||
|
|
||||||
let mut folds = iter::from_fn({
|
let mut folds = iter::from_fn({
|
||||||
move || {
|
|| {
|
||||||
let item = folds_cursor.item().map(|f| {
|
let item = folds_cursor.item().map(|f| {
|
||||||
let fold_buffer_start = f.0.start.to_offset(buffer);
|
let fold_buffer_start = f.0.start.to_offset(buffer);
|
||||||
let fold_buffer_end = f.0.end.to_offset(buffer);
|
let fold_buffer_end = f.0.end.to_offset(buffer);
|
||||||
|
@ -366,11 +379,13 @@ impl FoldMap {
|
||||||
})
|
})
|
||||||
.peekable();
|
.peekable();
|
||||||
|
|
||||||
while folds.peek().map_or(false, |fold| fold.start < edit.new.end) {
|
while folds.peek().map_or(false, |fold| {
|
||||||
|
inlay_snapshot.to_buffer_offset(fold.start) < edit.new.end
|
||||||
|
}) {
|
||||||
let mut fold = folds.next().unwrap();
|
let mut fold = folds.next().unwrap();
|
||||||
let sum = new_transforms.summary();
|
let sum = new_transforms.summary();
|
||||||
|
|
||||||
assert!(fold.start >= sum.input.len);
|
assert!(inlay_snapshot.to_buffer_offset(fold.start) >= sum.input.len);
|
||||||
|
|
||||||
while folds
|
while folds
|
||||||
.peek()
|
.peek()
|
||||||
|
@ -382,9 +397,10 @@ impl FoldMap {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if fold.start > sum.input.len {
|
if inlay_snapshot.to_buffer_offset(fold.start) > sum.input.len {
|
||||||
let text_summary =
|
let text_summary = buffer.text_summary_for_range::<TextSummary, _>(
|
||||||
buffer.text_summary_for_range::<TextSummary, _>(sum.input.len..fold.start);
|
sum.input.len..inlay_snapshot.to_buffer_offset(fold.start),
|
||||||
|
);
|
||||||
new_transforms.push(
|
new_transforms.push(
|
||||||
Transform {
|
Transform {
|
||||||
summary: TransformSummary {
|
summary: TransformSummary {
|
||||||
|
@ -403,7 +419,10 @@ impl FoldMap {
|
||||||
Transform {
|
Transform {
|
||||||
summary: TransformSummary {
|
summary: TransformSummary {
|
||||||
output: TextSummary::from(output_text),
|
output: TextSummary::from(output_text),
|
||||||
input: buffer.text_summary_for_range(fold.start..fold.end),
|
input: inlay_snapshot.text_summary_for_range(
|
||||||
|
inlay_snapshot.to_point(fold.start)
|
||||||
|
..inlay_snapshot.to_point(fold.end),
|
||||||
|
),
|
||||||
},
|
},
|
||||||
output_text: Some(output_text),
|
output_text: Some(output_text),
|
||||||
},
|
},
|
||||||
|
@ -414,7 +433,8 @@ impl FoldMap {
|
||||||
|
|
||||||
let sum = new_transforms.summary();
|
let sum = new_transforms.summary();
|
||||||
if sum.input.len < edit.new.end {
|
if sum.input.len < edit.new.end {
|
||||||
let text_summary = buffer.text_summary_for_range(sum.input.len..edit.new.end);
|
let text_summary: TextSummary =
|
||||||
|
buffer.text_summary_for_range(sum.input.len..edit.new.end);
|
||||||
new_transforms.push(
|
new_transforms.push(
|
||||||
Transform {
|
Transform {
|
||||||
summary: TransformSummary {
|
summary: TransformSummary {
|
||||||
|
@ -450,7 +470,13 @@ impl FoldMap {
|
||||||
let mut old_transforms = transforms.cursor::<(usize, FoldOffset)>();
|
let mut old_transforms = transforms.cursor::<(usize, FoldOffset)>();
|
||||||
let mut new_transforms = new_transforms.cursor::<(usize, FoldOffset)>();
|
let mut new_transforms = new_transforms.cursor::<(usize, FoldOffset)>();
|
||||||
|
|
||||||
for mut edit in inlay_edits {
|
for inlay_edit in inlay_edits {
|
||||||
|
let mut edit = Edit {
|
||||||
|
old: inlay_snapshot.to_buffer_offset(inlay_edit.old.start)
|
||||||
|
..inlay_snapshot.to_buffer_offset(inlay_edit.old.end),
|
||||||
|
new: inlay_snapshot.to_buffer_offset(inlay_edit.new.start)
|
||||||
|
..inlay_snapshot.to_buffer_offset(inlay_edit.new.end),
|
||||||
|
};
|
||||||
old_transforms.seek(&edit.old.start, Bias::Left, &());
|
old_transforms.seek(&edit.old.start, Bias::Left, &());
|
||||||
if old_transforms.item().map_or(false, |t| t.is_fold()) {
|
if old_transforms.item().map_or(false, |t| t.is_fold()) {
|
||||||
edit.old.start = old_transforms.start().0;
|
edit.old.start = old_transforms.start().0;
|
||||||
|
@ -580,10 +606,11 @@ impl FoldSnapshot {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let overshoot = InlayPoint(point.0 - cursor.start().0 .0);
|
let overshoot = InlayPoint(point.0 - cursor.start().0 .0);
|
||||||
FoldPoint(cmp::min(
|
// TODO kb is this right?
|
||||||
cursor.start().1 .0 + overshoot,
|
cmp::min(
|
||||||
cursor.end(&()).1 .0,
|
FoldPoint(cursor.start().1 .0 + overshoot.0),
|
||||||
))
|
cursor.end(&()).1,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -674,6 +701,7 @@ impl FoldSnapshot {
|
||||||
range: Range<FoldOffset>,
|
range: Range<FoldOffset>,
|
||||||
language_aware: bool,
|
language_aware: bool,
|
||||||
text_highlights: Option<&'a TextHighlights>,
|
text_highlights: Option<&'a TextHighlights>,
|
||||||
|
// TODO kb need to call inlay chunks and style them
|
||||||
inlay_highlights: Option<HighlightStyle>,
|
inlay_highlights: Option<HighlightStyle>,
|
||||||
) -> FoldChunks<'a> {
|
) -> FoldChunks<'a> {
|
||||||
let mut highlight_endpoints = Vec::new();
|
let mut highlight_endpoints = Vec::new();
|
||||||
|
@ -1355,7 +1383,7 @@ mod tests {
|
||||||
let buffer = MultiBuffer::build_simple("abcdefghijkl", cx);
|
let buffer = MultiBuffer::build_simple("abcdefghijkl", cx);
|
||||||
let subscription = buffer.update(cx, |buffer, _| buffer.subscribe());
|
let subscription = buffer.update(cx, |buffer, _| buffer.subscribe());
|
||||||
let buffer_snapshot = buffer.read(cx).snapshot(cx);
|
let buffer_snapshot = buffer.read(cx).snapshot(cx);
|
||||||
let (inlay_map, inlay_snapshot) = InlayMap::new(buffer_snapshot.clone());
|
let (mut inlay_map, inlay_snapshot) = InlayMap::new(buffer_snapshot.clone());
|
||||||
|
|
||||||
{
|
{
|
||||||
let mut map = FoldMap::new(inlay_snapshot.clone()).0;
|
let mut map = FoldMap::new(inlay_snapshot.clone()).0;
|
||||||
|
@ -1529,8 +1557,9 @@ mod tests {
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
||||||
let (inlay_snapshot, inlay_edits) = inlay_map.sync(buffer_snapshot, buffer_edits);
|
let (inlay_snapshot, inlay_edits) =
|
||||||
let (snapshot, edits) = map.read(inlay_snapshot, inlay_edits);
|
inlay_map.sync(buffer_snapshot.clone(), buffer_edits);
|
||||||
|
let (snapshot, edits) = map.read(inlay_snapshot.clone(), inlay_edits);
|
||||||
snapshot_edits.push((snapshot.clone(), edits));
|
snapshot_edits.push((snapshot.clone(), edits));
|
||||||
|
|
||||||
let mut expected_text: String = buffer_snapshot.text().to_string();
|
let mut expected_text: String = buffer_snapshot.text().to_string();
|
||||||
|
|
|
@ -282,8 +282,7 @@ impl InlayMap {
|
||||||
} else {
|
} else {
|
||||||
let mut inlay_edits = Patch::default();
|
let mut inlay_edits = Patch::default();
|
||||||
let mut new_transforms = SumTree::new();
|
let mut new_transforms = SumTree::new();
|
||||||
// TODO kb something is wrong with how we store it?
|
let transforms = &mut self.transforms;
|
||||||
let mut transforms = self.transforms;
|
|
||||||
let mut cursor = transforms.cursor::<(usize, InlayOffset)>();
|
let mut cursor = transforms.cursor::<(usize, InlayOffset)>();
|
||||||
let mut buffer_edits_iter = buffer_edits.iter().peekable();
|
let mut buffer_edits_iter = buffer_edits.iter().peekable();
|
||||||
while let Some(buffer_edit) = buffer_edits_iter.next() {
|
while let Some(buffer_edit) = buffer_edits_iter.next() {
|
||||||
|
@ -377,13 +376,14 @@ impl InlayMap {
|
||||||
}
|
}
|
||||||
|
|
||||||
let new_snapshot = InlaySnapshot {
|
let new_snapshot = InlaySnapshot {
|
||||||
buffer: buffer_snapshot,
|
buffer: buffer_snapshot.clone(),
|
||||||
transforms: new_transforms,
|
transforms: new_transforms,
|
||||||
version: post_inc(&mut self.version),
|
version: post_inc(&mut self.version),
|
||||||
};
|
};
|
||||||
new_snapshot.check_invariants();
|
new_snapshot.check_invariants();
|
||||||
drop(cursor);
|
drop(cursor);
|
||||||
|
|
||||||
|
// TODO kb remove the 2nd buffer here, leave it in snapshot only?
|
||||||
*buffer = buffer_snapshot.clone();
|
*buffer = buffer_snapshot.clone();
|
||||||
(new_snapshot, inlay_edits.into_inner())
|
(new_snapshot, inlay_edits.into_inner())
|
||||||
}
|
}
|
||||||
|
@ -434,7 +434,10 @@ impl InlayMap {
|
||||||
new: offset..offset,
|
new: offset..offset,
|
||||||
})
|
})
|
||||||
.collect();
|
.collect();
|
||||||
self.sync(buffer_snapshot.clone(), buffer_edits)
|
// TODO kb fugly
|
||||||
|
let buffer_snapshot_to_sync = buffer_snapshot.clone();
|
||||||
|
drop(buffer_snapshot);
|
||||||
|
self.sync(buffer_snapshot_to_sync, buffer_edits)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(any(test, feature = "test-support"))]
|
#[cfg(any(test, feature = "test-support"))]
|
||||||
|
@ -567,11 +570,14 @@ impl InlaySnapshot {
|
||||||
|
|
||||||
pub fn to_inlay_offset(&self, offset: usize) -> InlayOffset {
|
pub fn to_inlay_offset(&self, offset: usize) -> InlayOffset {
|
||||||
let mut cursor = self.transforms.cursor::<(Point, InlayOffset)>();
|
let mut cursor = self.transforms.cursor::<(Point, InlayOffset)>();
|
||||||
cursor.seek(&offset, Bias::Left, &());
|
// TODO kb is this right?
|
||||||
|
let buffer_point = self.buffer.offset_to_point(offset);
|
||||||
|
cursor.seek(&buffer_point, Bias::Left, &());
|
||||||
match cursor.item() {
|
match cursor.item() {
|
||||||
Some(Transform::Isomorphic(_)) => {
|
Some(Transform::Isomorphic(_)) => {
|
||||||
let overshoot = offset - cursor.start().0;
|
let overshoot = buffer_point - cursor.start().0;
|
||||||
InlayOffset(cursor.start().1 .0 + overshoot)
|
let overshoot_offset = self.to_inlay_offset(self.buffer.point_to_offset(overshoot));
|
||||||
|
cursor.start().1 + overshoot_offset
|
||||||
}
|
}
|
||||||
Some(Transform::Inlay(_)) => cursor.start().1,
|
Some(Transform::Inlay(_)) => cursor.start().1,
|
||||||
None => self.len(),
|
None => self.len(),
|
||||||
|
@ -635,7 +641,7 @@ impl InlaySnapshot {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn text_summary(&self) -> TextSummary {
|
pub fn text_summary(&self) -> TextSummary {
|
||||||
self.transforms.summary().output
|
self.transforms.summary().output.clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn text_summary_for_range(&self, range: Range<InlayPoint>) -> TextSummary {
|
pub fn text_summary_for_range(&self, range: Range<InlayPoint>) -> TextSummary {
|
||||||
|
|
Loading…
Reference in a new issue