swayfmt 0.31.2

Sway language formatter.
Documentation
//! Configuration options related to rewriting a list.
use crate::config::{user_opts::ListsOptions, whitespace::IndentStyle};
use serde::{Deserialize, Serialize};

#[derive(Debug, Copy, Clone)]
pub struct Lists {
    /// How to handle trailing commas for lists.
    pub trailing_comma: SeparatorTactic,
}

impl Default for Lists {
    fn default() -> Self {
        Self {
            trailing_comma: SeparatorTactic::Vertical,
        }
    }
}

impl Lists {
    pub fn from_opts(opts: &ListsOptions) -> Self {
        let default = Self::default();
        Self {
            trailing_comma: opts.trailing_comma.unwrap_or(default.trailing_comma),
        }
    }
}

/// The definitive formatting tactic for lists.
#[derive(Eq, PartialEq, Debug, Copy, Clone, Serialize, Deserialize)]
pub enum DefinitiveListTactic {
    Vertical,
    Horizontal,
    Mixed,
}

impl DefinitiveListTactic {
    pub fn ends_with_newline(&self, indent_style: IndentStyle) -> bool {
        match indent_style {
            IndentStyle::Block => *self != DefinitiveListTactic::Horizontal,
            IndentStyle::Visual => false,
        }
    }
}

/// Formatting tactic for lists. This will be cast down to a
/// `DefinitiveListTactic` depending on the number and length of the items and
/// their comments.
#[derive(Serialize, Deserialize, Debug, Copy, Clone)]
pub enum ListTactic {
    /// One item per row.
    Vertical,
    /// All items on one row.
    Horizontal,
    /// Try Horizontal layout, if that fails then vertical.
    HorizontalVertical,
    /// HorizontalVertical with a soft limit of n characters.
    LimitedHorizontalVertical(usize),
    /// Pack as many items as possible per row over (possibly) many rows.
    Mixed,
}

#[derive(Serialize, Deserialize, Debug, Copy, Clone)]
pub enum SeparatorTactic {
    Always,
    Never,
    Vertical,
}

impl SeparatorTactic {
    pub fn from_bool(b: bool) -> SeparatorTactic {
        if b {
            SeparatorTactic::Always
        } else {
            SeparatorTactic::Never
        }
    }
}

/// Where to put separator.
#[derive(PartialEq, Eq, Clone, Copy)]
pub enum SeparatorPlace {
    Front,
    Back,
}

impl SeparatorPlace {
    pub fn is_front(self) -> bool {
        self == SeparatorPlace::Front
    }

    pub fn is_back(self) -> bool {
        self == SeparatorPlace::Back
    }

    pub fn from_tactic(
        default: SeparatorPlace,
        tactic: DefinitiveListTactic,
        sep: &str,
    ) -> SeparatorPlace {
        match tactic {
            DefinitiveListTactic::Vertical => default,
            _ => {
                if sep == "," {
                    SeparatorPlace::Back
                } else {
                    default
                }
            }
        }
    }
}