mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-11 13:10:54 +00:00
Make UniformListState an Rc<RefCell<>> instead of an Arc<Mutex<>>
We don't need to support multiple threads.
This commit is contained in:
parent
0cbcc81ed9
commit
025d857be8
1 changed files with 7 additions and 8 deletions
|
@ -8,11 +8,10 @@ use crate::{
|
||||||
ElementBox,
|
ElementBox,
|
||||||
};
|
};
|
||||||
use json::ToJson;
|
use json::ToJson;
|
||||||
use parking_lot::Mutex;
|
use std::{cell::RefCell, cmp, ops::Range, rc::Rc};
|
||||||
use std::{cmp, ops::Range, sync::Arc};
|
|
||||||
|
|
||||||
#[derive(Clone, Default)]
|
#[derive(Clone, Default)]
|
||||||
pub struct UniformListState(Arc<Mutex<StateInner>>);
|
pub struct UniformListState(Rc<RefCell<StateInner>>);
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum ScrollTarget {
|
pub enum ScrollTarget {
|
||||||
|
@ -22,11 +21,11 @@ pub enum ScrollTarget {
|
||||||
|
|
||||||
impl UniformListState {
|
impl UniformListState {
|
||||||
pub fn scroll_to(&self, scroll_to: ScrollTarget) {
|
pub fn scroll_to(&self, scroll_to: ScrollTarget) {
|
||||||
self.0.lock().scroll_to = Some(scroll_to);
|
self.0.borrow_mut().scroll_to = Some(scroll_to);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn scroll_top(&self) -> f32 {
|
pub fn scroll_top(&self) -> f32 {
|
||||||
self.0.lock().scroll_top
|
self.0.borrow().scroll_top
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +95,7 @@ where
|
||||||
delta *= 20.;
|
delta *= 20.;
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut state = self.state.0.lock();
|
let mut state = self.state.0.borrow_mut();
|
||||||
state.scroll_top = (state.scroll_top - delta.y()).max(0.0).min(scroll_max);
|
state.scroll_top = (state.scroll_top - delta.y()).max(0.0).min(scroll_max);
|
||||||
cx.notify();
|
cx.notify();
|
||||||
|
|
||||||
|
@ -104,7 +103,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
fn autoscroll(&mut self, scroll_max: f32, list_height: f32, item_height: f32) {
|
fn autoscroll(&mut self, scroll_max: f32, list_height: f32, item_height: f32) {
|
||||||
let mut state = self.state.0.lock();
|
let mut state = self.state.0.borrow_mut();
|
||||||
|
|
||||||
if let Some(scroll_to) = state.scroll_to.take() {
|
if let Some(scroll_to) = state.scroll_to.take() {
|
||||||
let item_ix;
|
let item_ix;
|
||||||
|
@ -141,7 +140,7 @@ where
|
||||||
}
|
}
|
||||||
|
|
||||||
fn scroll_top(&self) -> f32 {
|
fn scroll_top(&self) -> f32 {
|
||||||
self.state.0.lock().scroll_top
|
self.state.0.borrow().scroll_top
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue