summaryrefslogtreecommitdiff
path: root/src/state/sheetview.rs
diff options
context:
space:
mode:
authorNathan Reiner <nathan@nathanreiner.xyz>2024-08-02 11:38:19 +0200
committerNathan Reiner <nathan@nathanreiner.xyz>2024-08-02 11:38:19 +0200
commit04a5a938994ddb95cfaa9a74b180e457d3a2b5d0 (patch)
tree31ce9525ed3f3423678397323b65c910d63eadb1 /src/state/sheetview.rs
parentfe0938b1de0c46fc2afcaa3dcd6a0f4ec870d21a (diff)
implement new lua interface
Diffstat (limited to 'src/state/sheetview.rs')
-rw-r--r--src/state/sheetview.rs97
1 files changed, 0 insertions, 97 deletions
diff --git a/src/state/sheetview.rs b/src/state/sheetview.rs
deleted file mode 100644
index 8108a1d..0000000
--- a/src/state/sheetview.rs
+++ /dev/null
@@ -1,97 +0,0 @@
-use std::sync::{Arc, RwLock};
-
-use mlua::{IntoLua, UserData, Value};
-
-use super::GlobalState;
-use crate::{
- cursor::{Cursor, CursorMove},
- sheet::{
- register::{Register, SheetId},
- Sheet, SheetLuaRef,
- },
-};
-
-#[derive(Default, Debug)]
-pub struct SheetViewState {
- pub cursor: Cursor,
- active_sheet: Option<SheetId>,
-}
-
-impl SheetViewState {
- pub const fn new() -> Self {
- Self {
- cursor: Cursor::new(),
- active_sheet: None,
- }
- }
-
- pub fn set_active_sheet(&mut self, sheet: Option<SheetId>) {
- if let Some(id) = sheet {
- if let Some(lock) = Register::get(id) {
- let sheet = lock.read().unwrap();
- self.cursor.set_x_max(sheet.width());
- self.cursor.set_y_max(sheet.height());
- }
- }
-
- self.active_sheet = sheet
- }
-
- pub fn active_sheet(&self) -> Option<Arc<RwLock<Sheet>>> {
- if let Some(id) = self.active_sheet {
- Register::get(id)
- } else {
- None
- }
- }
-}
-
-macro_rules! cfg {
- () => {
- GlobalState::instance().sheetview
- };
-}
-
-macro_rules! cfg_mut {
- () => {
- GlobalState::instance_mut().sheetview
- };
-}
-
-impl UserData for SheetViewState {
- fn add_fields<'lua, F: mlua::prelude::LuaUserDataFields<'lua, Self>>(fields: &mut F) {
- fields.add_field_function_get("active", |lua, _| {
- if let Some(id) = cfg!().active_sheet {
- SheetLuaRef::new(id).into_lua(lua)
- } else {
- Ok(Value::Nil)
- }
- });
-
- fields.add_field_function_set("active", |_, _, sheet: Option<SheetLuaRef>| {
- if let Some(r) = sheet {
- cfg_mut!().active_sheet = Some(r.id())
- } else {
- cfg_mut!().active_sheet = None
- }
-
- Ok(())
- });
-
- fields.add_field_function_get("cursor", |lua, _| {
- let table = lua.create_table()?;
- table.set("row", cfg!().cursor.y())?;
- table.set("column", cfg!().cursor.x())?;
- Ok(table)
- })
- }
-
- fn add_methods<'lua, M: mlua::prelude::LuaUserDataMethods<'lua, Self>>(methods: &mut M) {
- methods.add_function("move_cursor", |_, (row, column): (usize, usize)| {
- cfg_mut!()
- .cursor
- .move_checked(CursorMove::Jump((row, column)));
- Ok(())
- })
- }
-}