Use ui_check instead of real mutex
This commit is contained in:
parent
e020a5825b
commit
be2626fb8d
@ -1,9 +1,9 @@
|
|||||||
use cairo;
|
use cairo;
|
||||||
use ui_model::Color;
|
use ui_model::Color;
|
||||||
use ui::UI;
|
use ui::{UI, UiMutex};
|
||||||
use shell::{Shell, NvimMode};
|
use shell::{Shell, NvimMode};
|
||||||
use nvim::{RepaintMode, RedrawEvents};
|
use nvim::{RepaintMode, RedrawEvents};
|
||||||
use std::sync::{Arc, Mutex};
|
use std::sync::Arc;
|
||||||
|
|
||||||
use glib;
|
use glib;
|
||||||
|
|
||||||
@ -60,19 +60,17 @@ impl State {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub struct Cursor {
|
pub struct Cursor {
|
||||||
state: Arc<Mutex<State>>,
|
state: Arc<UiMutex<State>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Cursor {
|
impl Cursor {
|
||||||
pub fn new() -> Cursor {
|
pub fn new() -> Cursor {
|
||||||
|
Cursor { state: Arc::new(UiMutex::new(State::new())) }
|
||||||
Cursor { state: Arc::new(Mutex::new(State::new())) }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn start(&mut self) {
|
pub fn start(&mut self) {
|
||||||
let state = self.state.clone();
|
let state = self.state.clone();
|
||||||
let mut mut_state = self.state.lock().unwrap();
|
let mut mut_state = self.state.borrow_mut();
|
||||||
mut_state.reset();
|
mut_state.reset();
|
||||||
if let Some(timer_id) = mut_state.timer {
|
if let Some(timer_id) = mut_state.timer {
|
||||||
glib::source_remove(timer_id);
|
glib::source_remove(timer_id);
|
||||||
@ -94,7 +92,7 @@ impl Cursor {
|
|||||||
bg: &Color) {
|
bg: &Color) {
|
||||||
|
|
||||||
let current_point = ctx.get_current_point();
|
let current_point = ctx.get_current_point();
|
||||||
let state = self.state.lock().unwrap();
|
let state = self.state.borrow();
|
||||||
ctx.set_source_rgba(1.0 - bg.0, 1.0 - bg.1, 1.0 - bg.2, 0.6 * state.alpha.0);
|
ctx.set_source_rgba(1.0 - bg.0, 1.0 - bg.1, 1.0 - bg.2, 0.6 * state.alpha.0);
|
||||||
|
|
||||||
let cursor_width = if shell.mode == NvimMode::Insert {
|
let cursor_width = if shell.mode == NvimMode::Insert {
|
||||||
@ -112,9 +110,9 @@ impl Cursor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn anim_step(state: &Arc<Mutex<State>>) -> glib::Continue {
|
fn anim_step(state: &Arc<UiMutex<State>>) -> glib::Continue {
|
||||||
let moved_state = state.clone();
|
let moved_state = state.clone();
|
||||||
let mut mut_state = state.lock().unwrap();
|
let mut mut_state = state.borrow_mut();
|
||||||
|
|
||||||
let next_event = match mut_state.anim_phase {
|
let next_event = match mut_state.anim_phase {
|
||||||
AnimPhase::Shown => {
|
AnimPhase::Shown => {
|
||||||
@ -164,7 +162,7 @@ fn anim_step(state: &Arc<Mutex<State>>) -> glib::Continue {
|
|||||||
|
|
||||||
impl Drop for Cursor {
|
impl Drop for Cursor {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
if let Some(timer_id) = self.state.lock().unwrap().timer {
|
if let Some(timer_id) = self.state.borrow().timer {
|
||||||
glib::source_remove(timer_id);
|
glib::source_remove(timer_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
48
src/ui.rs
48
src/ui.rs
@ -1,4 +1,4 @@
|
|||||||
use std::cell::RefCell;
|
use std::cell::{RefCell, Ref, RefMut};
|
||||||
use std::thread;
|
use std::thread;
|
||||||
|
|
||||||
use gtk;
|
use gtk;
|
||||||
@ -13,14 +13,9 @@ use settings;
|
|||||||
use shell::{Shell, NvimMode};
|
use shell::{Shell, NvimMode};
|
||||||
use nvim::ErrorReport;
|
use nvim::ErrorReport;
|
||||||
|
|
||||||
|
|
||||||
macro_rules! ui_thread_var {
|
macro_rules! ui_thread_var {
|
||||||
($id:ident, $ty:ty, $expr:expr) => (thread_local!(pub static $id: RefCell<$ty> = {
|
($id:ident, $ty:ty, $expr:expr) => (thread_local!(pub static $id: RefCell<$ty> = {
|
||||||
let thread = thread::current();
|
assert_ui_thread();
|
||||||
let current_thread_name = thread.name();
|
|
||||||
if current_thread_name != Some("main") {
|
|
||||||
panic!("Can create UI only from main thread, {:?}", current_thread_name);
|
|
||||||
}
|
|
||||||
RefCell::new($expr)
|
RefCell::new($expr)
|
||||||
});)
|
});)
|
||||||
}
|
}
|
||||||
@ -109,7 +104,6 @@ impl Ui {
|
|||||||
|
|
||||||
self.shell.add_configure_event();
|
self.shell.add_configure_event();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn edit_paste() {
|
fn edit_paste() {
|
||||||
@ -148,3 +142,41 @@ fn gtk_delete(_: &ApplicationWindow, _: &Event) -> Inhibit {
|
|||||||
Inhibit(false)
|
Inhibit(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
pub struct UiMutex<T: ?Sized> {
|
||||||
|
data: RefCell<T>,
|
||||||
|
}
|
||||||
|
|
||||||
|
unsafe impl<T: ?Sized + Send> Send for UiMutex<T> {}
|
||||||
|
unsafe impl<T: ?Sized + Send> Sync for UiMutex<T> {}
|
||||||
|
|
||||||
|
impl<T> UiMutex<T> {
|
||||||
|
pub fn new(t: T) -> UiMutex<T> {
|
||||||
|
UiMutex { data: RefCell::new(t) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: ?Sized> UiMutex<T> {
|
||||||
|
pub fn borrow(&self) -> Ref<T> {
|
||||||
|
assert_ui_thread();
|
||||||
|
self.data.borrow()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn borrow_mut(&self) -> RefMut<T> {
|
||||||
|
assert_ui_thread();
|
||||||
|
self.data.borrow_mut()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn assert_ui_thread() {
|
||||||
|
match thread::current().name() {
|
||||||
|
Some("main") => (),
|
||||||
|
Some(ref name) => {
|
||||||
|
panic!("Can create UI only from main thread, {}", name);
|
||||||
|
}
|
||||||
|
None => panic!("Can create UI only from main thread, current thiread has no name"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user