experimental support for wasm

This commit is contained in:
ConnorSkees 2020-04-24 18:08:20 -04:00
parent a86d717f26
commit b8ca587353
2 changed files with 33 additions and 0 deletions

View File

@ -10,6 +10,7 @@ repository = "https://github.com/connorskees/grass"
authors = ["ConnorSkees <39542938+ConnorSkees@users.noreply.github.com>"] authors = ["ConnorSkees <39542938+ConnorSkees@users.noreply.github.com>"]
edition = "2018" edition = "2018"
exclude = ["*.scss", "sass-spec", "tests", "Cargo.lock"] exclude = ["*.scss", "sass-spec", "tests", "Cargo.lock"]
default-run = "grass"
[[bin]] [[bin]]
name = "grass" name = "grass"
@ -19,6 +20,7 @@ required-features = ["commandline"]
[lib] [lib]
name = "grass" name = "grass"
path = "src/lib.rs" path = "src/lib.rs"
crate-type = ["cdylib", "rlib"]
[dependencies] [dependencies]
clap = { version = "2.33.0", optional = true } clap = { version = "2.33.0", optional = true }
@ -29,6 +31,7 @@ once_cell = "1.3.1"
rand = { version = "0.7.3", optional = true } rand = { version = "0.7.3", optional = true }
codemap = "0.1.3" codemap = "0.1.3"
peekmore = "0.4.0" peekmore = "0.4.0"
wasm-bindgen = { version = "0.2.60", optional = true }
[features] [features]
default = ["commandline", "random"] default = ["commandline", "random"]
@ -38,6 +41,8 @@ commandline = ["clap"]
nightly = [] nightly = []
# Option (enabled by default): enable the builtin functions `random([$limit])` and `unique-id()` # Option (enabled by default): enable the builtin functions `random([$limit])` and `unique-id()`
random = ["rand"] random = ["rand"]
# Option: compile to web assembly
wasm = ["wasm-bindgen"]
[dev-dependencies] [dev-dependencies]
tempfile = "3" tempfile = "3"

View File

@ -88,6 +88,9 @@ use codemap::{CodeMap, Span, Spanned};
use peekmore::{PeekMore, PeekMoreIterator}; use peekmore::{PeekMore, PeekMoreIterator};
#[cfg(feature = "wasm")]
use wasm_bindgen::prelude::*;
use crate::atrule::{eat_include, AtRule, AtRuleKind, Function, Mixin}; use crate::atrule::{eat_include, AtRule, AtRuleKind, Function, Mixin};
pub use crate::error::{SassError, SassResult}; pub use crate::error::{SassError, SassResult};
use crate::imports::import; use crate::imports::import;
@ -124,6 +127,7 @@ mod utils;
mod value; mod value;
/// Represents a parsed SASS stylesheet with nesting /// Represents a parsed SASS stylesheet with nesting
#[cfg_attr(feature = "wasm", wasm_bindgen)]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct StyleSheet(Vec<Spanned<Stmt>>); pub struct StyleSheet(Vec<Spanned<Stmt>>);
@ -188,6 +192,28 @@ fn raw_to_parse_error(map: &CodeMap, err: SassError) -> SassError {
SassError::from_loc(message, map.look_up_span(span)) SassError::from_loc(message, map.look_up_span(span))
} }
#[cfg(feature = "wasm")]
#[wasm_bindgen]
impl StyleSheet {
pub fn new(input: String) -> Result<String, JsValue> {
let mut map = CodeMap::new();
let file = map.add_file("stdin".into(), input);
Ok(Css::from_stylesheet(StyleSheet(
StyleSheetParser {
lexer: Lexer::new(&file).peekmore(),
nesting: 0,
map: &map,
}
.parse_toplevel()
.map_err(|e| raw_to_parse_error(&map, e).to_string())?
.0,
))
.map_err(|e| raw_to_parse_error(&map, e).to_string())?
.pretty_print()
.map_err(|e| raw_to_parse_error(&map, e).to_string())?)
}
}
impl StyleSheet { impl StyleSheet {
/// Write CSS to `buf`, constructed from a string /// Write CSS to `buf`, constructed from a string
/// ///
@ -201,6 +227,7 @@ impl StyleSheet {
/// } /// }
/// ``` /// ```
#[inline] #[inline]
#[cfg(not(feature = "wasm"))]
pub fn new(input: String) -> SassResult<String> { pub fn new(input: String) -> SassResult<String> {
let mut map = CodeMap::new(); let mut map = CodeMap::new();
let file = map.add_file("stdin".into(), input); let file = map.add_file("stdin".into(), input);
@ -230,6 +257,7 @@ impl StyleSheet {
/// } /// }
/// ``` /// ```
#[inline] #[inline]
#[cfg(not(feature = "wasm"))]
pub fn from_path<P: AsRef<Path> + Into<String> + Clone>(p: P) -> SassResult<String> { pub fn from_path<P: AsRef<Path> + Into<String> + Clone>(p: P) -> SassResult<String> {
let mut map = CodeMap::new(); let mut map = CodeMap::new();
let file = map.add_file(p.clone().into(), String::from_utf8(fs::read(p)?)?); let file = map.add_file(p.clone().into(), String::from_utf8(fs::read(p)?)?);