diff options
author | Ryan Dahl <ry@tinyclouds.org> | 2020-05-21 10:35:36 -0400 |
---|---|---|
committer | Ryan Dahl <ry@tinyclouds.org> | 2020-06-06 09:07:59 -0400 |
commit | 8a4533eb75ff505f8aa16c206af1ca13f0e6c166 (patch) | |
tree | 2c0b7dec8df5dba684b9f35f2bfbbe9fd51ff7d4 /cli/flags.rs | |
parent | 2093ee55d4c728448a3db373dd416b6eea845c14 (diff) |
feat: deno eval -p (#5682)
Diffstat (limited to 'cli/flags.rs')
-rw-r--r-- | cli/flags.rs | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/cli/flags.rs b/cli/flags.rs index 2c201fcb6..9bf838bfa 100644 --- a/cli/flags.rs +++ b/cli/flags.rs @@ -28,6 +28,7 @@ pub enum DenoSubcommand { filter: Option<String>, }, Eval { + print: bool, code: String, as_typescript: bool, }, @@ -430,7 +431,9 @@ fn eval_parse(flags: &mut Flags, matches: &clap::ArgMatches) { flags.allow_hrtime = true; let code = matches.value_of("code").unwrap().to_string(); let as_typescript = matches.is_present("ts"); + let print = matches.is_present("print"); flags.subcommand = DenoSubcommand::Eval { + print, code, as_typescript, } @@ -744,6 +747,14 @@ This command has implicit access to all permissions (--allow-all).", .takes_value(false) .multiple(false), ) + .arg( + Arg::with_name("print") + .long("print") + .short("p") + .help("print result to stdout") + .takes_value(false) + .multiple(false), + ) .arg(Arg::with_name("code").takes_value(true).required(true)) .arg(v8_flags_arg()) } @@ -1693,6 +1704,7 @@ mod tests { r.unwrap(), Flags { subcommand: DenoSubcommand::Eval { + print: false, code: "'console.log(\"hello\")'".to_string(), as_typescript: false, }, @@ -1709,6 +1721,29 @@ mod tests { } #[test] + fn eval_p() { + let r = flags_from_vec_safe(svec!["deno", "eval", "-p", "1+2"]); + assert_eq!( + r.unwrap(), + Flags { + subcommand: DenoSubcommand::Eval { + print: true, + code: "1+2".to_string(), + as_typescript: false, + }, + allow_net: true, + allow_env: true, + allow_run: true, + allow_read: true, + allow_write: true, + allow_plugin: true, + allow_hrtime: true, + ..Flags::default() + } + ); + } + + #[test] fn eval_unstable() { let r = flags_from_vec_safe(svec![ "deno", @@ -1721,6 +1756,7 @@ mod tests { Flags { unstable: true, subcommand: DenoSubcommand::Eval { + print: false, code: "'console.log(\"hello\")'".to_string(), as_typescript: false, }, @@ -1748,6 +1784,7 @@ mod tests { r.unwrap(), Flags { subcommand: DenoSubcommand::Eval { + print: false, code: "'console.log(\"hello\")'".to_string(), as_typescript: true, }, @@ -1771,6 +1808,7 @@ mod tests { r.unwrap(), Flags { subcommand: DenoSubcommand::Eval { + print: false, code: "42".to_string(), as_typescript: false, }, @@ -2456,6 +2494,7 @@ mod tests { r.unwrap(), Flags { subcommand: DenoSubcommand::Eval { + print: false, code: "console.log('hello world')".to_string(), as_typescript: false, }, @@ -2484,6 +2523,7 @@ mod tests { r.unwrap(), Flags { subcommand: DenoSubcommand::Eval { + print: false, code: "const foo = 'bar'".to_string(), as_typescript: false, }, |