Merge pull request #503 from serde-rs/stack
Set RUST_MIN_STACK if unset
This commit is contained in:
commit
01f6115d73
36
serde_codegen/src/env.rs
Normal file
36
serde_codegen/src/env.rs
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
use std::env;
|
||||||
|
use std::ffi::OsStr;
|
||||||
|
use std::ops::Drop;
|
||||||
|
|
||||||
|
pub fn set_if_unset<K, V>(k: K, v: V) -> TmpEnv<K>
|
||||||
|
where K: AsRef<OsStr>,
|
||||||
|
V: AsRef<OsStr>,
|
||||||
|
{
|
||||||
|
match env::var(&k) {
|
||||||
|
Ok(_) => TmpEnv::WasAlreadySet,
|
||||||
|
Err(_) => {
|
||||||
|
env::set_var(&k, v);
|
||||||
|
TmpEnv::WasNotSet { k: k }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[must_use]
|
||||||
|
pub enum TmpEnv<K>
|
||||||
|
where K: AsRef<OsStr>,
|
||||||
|
{
|
||||||
|
WasAlreadySet,
|
||||||
|
WasNotSet {
|
||||||
|
k: K,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<K> Drop for TmpEnv<K>
|
||||||
|
where K: AsRef<OsStr>,
|
||||||
|
{
|
||||||
|
fn drop(&mut self) {
|
||||||
|
if let TmpEnv::WasNotSet { ref k } = *self {
|
||||||
|
env::remove_var(k);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -35,48 +35,62 @@ include!(concat!(env!("OUT_DIR"), "/lib.rs"));
|
|||||||
#[cfg(not(feature = "with-syntex"))]
|
#[cfg(not(feature = "with-syntex"))]
|
||||||
include!("lib.rs.in");
|
include!("lib.rs.in");
|
||||||
|
|
||||||
|
#[cfg(feature = "with-syntex")]
|
||||||
|
mod env;
|
||||||
|
|
||||||
#[cfg(feature = "with-syntex")]
|
#[cfg(feature = "with-syntex")]
|
||||||
pub fn expand<S, D>(src: S, dst: D) -> Result<(), syntex::Error>
|
pub fn expand<S, D>(src: S, dst: D) -> Result<(), syntex::Error>
|
||||||
where S: AsRef<Path>,
|
where S: AsRef<Path>,
|
||||||
D: AsRef<Path>,
|
D: AsRef<Path>,
|
||||||
{
|
{
|
||||||
use syntax::{ast, fold};
|
let src = src.as_ref().to_owned();
|
||||||
|
let dst = dst.as_ref().to_owned();
|
||||||
|
|
||||||
/// Strip the serde attributes from the crate.
|
let expand_thread = move || {
|
||||||
#[cfg(feature = "with-syntex")]
|
use syntax::{ast, fold};
|
||||||
fn strip_attributes(krate: ast::Crate) -> ast::Crate {
|
|
||||||
/// Helper folder that strips the serde attributes after the extensions have been expanded.
|
|
||||||
struct StripAttributeFolder;
|
|
||||||
|
|
||||||
impl fold::Folder for StripAttributeFolder {
|
/// Strip the serde attributes from the crate.
|
||||||
fn fold_attribute(&mut self, attr: ast::Attribute) -> Option<ast::Attribute> {
|
#[cfg(feature = "with-syntex")]
|
||||||
match attr.node.value.node {
|
fn strip_attributes(krate: ast::Crate) -> ast::Crate {
|
||||||
ast::MetaItemKind::List(ref n, _) if n == &"serde" => { return None; }
|
/// Helper folder that strips the serde attributes after the extensions have been expanded.
|
||||||
_ => {}
|
struct StripAttributeFolder;
|
||||||
|
|
||||||
|
impl fold::Folder for StripAttributeFolder {
|
||||||
|
fn fold_attribute(&mut self, attr: ast::Attribute) -> Option<ast::Attribute> {
|
||||||
|
match attr.node.value.node {
|
||||||
|
ast::MetaItemKind::List(ref n, _) if n == &"serde" => { return None; }
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
|
||||||
|
Some(attr)
|
||||||
}
|
}
|
||||||
|
|
||||||
Some(attr)
|
fn fold_mac(&mut self, mac: ast::Mac) -> ast::Mac {
|
||||||
|
fold::noop_fold_mac(mac, self)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn fold_mac(&mut self, mac: ast::Mac) -> ast::Mac {
|
fold::Folder::fold_crate(&mut StripAttributeFolder, krate)
|
||||||
fold::noop_fold_mac(mac, self)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fold::Folder::fold_crate(&mut StripAttributeFolder, krate)
|
let mut reg = syntex::Registry::new();
|
||||||
}
|
|
||||||
|
|
||||||
let mut reg = syntex::Registry::new();
|
reg.add_attr("feature(custom_derive)");
|
||||||
|
reg.add_attr("feature(custom_attribute)");
|
||||||
|
|
||||||
reg.add_attr("feature(custom_derive)");
|
reg.add_decorator("derive_Serialize", ser::expand_derive_serialize);
|
||||||
reg.add_attr("feature(custom_attribute)");
|
reg.add_decorator("derive_Deserialize", de::expand_derive_deserialize);
|
||||||
|
|
||||||
reg.add_decorator("derive_Serialize", ser::expand_derive_serialize);
|
reg.add_post_expansion_pass(strip_attributes);
|
||||||
reg.add_decorator("derive_Deserialize", de::expand_derive_deserialize);
|
|
||||||
|
|
||||||
reg.add_post_expansion_pass(strip_attributes);
|
reg.expand("", src, dst)
|
||||||
|
};
|
||||||
|
|
||||||
reg.expand("", src.as_ref(), dst.as_ref())
|
// 16 MB stack unless otherwise specified
|
||||||
|
let _tmp_env = env::set_if_unset("RUST_MIN_STACK", "16777216");
|
||||||
|
|
||||||
|
use std::thread;
|
||||||
|
thread::spawn(expand_thread).join().unwrap()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(feature = "with-syntex"))]
|
#[cfg(not(feature = "with-syntex"))]
|
||||||
|
Loading…
Reference in New Issue
Block a user