Fallback to broader scope if theme scope not found (#1714)

pull/1747/head
Gokul Soumya 3 years ago committed by GitHub
parent c484b08923
commit 74a9dd51ff
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -27,16 +27,15 @@ pub struct Markdown {
// better yet, just use Tendril + subtendril for references // better yet, just use Tendril + subtendril for references
impl Markdown { impl Markdown {
// theme keys, including fallbacks const TEXT_STYLE: &'static str = "ui.text";
const TEXT_STYLE: [&'static str; 2] = ["ui.text", "ui"]; const BLOCK_STYLE: &'static str = "markup.raw.inline";
const BLOCK_STYLE: [&'static str; 3] = ["markup.raw.inline", "markup.raw", "markup"]; const HEADING_STYLES: [&'static str; 6] = [
const HEADING_STYLES: [[&'static str; 3]; 6] = [ "markup.heading.1",
["markup.heading.1", "markup.heading", "markup"], "markup.heading.2",
["markup.heading.2", "markup.heading", "markup"], "markup.heading.3",
["markup.heading.3", "markup.heading", "markup"], "markup.heading.4",
["markup.heading.4", "markup.heading", "markup"], "markup.heading.5",
["markup.heading.5", "markup.heading", "markup"], "markup.heading.6",
["markup.heading.6", "markup.heading", "markup"],
]; ];
pub fn new(contents: String, config_loader: Arc<syntax::Loader>) -> Self { pub fn new(contents: String, config_loader: Arc<syntax::Loader>) -> Self {
@ -59,15 +58,9 @@ impl Markdown {
let mut spans = Vec::new(); let mut spans = Vec::new();
let mut lines = Vec::new(); let mut lines = Vec::new();
let get_theme = |keys: &[&str]| match theme { let get_theme = |key: &str| -> Style { theme.map(|t| t.get(key)).unwrap_or_default() };
Some(theme) => keys let text_style = get_theme(Self::TEXT_STYLE);
.iter() let code_style = get_theme(Self::BLOCK_STYLE);
.find_map(|key| theme.try_get(key))
.unwrap_or_default(),
None => Default::default(),
};
let text_style = get_theme(&Self::TEXT_STYLE);
let code_style = get_theme(&Self::BLOCK_STYLE);
let heading_styles: Vec<Style> = Self::HEADING_STYLES let heading_styles: Vec<Style> = Self::HEADING_STYLES
.iter() .iter()
.map(|key| get_theme(key)) .map(|key| get_theme(key))

@ -153,8 +153,12 @@ impl Theme {
self.try_get(scope).unwrap_or_default() self.try_get(scope).unwrap_or_default()
} }
/// Get the style of a scope, falling back to dot separated broader
/// scopes. For example if `ui.text.focus` is not defined in the theme,
/// `ui.text` is tried and then `ui` is tried.
pub fn try_get(&self, scope: &str) -> Option<Style> { pub fn try_get(&self, scope: &str) -> Option<Style> {
self.styles.get(scope).copied() std::iter::successors(Some(scope), |s| Some(s.rsplit_once('.')?.0))
.find_map(|s| self.styles.get(s).copied())
} }
#[inline] #[inline]

Loading…
Cancel
Save