Start implementing window definition
This commit is contained in:
parent
12ded2f726
commit
49bd2c6678
4 changed files with 164 additions and 0 deletions
|
@ -22,6 +22,7 @@ serde = {version = "1.0", features = ["derive"]}
|
||||||
serde_json = "1.0"
|
serde_json = "1.0"
|
||||||
lazy_static = "1.4"
|
lazy_static = "1.4"
|
||||||
pretty_assertions = "0.7"
|
pretty_assertions = "0.7"
|
||||||
|
smart-default = "0.6"
|
||||||
|
|
||||||
anyhow = "1"
|
anyhow = "1"
|
||||||
|
|
||||||
|
|
|
@ -76,6 +76,18 @@ impl Attributes {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn eval_optional<T: TryFrom<DynVal>>(&mut self, key: &str) -> Result<Option<T>, AttrError> {
|
||||||
|
let key = AttrName(key.to_string());
|
||||||
|
match self.attrs.remove(&key) {
|
||||||
|
Some(AttrEntry { key_span, value }) => {
|
||||||
|
let value_span = value.span();
|
||||||
|
let dynval = value.eval_no_vars().map_err(|err| AttrError::EvaluationError(value_span.into(), err))?;
|
||||||
|
T::try_from(dynval).map(Some).map_err(|_| AttrError::AttrTypeError(value_span.into(), key.clone()))
|
||||||
|
}
|
||||||
|
None => Ok(None),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// pub fn parse_required<T: TryFrom<SimplExpr>>(&mut self, key: &str) -> Result<T, AttrError> {
|
// pub fn parse_required<T: TryFrom<SimplExpr>>(&mut self, key: &str) -> Result<T, AttrError> {
|
||||||
// let key = AttrName(key.to_string());
|
// let key = AttrName(key.to_string());
|
||||||
// match self.attrs.remove(&key) {
|
// match self.attrs.remove(&key) {
|
||||||
|
|
|
@ -8,3 +8,4 @@ pub mod validate;
|
||||||
pub mod var_definition;
|
pub mod var_definition;
|
||||||
pub mod widget_definition;
|
pub mod widget_definition;
|
||||||
pub mod widget_use;
|
pub mod widget_use;
|
||||||
|
pub mod window_definition;
|
||||||
|
|
150
src/config/window_definition.rs
Normal file
150
src/config/window_definition.rs
Normal file
|
@ -0,0 +1,150 @@
|
||||||
|
use std::collections::HashMap;
|
||||||
|
|
||||||
|
use simplexpr::{dynval::DynVal, SimplExpr};
|
||||||
|
|
||||||
|
use crate::{
|
||||||
|
error::{AstError, AstResult},
|
||||||
|
parser::{
|
||||||
|
ast::{Ast, AstIterator, Span},
|
||||||
|
from_ast::{FromAst, FromAstElementContent},
|
||||||
|
},
|
||||||
|
spanned,
|
||||||
|
value::{AttrName, VarName},
|
||||||
|
};
|
||||||
|
|
||||||
|
use super::widget_use::WidgetUse;
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, serde::Serialize)]
|
||||||
|
pub struct EwwWindowDefinition {
|
||||||
|
pub name: String,
|
||||||
|
pub geometry: Option<EwwWindowGeometry>,
|
||||||
|
pub stacking: WindowStacking,
|
||||||
|
pub monitor_number: Option<i32>,
|
||||||
|
pub widget: WidgetUse,
|
||||||
|
pub resizable: bool,
|
||||||
|
// pub backend_options: BackendWindowOptions,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl FromAstElementContent for EwwWindowDefinition {
|
||||||
|
fn get_element_name() -> &'static str {
|
||||||
|
"defwindow"
|
||||||
|
}
|
||||||
|
|
||||||
|
fn from_tail<I: Iterator<Item = Ast>>(span: Span, mut iter: AstIterator<I>) -> AstResult<Self> {
|
||||||
|
let (_, name) = iter.expect_symbol()?;
|
||||||
|
let mut attrs = iter.expect_key_values()?;
|
||||||
|
let monitor_number = attrs.eval_optional("monitor")?;
|
||||||
|
let resizable = attrs.eval_optional("resizable")?.unwrap_or(true);
|
||||||
|
let stacking = attrs.eval_optional("stacking")?.unwrap_or(WindowStacking::Foreground);
|
||||||
|
let widget = iter.expect_any()?;
|
||||||
|
Ok(Self { name, monitor_number, resizable, widget, stacking })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct EnumParseError {
|
||||||
|
input: String,
|
||||||
|
expected: Vec<&'static str>,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Parse a string with a concrete set of options into some data-structure,
|
||||||
|
/// and return an [EnumParseError]
|
||||||
|
/// ```rs
|
||||||
|
/// let input = "up";
|
||||||
|
/// enum_parse { "direction", input,
|
||||||
|
/// "up" => Direction::Up,
|
||||||
|
/// "down" => Direction::Down,
|
||||||
|
/// }
|
||||||
|
/// ```
|
||||||
|
#[macro_export]
|
||||||
|
macro_rules! enum_parse {
|
||||||
|
($name:literal, $input:expr, $($($s:literal)|* => $val:expr),* $(,)?) => {
|
||||||
|
let input = $input.to_lowercase();
|
||||||
|
match input.as_str() {
|
||||||
|
$( $( $s )|* => Ok($val) ),*,
|
||||||
|
_ => Err(EnumParseError {
|
||||||
|
input: $name,
|
||||||
|
expected: vec![$($($s),*),*],
|
||||||
|
})
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, PartialEq, Eq, SmartDefault)]
|
||||||
|
pub enum EwwWindowType {
|
||||||
|
#[default]
|
||||||
|
Dock,
|
||||||
|
Dialog,
|
||||||
|
Toolbar,
|
||||||
|
Normal,
|
||||||
|
Utility,
|
||||||
|
}
|
||||||
|
impl FromStr for EwwWindowType {
|
||||||
|
type Err = EnumParseError;
|
||||||
|
|
||||||
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
||||||
|
enum_parse! { "window type", s,
|
||||||
|
"dock" => Self::Dock,
|
||||||
|
"toolbar" => Self::Toolbar,
|
||||||
|
"dialog" => Self::Dialog,
|
||||||
|
"normal" => Self::Normal,
|
||||||
|
"utility" => Self::Utility,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Copy, Eq, PartialEq, smart_default::SmartDefault)]
|
||||||
|
pub enum Side {
|
||||||
|
#[default]
|
||||||
|
Top,
|
||||||
|
Left,
|
||||||
|
Right,
|
||||||
|
Bottom,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl std::str::FromStr for Side {
|
||||||
|
type Err = anyhow::Error;
|
||||||
|
|
||||||
|
fn from_str(s: &str) -> Result<Side> {
|
||||||
|
enum_parse! { "side", s,
|
||||||
|
"l" | "left" => Side::Left,
|
||||||
|
"r" | "right" => Side::Right,
|
||||||
|
"t" | "top" => Side::Top,
|
||||||
|
"b" | "bottom" => Side::Bottom,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Surface definition if the backend for X11 is enable
|
||||||
|
#[derive(Debug, Clone, Copy, Eq, PartialEq, Default)]
|
||||||
|
pub struct StrutDefinition {
|
||||||
|
pub side: Side,
|
||||||
|
pub dist: NumWithUnit,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl StrutDefinition {
|
||||||
|
pub fn from_xml_element(xml: XmlElement) -> Result<Self> {
|
||||||
|
Ok(StrutDefinition { side: xml.attr("side")?.parse()?, dist: xml.attr("distance")?.parse()? })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, derive_more::Display, SmartDefault)]
|
||||||
|
pub enum WindowStacking {
|
||||||
|
#[default]
|
||||||
|
Foreground,
|
||||||
|
Background,
|
||||||
|
Bottom,
|
||||||
|
Overlay,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl std::str::FromStr for WindowStacking {
|
||||||
|
type Err = anyhow::Error;
|
||||||
|
|
||||||
|
fn from_str(s: &str) -> Result<Self> {
|
||||||
|
enum_parse! { "WindowStacking", s,
|
||||||
|
"foreground" | "fg" => WindowStacking::Foreground,
|
||||||
|
"background" | "bg" => WindowStacking::Background,
|
||||||
|
"bottom" | "bt" => WindowStacking::Bottom,
|
||||||
|
"overlay" | "ov" => WindowStacking::Overlay,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue