From 06c1d85d63e659166c74bf1d37b5875f1af05126 Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Thu, 28 Sep 2023 12:03:21 -0700 Subject: [PATCH 1/3] Remove usage of `is-terminal` and `atty` crates This functionality is now folded into the standard library itself. --- Cargo.lock | 3 --- crates/environ/Cargo.toml | 1 - crates/environ/examples/factc.rs | 4 ++-- crates/test-programs/Cargo.toml | 1 - crates/test-programs/src/lib.rs | 8 ++++---- crates/wasi-common/cap-std-sync/Cargo.toml | 1 - crates/wasi-common/cap-std-sync/src/file.rs | 5 ++--- crates/wasi-common/cap-std-sync/src/stdio.rs | 9 +++++---- 8 files changed, 13 insertions(+), 19 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 28ec4893c185..69afb4685dee 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -2668,7 +2668,6 @@ dependencies = [ "http-body", "http-body-util", "hyper", - "is-terminal", "lazy_static", "tempfile", "test-log", @@ -3014,7 +3013,6 @@ dependencies = [ "fs-set-times", "io-extras", "io-lifetimes 2.0.2", - "is-terminal", "once_cell", "rustix 0.38.8", "system-interface", @@ -3505,7 +3503,6 @@ name = "wasmtime-environ" version = "14.0.0" dependencies = [ "anyhow", - "atty", "clap", "cranelift-entity", "env_logger 0.10.0", diff --git a/crates/environ/Cargo.toml b/crates/environ/Cargo.toml index 1fd84a613fdf..b09f3cfd4276 100644 --- a/crates/environ/Cargo.toml +++ b/crates/environ/Cargo.toml @@ -28,7 +28,6 @@ wasmprinter = { workspace = true, optional = true } wasmtime-component-util = { workspace = true, optional = true } [dev-dependencies] -atty = "0.2.14" clap = { workspace = true } env_logger = { workspace = true } wat = { workspace = true } diff --git a/crates/environ/examples/factc.rs b/crates/environ/examples/factc.rs index 171fd6cd962d..6dfb7136e485 100644 --- a/crates/environ/examples/factc.rs +++ b/crates/environ/examples/factc.rs @@ -1,6 +1,6 @@ use anyhow::{bail, Context, Result}; use clap::Parser; -use std::io::Write; +use std::io::{IsTerminal, Write}; use std::path::PathBuf; use wasmparser::{Validator, WasmFeatures}; use wasmtime_environ::component::*; @@ -179,7 +179,7 @@ impl Factc { wasmprinter::print_bytes(&wasm) .context("failed to convert binary wasm to text")? .into_bytes() - } else if self.output.is_none() && atty::is(atty::Stream::Stdout) { + } else if self.output.is_none() && std::io::stdout().is_terminal() { bail!("cannot print binary wasm output to a terminal unless `-t` flag is passed") } else { wasm.clone() diff --git a/crates/test-programs/Cargo.toml b/crates/test-programs/Cargo.toml index 4808b8e462e7..e52d148754d0 100644 --- a/crates/test-programs/Cargo.toml +++ b/crates/test-programs/Cargo.toml @@ -19,7 +19,6 @@ http = { version = "0.2.9" } http-body = "1.0.0-rc.2" http-body-util = "0.1.0-rc.2" hyper = { version = "1.0.0-rc.3", features = ["full"] } -is-terminal = { workspace = true } tokio = { workspace = true, features = ["net", "rt-multi-thread", "macros"] } tracing = { workspace = true } diff --git a/crates/test-programs/src/lib.rs b/crates/test-programs/src/lib.rs index cd3b710703c1..f793242b3048 100644 --- a/crates/test-programs/src/lib.rs +++ b/crates/test-programs/src/lib.rs @@ -1,5 +1,6 @@ ///! This crate exists to build crates for wasm32-wasi in build.rs, and execute ///! these wasm programs in harnesses defined under tests/. +use std::io::IsTerminal; #[cfg(all(feature = "test_programs", not(skip_wasi_http_tests)))] pub mod http_server; @@ -40,8 +41,7 @@ pub fn wasi_tests_environment() -> &'static [(&'static str, &'static str)] { } pub fn stdio_is_terminal() -> bool { - use is_terminal::is_terminal; - is_terminal(&std::io::stdin()) - && is_terminal(&std::io::stdout()) - && is_terminal(&std::io::stderr()) + std::io::stdin().is_terminal() + && std::io::stdout().is_terminal() + && std::io::stderr().is_terminal() } diff --git a/crates/wasi-common/cap-std-sync/Cargo.toml b/crates/wasi-common/cap-std-sync/Cargo.toml index f0fe058eac32..f9811bbb51f6 100644 --- a/crates/wasi-common/cap-std-sync/Cargo.toml +++ b/crates/wasi-common/cap-std-sync/Cargo.toml @@ -23,7 +23,6 @@ fs-set-times = { workspace = true } system-interface = { workspace = true, features = ["cap_std_impls"] } tracing = { workspace = true } io-lifetimes = { workspace = true } -is-terminal = { workspace = true } [target.'cfg(unix)'.dependencies] rustix = { workspace = true, features = ["fs", "event"] } diff --git a/crates/wasi-common/cap-std-sync/src/file.rs b/crates/wasi-common/cap-std-sync/src/file.rs index 20a95e94425a..7d13949a346c 100644 --- a/crates/wasi-common/cap-std-sync/src/file.rs +++ b/crates/wasi-common/cap-std-sync/src/file.rs @@ -1,10 +1,9 @@ use cap_fs_ext::MetadataExt; use fs_set_times::{SetTimes, SystemTimeSpec}; use io_lifetimes::AsFilelike; -use is_terminal::IsTerminal; use std::any::Any; use std::convert::TryInto; -use std::io; +use std::io::{self, IsTerminal}; use system_interface::{ fs::{FileIoExt, GetSetFdFlags}, io::{IoExt, ReadReady}, @@ -128,7 +127,7 @@ impl WasiFile for File { Ok(self.0.num_ready_bytes()?) } fn isatty(&self) -> bool { - self.0.is_terminal() + self.0.as_fd().is_terminal() } } diff --git a/crates/wasi-common/cap-std-sync/src/stdio.rs b/crates/wasi-common/cap-std-sync/src/stdio.rs index e60ddc034ebf..392e88a50229 100644 --- a/crates/wasi-common/cap-std-sync/src/stdio.rs +++ b/crates/wasi-common/cap-std-sync/src/stdio.rs @@ -1,10 +1,8 @@ use crate::file::convert_systimespec; use fs_set_times::SetTimes; -use is_terminal::IsTerminal; use std::any::Any; use std::convert::TryInto; -use std::io; -use std::io::{Read, Write}; +use std::io::{self, IsTerminal, Read, Write}; use system_interface::io::ReadReady; #[cfg(windows)] @@ -77,7 +75,10 @@ impl WasiFile for Stdin { Ok(self.0.num_ready_bytes()?) } fn isatty(&self) -> bool { - self.0.is_terminal() + #[cfg(unix)] + self.0.as_fd().is_terminal() + #[cfg(windows)] + self.0.as_handle().is_terminal() } } #[cfg(windows)] From 2f7153b4361c98a6ade8f231336707f2b66fb5f5 Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Thu, 28 Sep 2023 12:07:05 -0700 Subject: [PATCH 2/3] Fix syntax --- crates/wasi-common/cap-std-sync/src/stdio.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/crates/wasi-common/cap-std-sync/src/stdio.rs b/crates/wasi-common/cap-std-sync/src/stdio.rs index 392e88a50229..b2723d076c98 100644 --- a/crates/wasi-common/cap-std-sync/src/stdio.rs +++ b/crates/wasi-common/cap-std-sync/src/stdio.rs @@ -76,9 +76,9 @@ impl WasiFile for Stdin { } fn isatty(&self) -> bool { #[cfg(unix)] - self.0.as_fd().is_terminal() + return self.0.as_fd().is_terminal(); #[cfg(windows)] - self.0.as_handle().is_terminal() + return self.0.as_handle().is_terminal(); } } #[cfg(windows)] From 39f6083cd188e51b76a5aa4aa9abb5c3eba44d31 Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Fri, 29 Sep 2023 07:09:18 -0700 Subject: [PATCH 3/3] Fix a unix/windows cfg --- crates/wasi-common/cap-std-sync/src/file.rs | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/crates/wasi-common/cap-std-sync/src/file.rs b/crates/wasi-common/cap-std-sync/src/file.rs index 7d13949a346c..e986c173404d 100644 --- a/crates/wasi-common/cap-std-sync/src/file.rs +++ b/crates/wasi-common/cap-std-sync/src/file.rs @@ -127,7 +127,10 @@ impl WasiFile for File { Ok(self.0.num_ready_bytes()?) } fn isatty(&self) -> bool { - self.0.as_fd().is_terminal() + #[cfg(unix)] + return self.0.as_fd().is_terminal(); + #[cfg(windows)] + return self.0.as_handle().is_terminal(); } }