From 981686ed8fbf5c036ba66621f3eea43665e184d9 Mon Sep 17 00:00:00 2001 From: Konrad Koschel Date: Thu, 11 Jul 2024 15:52:38 +0200 Subject: [PATCH] Allow hyphen for input/output of CLI --- crates/cli/src/js.rs | 2 +- crates/cli/src/main.rs | 18 +++++++++++++++--- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/crates/cli/src/js.rs b/crates/cli/src/js.rs index 1e6465fe..fe5e85ac 100644 --- a/crates/cli/src/js.rs +++ b/crates/cli/src/js.rs @@ -32,7 +32,7 @@ pub struct JS { } impl JS { - fn from_string(source_code: String) -> JS { + pub fn from_string(source_code: String) -> JS { JS { source_code: Rc::new(source_code), } diff --git a/crates/cli/src/main.rs b/crates/cli/src/main.rs index ed07a85c..2d838781 100644 --- a/crates/cli/src/main.rs +++ b/crates/cli/src/main.rs @@ -12,7 +12,7 @@ use clap::Parser; use js::JS; use std::fs; use std::fs::File; -use std::io::Write; +use std::io::{Read, Write}; use wasm_generator::dynamic as dynamic_generator; fn main() -> Result<()> { @@ -21,7 +21,14 @@ fn main() -> Result<()> { match args.command { Command::EmitProvider(opts) => emit_provider(&opts), Command::Compile(opts) => { - let js = JS::from_file(&opts.input)?; + let js = match opts.input.to_str() { + Some("-") => { + let mut content = String::new(); + std::io::stdin().read_to_string(&mut content)?; + JS::from_string(content) + } + _ => JS::from_file(&opts.input)?, + }; let exports = match (&opts.wit, &opts.wit_world) { (None, None) => Ok(vec![]), (None, Some(_)) => Ok(vec![]), @@ -33,7 +40,12 @@ fn main() -> Result<()> { } else { static_generator::generate(&js, exports, opts.no_source_compression)? }; - fs::write(&opts.output, wasm)?; + match opts.output.to_str() { + Some("-") => { + std::io::stdout().write_all(&wasm)?; + } + _ => fs::write(&opts.output, wasm)?, + } Ok(()) } }