diff options
| author | 2021-07-22 12:37:39 -0500 | |
|---|---|---|
| committer | 2021-07-22 12:37:39 -0500 | |
| commit | e822f654e44d2d7375b7fda966bb772055f377d4 (patch) | |
| tree | 8707561f1bb09c9e58cc9d9884bfb16d956f9f65 /native/src/widget/text_input | |
| parent | 1c06920158e1a47977b2762bf8b34e56fd1a935a (diff) | |
| parent | dc0b96ce407283f2ffd9add5ad339f89097555d3 (diff) | |
| download | iced-e822f654e44d2d7375b7fda966bb772055f377d4.tar.gz iced-e822f654e44d2d7375b7fda966bb772055f377d4.tar.bz2 iced-e822f654e44d2d7375b7fda966bb772055f377d4.zip | |
Merge branch 'master' of https://github.com/hecrj/iced into wgpu_outdatedframe
Diffstat (limited to 'native/src/widget/text_input')
| -rw-r--r-- | native/src/widget/text_input/cursor.rs | 25 | ||||
| -rw-r--r-- | native/src/widget/text_input/editor.rs | 4 | ||||
| -rw-r--r-- | native/src/widget/text_input/value.rs | 9 | 
3 files changed, 25 insertions, 13 deletions
| diff --git a/native/src/widget/text_input/cursor.rs b/native/src/widget/text_input/cursor.rs index e630e293..4f3b159b 100644 --- a/native/src/widget/text_input/cursor.rs +++ b/native/src/widget/text_input/cursor.rs @@ -48,6 +48,18 @@ impl Cursor {          }      } +    /// Returns the current selection of the [`Cursor`] for the given [`Value`]. +    /// +    /// `start` is guaranteed to be <= than `end`. +    pub fn selection(&self, value: &Value) -> Option<(usize, usize)> { +        match self.state(value) { +            State::Selection { start, end } => { +                Some((start.min(end), start.max(end))) +            } +            _ => None, +        } +    } +      pub(crate) fn move_to(&mut self, position: usize) {          self.state = State::Index(position);      } @@ -101,7 +113,7 @@ impl Cursor {              State::Selection { start, end } if end > 0 => {                  self.select_range(start, end - 1)              } -            _ => (), +            _ => {}          }      } @@ -113,7 +125,7 @@ impl Cursor {              State::Selection { start, end } if end < value.len() => {                  self.select_range(start, end + 1)              } -            _ => (), +            _ => {}          }      } @@ -161,15 +173,6 @@ impl Cursor {          end.min(value.len())      } -    pub(crate) fn selection(&self, value: &Value) -> Option<(usize, usize)> { -        match self.state(value) { -            State::Selection { start, end } => { -                Some((start.min(end), start.max(end))) -            } -            _ => None, -        } -    } -      fn left(&self, value: &Value) -> usize {          match self.state(value) {              State::Index(index) => index, diff --git a/native/src/widget/text_input/editor.rs b/native/src/widget/text_input/editor.rs index 20e42567..0b50a382 100644 --- a/native/src/widget/text_input/editor.rs +++ b/native/src/widget/text_input/editor.rs @@ -20,7 +20,7 @@ impl<'a> Editor<'a> {                  self.cursor.move_left(self.value);                  self.value.remove_many(left, right);              } -            _ => (), +            _ => {}          }          self.value.insert(self.cursor.end(self.value), character); @@ -35,7 +35,7 @@ impl<'a> Editor<'a> {                  self.cursor.move_left(self.value);                  self.value.remove_many(left, right);              } -            _ => (), +            _ => {}          }          self.value.insert_many(self.cursor.end(self.value), content); diff --git a/native/src/widget/text_input/value.rs b/native/src/widget/text_input/value.rs index 86be2790..2034cca4 100644 --- a/native/src/widget/text_input/value.rs +++ b/native/src/widget/text_input/value.rs @@ -73,6 +73,15 @@ impl Value {              .unwrap_or(self.len())      } +    /// Returns a new [`Value`] containing the graphemes from `start` until the +    /// given `end`. +    pub fn select(&self, start: usize, end: usize) -> Self { +        let graphemes = +            self.graphemes[start.min(self.len())..end.min(self.len())].to_vec(); + +        Self { graphemes } +    } +      /// Returns a new [`Value`] containing the graphemes until the given      /// `index`.      pub fn until(&self, index: usize) -> Self { | 
