1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
/*
* render/html/element/style.rs
*
* ftml - Library to parse Wikidot text
* Copyright (C) 2019-2022 Wikijump Team
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
use super::prelude::*;
use parcel_css::stylesheet::{ParserOptions, PrinterOptions, StyleSheet};
pub fn render_style(ctx: &mut HtmlContext, input_css: &str) {
let minify = ctx.settings().minify_css;
let parser_options = ParserOptions {
error_recovery: true,
..Default::default()
};
let print_options = PrinterOptions {
minify,
..Default::default()
};
info!("Parsing input CSS ({} bytes)", input_css.len());
let stylesheet = StyleSheet::parse(input_css, parser_options)
.expect("Produced error with recovery enabled");
debug!("Rendering CSS into HTML (minify: {minify})");
let output_css = match stylesheet.to_css(print_options) {
Ok(output) => output.code,
Err(error) => {
error!("Problem outputting CSS from stylesheet: {error}");
debug!("Input CSS:\n{input_css}");
debug!("Parsed stylesheet:\n{stylesheet:#?}");
return;
}
};
ctx.html().style().inner(|ctx| {
// SAFETY: The resultant CSS cannot contain HTML-escaping elements,
// as those are invalid and would not be retained during
// the parcel_css parsing process.
ctx.push_raw_str(&output_css);
});
}