]> git.lizzy.rs Git - rust.git/blobdiff - src/librustc/middle/liveness.rs
Auto merge of #35856 - phimuemue:master, r=brson
[rust.git] / src / librustc / middle / liveness.rs
index 74d29b273ff2b40c9d619275a163aadbddfd4978..b83826de26dd68b60b9936c86302bdcbca6ba1b2 100644 (file)
@@ -1479,7 +1479,13 @@ fn check_ret(&self,
                 self.ir.tcx.region_maps.call_site_extent(id, body.id),
                 &self.fn_ret(id));
 
-        if self.live_on_entry(entry_ln, self.s.no_ret_var).is_some() {
+        if fn_ret.is_never() {
+            // FIXME(durka) this rejects code like `fn foo(x: !) -> ! { x }`
+            if self.live_on_entry(entry_ln, self.s.clean_exit_var).is_some() {
+                span_err!(self.ir.tcx.sess, sp, E0270,
+                          "computation may converge in a function marked as diverging");
+            }
+        } else if self.live_on_entry(entry_ln, self.s.no_ret_var).is_some() {
             let param_env = ParameterEnvironment::for_item(self.ir.tcx, id);
             let t_ret_subst = fn_ret.subst(self.ir.tcx, &param_env.free_substs);
             let is_nil = self.ir.tcx.infer_ctxt(None, Some(param_env),