2011-06-15 11:19:50 -07:00
|
|
|
|
2011-05-04 19:05:16 -07:00
|
|
|
/*
|
|
|
|
* The compiler code necessary to support the #env extension. Eventually this
|
|
|
|
* should all get sucked into either the compiler syntax extension plugin
|
|
|
|
* interface.
|
|
|
|
*/
|
2011-07-05 11:48:19 +02:00
|
|
|
import base::*;
|
2011-05-04 19:05:16 -07:00
|
|
|
export expand_syntax_ext;
|
|
|
|
|
2012-01-31 23:50:12 -07:00
|
|
|
fn expand_syntax_ext(cx: ext_ctxt, sp: codemap::span, arg: ast::mac_arg,
|
2012-01-31 20:30:26 -07:00
|
|
|
_body: ast::mac_body) -> @ast::expr {
|
2012-05-14 15:32:32 -07:00
|
|
|
let args = get_mac_args(cx, sp, arg, 1u, option::some(1u), "env");
|
|
|
|
|
2011-05-06 16:30:39 -07:00
|
|
|
// FIXME: if this was more thorough it would manufacture an
|
2012-04-19 15:20:11 -07:00
|
|
|
// option<str> rather than just an maybe-empty string. (Issue #2248)
|
2011-05-06 16:30:39 -07:00
|
|
|
|
2011-09-02 15:34:58 -07:00
|
|
|
let var = expr_to_str(cx, args[0], "#env requires a string");
|
2012-03-12 20:04:27 -07:00
|
|
|
alt os::getenv(var) {
|
2012-01-18 22:37:22 -08:00
|
|
|
option::none { ret make_new_str(cx, sp, ""); }
|
2011-09-02 15:34:58 -07:00
|
|
|
option::some(s) { ret make_new_str(cx, sp, s); }
|
2011-05-06 16:30:39 -07:00
|
|
|
}
|
2011-05-04 19:05:16 -07:00
|
|
|
}
|
|
|
|
|
2011-09-12 11:27:30 +02:00
|
|
|
fn make_new_str(cx: ext_ctxt, sp: codemap::span, s: str) -> @ast::expr {
|
2011-09-01 22:08:59 -07:00
|
|
|
ret make_new_lit(cx, sp, ast::lit_str(s));
|
2011-05-04 19:05:16 -07:00
|
|
|
}
|
|
|
|
//
|
|
|
|
// Local Variables:
|
|
|
|
// mode: rust
|
|
|
|
// fill-column: 78;
|
|
|
|
// indent-tabs-mode: nil
|
|
|
|
// c-basic-offset: 4
|
|
|
|
// buffer-file-coding-system: utf-8-unix
|
|
|
|
// End:
|
|
|
|
//
|