about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2014-09-03 09:21:02 +0000
committerbors <bors@rust-lang.org>2014-09-03 09:21:02 +0000
commit3ce5a026b076276a01ddec5b4b1ffbc171e8fce2 (patch)
tree590a8c4a3c214fa82f3b5536e1f43c6d17e808a6 /src
parentb7d456dfea5487c13ff0389c905693aad85f775f (diff)
parent968b1280e34848f7cf37358c9fd76af18cac2ec7 (diff)
downloadrust-3ce5a026b076276a01ddec5b4b1ffbc171e8fce2.tar.gz
rust-3ce5a026b076276a01ddec5b4b1ffbc171e8fce2.zip
auto merge of #16940 : treeman/rust/fail-non-utf8, r=pnkfelix
Closes #16877.
Diffstat (limited to 'src')
-rw-r--r--src/librustrt/unwind.rs4
-rw-r--r--src/test/run-fail/fail-non-utf8.rs26
2 files changed, 29 insertions, 1 deletions
diff --git a/src/librustrt/unwind.rs b/src/librustrt/unwind.rs
index 9e6dff8a751..fbbc1a08fd9 100644
--- a/src/librustrt/unwind.rs
+++ b/src/librustrt/unwind.rs
@@ -61,6 +61,7 @@ use core::prelude::*;
 
 use alloc::boxed::Box;
 use collections::string::String;
+use collections::str::StrAllocating;
 use collections::vec::Vec;
 use core::any::Any;
 use core::atomic;
@@ -525,7 +526,8 @@ pub fn begin_unwind_fmt(msg: &fmt::Arguments, file_line: &(&'static str, uint))
     let mut v = Vec::new();
     let _ = write!(&mut VecWriter { v: &mut v }, "{}", msg);
 
-    begin_unwind_inner(box String::from_utf8(v).unwrap(), file_line)
+    let msg = box String::from_utf8_lossy(v.as_slice()).into_string();
+    begin_unwind_inner(msg, file_line)
 }
 
 /// This is the entry point of unwinding for fail!() and assert!().
diff --git a/src/test/run-fail/fail-non-utf8.rs b/src/test/run-fail/fail-non-utf8.rs
new file mode 100644
index 00000000000..88720b421e6
--- /dev/null
+++ b/src/test/run-fail/fail-non-utf8.rs
@@ -0,0 +1,26 @@
+
+// Copyright 2013 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+// Previously failed formating invalid utf8.
+// cc #16877
+
+// error-pattern:failed at 'hello�'
+
+struct Foo;
+impl std::fmt::Show for Foo {
+    fn fmt(&self, fmtr:&mut std::fmt::Formatter) -> std::fmt::Result {
+        // Purge invalid utf8: 0xff
+        fmtr.write(&[104, 101, 108, 108, 111, 0xff])
+    }
+}
+fn main() {
+    fail!("{}", Foo)
+}