Start on BlockSnapshot::clip_point

Not sure it works yet. Ran into another failure in the unit tests.
This commit is contained in:
Nathan Sobo 2021-11-13 17:44:09 -07:00
parent 364fab7b5f
commit c9cbeafc05

View file

@ -234,6 +234,12 @@ impl BlockMap {
} }
} }
impl BlockPoint {
fn new(row: u32, column: u32) -> Self {
Self(Point::new(row, column))
}
}
impl std::ops::Deref for BlockPoint { impl std::ops::Deref for BlockPoint {
type Target = Point; type Target = Point;
@ -323,9 +329,7 @@ impl BlockSnapshot {
let (input_start, output_start) = cursor.start(); let (input_start, output_start) = cursor.start();
let row_overshoot = rows.start - output_start.0; let row_overshoot = rows.start - output_start.0;
let input_start_row = input_start.0 + row_overshoot; let input_start_row = input_start.0 + row_overshoot;
let input_end_row = self let input_end_row = self.to_wrap_point(BlockPoint::new(rows.end, 0)).row();
.to_wrap_point(BlockPoint(Point::new(rows.end, 0)))
.row();
let input_chunks = self let input_chunks = self
.wrap_snapshot .wrap_snapshot
.highlighted_chunks_for_rows(input_start_row..input_end_row); .highlighted_chunks_for_rows(input_start_row..input_end_row);
@ -344,7 +348,42 @@ impl BlockSnapshot {
} }
pub fn clip_point(&self, point: BlockPoint, bias: Bias) -> BlockPoint { pub fn clip_point(&self, point: BlockPoint, bias: Bias) -> BlockPoint {
todo!() let mut cursor = self.transforms.cursor::<(OutputRow, InputRow)>();
cursor.seek(&OutputRow(point.row), Bias::Right, &());
if let Some(transform) = cursor.item() {
if transform.is_isomorphic() {
let (output_start_row, input_start_row) = cursor.start();
let output_overshoot = point.row - output_start_row.0;
let input_point = self.wrap_snapshot.clip_point(
WrapPoint::new(input_start_row.0 + output_overshoot, point.column),
bias,
);
let input_overshoot = input_point.row() - input_start_row.0;
BlockPoint::new(output_start_row.0 + input_overshoot, input_point.column())
} else {
if bias == Bias::Left && cursor.start().1 .0 > 0
|| cursor.end(&()).1 .0 == self.wrap_snapshot.max_point().row()
{
loop {
cursor.prev(&());
let transform = cursor.item().unwrap();
if transform.is_isomorphic() {
return BlockPoint::new(cursor.end(&()).0 .0 - 1, 0);
}
}
} else {
loop {
cursor.next(&());
let transform = cursor.item().unwrap();
if transform.is_isomorphic() {
return BlockPoint::new(cursor.start().0 .0, 0);
}
}
}
}
} else {
self.max_point()
}
} }
pub fn to_block_point(&self, wrap_point: WrapPoint) -> BlockPoint { pub fn to_block_point(&self, wrap_point: WrapPoint) -> BlockPoint {
@ -358,10 +397,7 @@ impl BlockSnapshot {
} }
let (input_start, output_start) = cursor.start(); let (input_start, output_start) = cursor.start();
let row_overshoot = wrap_point.row() - input_start.0; let row_overshoot = wrap_point.row() - input_start.0;
BlockPoint(Point::new( BlockPoint::new(output_start.0 + row_overshoot, wrap_point.column())
output_start.0 + row_overshoot,
wrap_point.column(),
))
} }
pub fn to_wrap_point(&self, block_point: BlockPoint) -> WrapPoint { pub fn to_wrap_point(&self, block_point: BlockPoint) -> WrapPoint {
@ -627,7 +663,7 @@ mod tests {
); );
assert_eq!( assert_eq!(
snapshot.to_block_point(WrapPoint::new(1, 0)), snapshot.to_block_point(WrapPoint::new(1, 0)),
BlockPoint(Point::new(3, 0)) BlockPoint::new(3, 0)
); );
// Insert a line break, separating two block decorations into separate // Insert a line break, separating two block decorations into separate