mirror of
https://github.com/nushell/nushell
synced 2025-01-16 07:04:09 +00:00
Add BufWriter to ChildStdin on the plugin interface (#12419)
# Description This speeds up writing messages to the plugin, because otherwise every individual piece of the messages (not even the entire message) is written with one syscall, leading to a lot of back and forth with the kernel. I learned this by running `strace` to debug something and saw a ton of `write()` calls. ```nushell # Before 1..10 | each { timeit { example seq 1 10000 | example sum } } | math avg 269ms 779µs 149ns # After > 1..10 | each { timeit { example seq 1 10000 | example sum } } | math avg 39ms 636µs 643ns ``` # User-Facing Changes - Performance improvement # Tests + Formatting - 🟢 `toolkit fmt` - 🟢 `toolkit clippy` - 🟢 `toolkit test` - 🟢 `toolkit test stdlib`
This commit is contained in:
parent
2562e306b6
commit
0e36c43c64
1 changed files with 3 additions and 2 deletions
|
@ -10,7 +10,7 @@ use std::{
|
||||||
env,
|
env,
|
||||||
ffi::OsStr,
|
ffi::OsStr,
|
||||||
fmt::Write,
|
fmt::Write,
|
||||||
io::{BufReader, Read, Write as WriteTrait},
|
io::{BufReader, BufWriter, Read, Write as WriteTrait},
|
||||||
ops::Deref,
|
ops::Deref,
|
||||||
path::Path,
|
path::Path,
|
||||||
process::{Child, ChildStdout, Command as CommandSys, Stdio},
|
process::{Child, ChildStdout, Command as CommandSys, Stdio},
|
||||||
|
@ -178,8 +178,9 @@ fn make_plugin_interface(
|
||||||
let encoder = get_plugin_encoding(&mut stdout)?;
|
let encoder = get_plugin_encoding(&mut stdout)?;
|
||||||
|
|
||||||
let reader = BufReader::with_capacity(OUTPUT_BUFFER_SIZE, stdout);
|
let reader = BufReader::with_capacity(OUTPUT_BUFFER_SIZE, stdout);
|
||||||
|
let writer = BufWriter::with_capacity(OUTPUT_BUFFER_SIZE, stdin);
|
||||||
|
|
||||||
let mut manager = PluginInterfaceManager::new(source.clone(), (Mutex::new(stdin), encoder));
|
let mut manager = PluginInterfaceManager::new(source.clone(), (Mutex::new(writer), encoder));
|
||||||
manager.set_garbage_collector(gc);
|
manager.set_garbage_collector(gc);
|
||||||
|
|
||||||
let interface = manager.get_interface();
|
let interface = manager.get_interface();
|
||||||
|
|
Loading…
Reference in a new issue