address clippy warnings

This commit is contained in:
Blaž Hrastnik 2020-05-28 14:45:44 +09:00
parent 23109f1512
commit b5c38812e9
4 changed files with 20 additions and 11 deletions

View File

@ -3,6 +3,9 @@
mod state;
mod transaction;
pub use ropey::Rope;
pub use tendril::StrTendril as Tendril;
pub use buffer::Buffer;
pub use selection::Range as SelectionRange;

View File

@ -30,12 +30,14 @@ pub fn new(anchor: usize, head: usize) -> Self {
/// Start of the range.
#[inline]
#[must_use]
pub fn from(&self) -> usize {
std::cmp::min(self.anchor, self.head)
}
/// End of the range.
#[inline]
#[must_use]
pub fn to(&self) -> usize {
std::cmp::max(self.anchor, self.head)
}
@ -47,6 +49,7 @@ pub fn is_empty(&self) -> bool {
}
/// Check two ranges for overlap.
#[must_use]
pub fn overlaps(&self, other: &Self) -> bool {
// cursor overlap is checked differently
if self.is_empty() {
@ -59,6 +62,7 @@ pub fn overlaps(&self, other: &Self) -> bool {
// TODO: map
/// Extend the range to cover at least `from` `to`.
#[must_use]
pub fn extend(&self, from: usize, to: usize) -> Self {
if from <= self.anchor && to >= self.anchor {
return Range {
@ -90,12 +94,14 @@ pub struct Selection {
impl Selection {
// map
// eq
#[must_use]
pub fn primary(&self) -> Range {
self.ranges[self.primary_index]
}
/// Ensure selection containing only the primary selection.
pub fn as_single(self) -> Self {
pub fn into_single(self) -> Self {
if self.ranges.len() == 1 {
self
} else {
@ -109,6 +115,7 @@ pub fn as_single(self) -> Self {
// add_range // push
// replace_range
#[must_use]
/// Constructs a selection holding a single range.
pub fn single(anchor: usize, head: usize) -> Self {
Self {
@ -117,11 +124,12 @@ pub fn single(anchor: usize, head: usize) -> Self {
}
}
#[must_use]
pub fn new(ranges: SmallVec<[Range; 1]>, primary_index: usize) -> Self {
fn normalize(mut ranges: SmallVec<[Range; 1]>, primary_index: usize) -> Selection {
fn normalize(mut ranges: SmallVec<[Range; 1]>, mut primary_index: usize) -> Selection {
let primary = ranges[primary_index];
ranges.sort_unstable_by_key(|range| range.from());
let mut primary_index = ranges.iter().position(|&range| range == primary).unwrap();
ranges.sort_unstable_by_key(Range::from);
primary_index = ranges.iter().position(|&range| range == primary).unwrap();
let mut result: SmallVec<[Range; 1]> = SmallVec::new();

View File

@ -8,6 +8,7 @@ pub struct State {
}
impl State {
#[must_use]
pub fn new(buffer: Buffer) -> Self {
Self {
buffer,

View File

@ -14,10 +14,7 @@
// distance: usize,
// }
use crate::{Buffer, Selection};
use ropey::Rope;
use tendril::StrTendril as Tendril;
use crate::{Buffer, Rope, Selection, Tendril};
// TODO: divided into three different operations, I sort of like having just
// Splice { extent, Option<text>, distance } better.
@ -56,6 +53,7 @@ pub struct ChangeSet {
}
impl ChangeSet {
#[must_use]
pub fn new(buf: &Buffer) -> Self {
let len = buf.contents.len_chars();
Self {
@ -105,8 +103,7 @@ pub fn compose(self, other: ChangeSet) -> Result<Self, ()> {
head_a = a;
head_b = changes_b.next();
}
(None, _) => return Err(()),
(_, None) => return Err(()),
(None, _) | (_, None) => return Err(()),
(Some(Retain(i)), Some(Retain(j))) => match i.cmp(&j) {
Ordering::Less => {
changes.push(Retain(i));
@ -221,7 +218,7 @@ pub fn apply(&self, text: &mut Rope) {
let mut pos = 0;
for change in self.changes.iter() {
for change in &self.changes {
use Change::*;
match change {
Retain(n) => {