File tree Expand file tree Collapse file tree 3 files changed +8
-4
lines changed
librustc/middle/typeck/check Expand file tree Collapse file tree 3 files changed +8
-4
lines changed Original file line number Diff line number Diff line change 1
1
---
2
- refs/heads/master: e5f8026ebab867547514677bf9d7c7870a4345ad
2
+ refs/heads/master: bbc4ca134900456ba2a00368ec1f19bc1a357528
3
3
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
4
4
refs/heads/snap-stage3: f7a2371c176663d59062ec5158f39faecba45768
5
5
refs/heads/try: 2a8fb58d79e685d5ca07b039badcf2ae3ef077ea
Original file line number Diff line number Diff line change @@ -99,8 +99,12 @@ pub unsafe fn borrow_as_imm(a: *u8) {
99
99
#[ lang="return_to_mut" ]
100
100
#[ inline( always) ]
101
101
pub unsafe fn return_to_mut ( a : * u8 ) {
102
- let a: * mut BoxRepr = transmute ( a) ;
103
- ( * a) . header . ref_count &= !FROZEN_BIT ;
102
+ // Sometimes the box is null, if it is conditionally frozen.
103
+ // See e.g. #4904.
104
+ if !a. is_null ( ) {
105
+ let a: * mut BoxRepr = transmute ( a) ;
106
+ ( * a) . header . ref_count &= !FROZEN_BIT ;
107
+ }
104
108
}
105
109
106
110
#[ lang="check_not_borrowed" ]
Original file line number Diff line number Diff line change @@ -615,7 +615,7 @@ pub mod guarantor {
615
615
// expressions, both of which always yield a region variable, so
616
616
// mk_subr should never fail.
617
617
let rptr_ty = rcx. resolve_node_type( id) ;
618
- if !ty:: type_is_error( rptr_ty) {
618
+ if !ty:: type_is_error( rptr_ty) && !ty :: type_is_bot ( rptr_ty ) {
619
619
let tcx = rcx. fcx. ccx. tcx;
620
620
debug!( "rptr_ty=%s", ty_to_str( tcx, rptr_ty) ) ;
621
621
let r = ty:: ty_region( tcx, span, rptr_ty) ;
You can’t perform that action at this time.
0 commit comments