diff options
| author | Luqman Aden <laden@csclub.uwaterloo.ca> | 2015-04-25 04:20:08 -0400 |
|---|---|---|
| committer | Luqman Aden <laden@csclub.uwaterloo.ca> | 2015-04-25 07:47:45 -0400 |
| commit | 34601afd5720eb13aa8cf49a02161802900dacf4 (patch) | |
| tree | 0ec95e5abae35ec74a78b94e13bf8cf9b420ac65 | |
| parent | 54d65092a49eba959b5cd7a1c4b2e43b3fedba1f (diff) | |
| download | rust-34601afd5720eb13aa8cf49a02161802900dacf4.tar.gz rust-34601afd5720eb13aa8cf49a02161802900dacf4.zip | |
librustc_trans: Don't ICE on unsized type behind raw pointer in nullable pointer opt.
| -rw-r--r-- | src/librustc_trans/trans/adt.rs | 4 | ||||
| -rw-r--r-- | src/test/run-pass/issue-23433.rs | 24 |
2 files changed, 28 insertions, 0 deletions
diff --git a/src/librustc_trans/trans/adt.rs b/src/librustc_trans/trans/adt.rs index e2827eeae15..d0cbd3370cf 100644 --- a/src/librustc_trans/trans/adt.rs +++ b/src/librustc_trans/trans/adt.rs @@ -414,6 +414,10 @@ fn find_discr_field_candidate<'tcx>(tcx: &ty::ctxt<'tcx>, assert_eq!(nonzero_fields.len(), 1); let nonzero_field = ty::lookup_field_type(tcx, did, nonzero_fields[0].id, substs); match nonzero_field.sty { + ty::ty_ptr(ty::mt { ty, .. }) if !type_is_sized(tcx, ty) => { + path.push_all(&[0, FAT_PTR_ADDR]); + Some(path) + }, ty::ty_ptr(..) | ty::ty_int(..) | ty::ty_uint(..) => { path.push(0); Some(path) diff --git a/src/test/run-pass/issue-23433.rs b/src/test/run-pass/issue-23433.rs new file mode 100644 index 00000000000..82f80586b9f --- /dev/null +++ b/src/test/run-pass/issue-23433.rs @@ -0,0 +1,24 @@ +// Copyright 2015 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. + +// Don't fail if we encounter a NonZero<*T> where T is an unsized type + +#![feature(unique)] + +use std::ptr::Unique; + +fn main() { + let mut a = [0u8; 5]; + let b: Option<Unique<[u8]>> = unsafe { Some(Unique::new(&mut a)) }; + match b { + Some(_) => println!("Got `Some`"), + None => panic!("Unexpected `None`"), + } +} |
