about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorMazdak Farrokhzad <twingoow@gmail.com>2020-03-19 06:57:36 +0100
committerGitHub <noreply@github.com>2020-03-19 06:57:36 +0100
commit73c3a496cc8ce261e87abbd998b36ab16dab4f4b (patch)
tree92afedadaf106abf4705ade8129565cf9f22ced8 /src/libstd
parent904909fd06cd203cea1651910962943b8338286c (diff)
parentd5b6a20557743911ff9f90af5d8ad24c699570d3 (diff)
downloadrust-73c3a496cc8ce261e87abbd998b36ab16dab4f4b.tar.gz
rust-73c3a496cc8ce261e87abbd998b36ab16dab4f4b.zip
Rollup merge of #69959 - alexcrichton:fix-panic-in-print, r=Mark-Simulacrum
std: Don't abort process when printing panics in tests

This commit fixes an issue when using `set_print` and friends, notably
used by libtest, to avoid aborting the process if printing panics. This
previously panicked due to borrowing a mutable `RefCell` twice, and this
is worked around by borrowing these cells for less time, instead
taking out and removing contents temporarily.

Closes #69558
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/io/stdio.rs12
1 files changed, 8 insertions, 4 deletions
diff --git a/src/libstd/io/stdio.rs b/src/libstd/io/stdio.rs
index d410faca30d..0fb0757792e 100644
--- a/src/libstd/io/stdio.rs
+++ b/src/libstd/io/stdio.rs
@@ -792,10 +792,14 @@ fn print_to<T>(
 {
     let result = local_s
         .try_with(|s| {
-            if let Ok(mut borrowed) = s.try_borrow_mut() {
-                if let Some(w) = borrowed.as_mut() {
-                    return w.write_fmt(args);
-                }
+            // Note that we completely remove a local sink to write to in case
+            // our printing recursively panics/prints, so the recursive
+            // panic/print goes to the global sink instead of our local sink.
+            let prev = s.borrow_mut().take();
+            if let Some(mut w) = prev {
+                let result = w.write_fmt(args);
+                *s.borrow_mut() = Some(w);
+                return result;
             }
             global_s().write_fmt(args)
         })