]> git.lizzy.rs Git - rust.git/blob - src/librustc_typeck/check/mod.rs
48475b3dcb802b0af0786dacd1a09d8f06df87e2
[rust.git] / src / librustc_typeck / check / mod.rs
1 /*!
2
3 # check.rs
4
5 Within the check phase of type check, we check each item one at a time
6 (bodies of function expressions are checked as part of the containing
7 function). Inference is used to supply types wherever they are unknown.
8
9 By far the most complex case is checking the body of a function. This
10 can be broken down into several distinct phases:
11
12 - gather: creates type variables to represent the type of each local
13   variable and pattern binding.
14
15 - main: the main pass does the lion's share of the work: it
16   determines the types of all expressions, resolves
17   methods, checks for most invalid conditions, and so forth.  In
18   some cases, where a type is unknown, it may create a type or region
19   variable and use that as the type of an expression.
20
21   In the process of checking, various constraints will be placed on
22   these type variables through the subtyping relationships requested
23   through the `demand` module.  The `infer` module is in charge
24   of resolving those constraints.
25
26 - regionck: after main is complete, the regionck pass goes over all
27   types looking for regions and making sure that they did not escape
28   into places they are not in scope.  This may also influence the
29   final assignments of the various region variables if there is some
30   flexibility.
31
32 - vtable: find and records the impls to use for each trait bound that
33   appears on a type parameter.
34
35 - writeback: writes the final types within a function body, replacing
36   type variables with their final inferred types.  These final types
37   are written into the `tcx.node_types` table, which should *never* contain
38   any reference to a type variable.
39
40 ## Intermediate types
41
42 While type checking a function, the intermediate types for the
43 expressions, blocks, and so forth contained within the function are
44 stored in `fcx.node_types` and `fcx.node_substs`.  These types
45 may contain unresolved type variables.  After type checking is
46 complete, the functions in the writeback module are used to take the
47 types from this table, resolve them, and then write them into their
48 permanent home in the type context `tcx`.
49
50 This means that during inferencing you should use `fcx.write_ty()`
51 and `fcx.expr_ty()` / `fcx.node_ty()` to write/obtain the types of
52 nodes within the function.
53
54 The types of top-level items, which never contain unbound type
55 variables, are stored directly into the `tcx` tables.
56
57 N.B., a type variable is not the same thing as a type parameter.  A
58 type variable is rather an "instance" of a type parameter: that is,
59 given a generic function `fn foo<T>(t: T)`: while checking the
60 function `foo`, the type `ty_param(0)` refers to the type `T`, which
61 is treated in abstract.  When `foo()` is called, however, `T` will be
62 substituted for a fresh type variable `N`.  This variable will
63 eventually be resolved to some concrete type (which might itself be
64 type parameter).
65
66 */
67
68 mod autoderef;
69 pub mod dropck;
70 pub mod _match;
71 pub mod writeback;
72 mod regionck;
73 pub mod coercion;
74 pub mod demand;
75 pub mod method;
76 mod upvar;
77 mod wfcheck;
78 mod cast;
79 mod closure;
80 mod callee;
81 mod compare_method;
82 mod generator_interior;
83 pub mod intrinsic;
84 mod op;
85
86 use astconv::{AstConv, PathSeg};
87 use errors::{Applicability, DiagnosticBuilder, DiagnosticId};
88 use rustc::hir::{self, ExprKind, GenericArg, ItemKind, Node, PatKind, QPath};
89 use rustc::hir::def::{CtorKind, Def};
90 use rustc::hir::def_id::{CrateNum, DefId, LOCAL_CRATE};
91 use rustc::hir::intravisit::{self, Visitor, NestedVisitorMap};
92 use rustc::hir::itemlikevisit::ItemLikeVisitor;
93 use middle::lang_items;
94 use namespace::Namespace;
95 use rustc::infer::{self, InferCtxt, InferOk, InferResult, RegionVariableOrigin};
96 use rustc::infer::canonical::{Canonical, OriginalQueryValues, QueryResponse};
97 use rustc_data_structures::indexed_vec::Idx;
98 use rustc_data_structures::sync::Lrc;
99 use rustc_target::spec::abi::Abi;
100 use rustc::infer::opaque_types::OpaqueTypeDecl;
101 use rustc::infer::type_variable::{TypeVariableOrigin};
102 use rustc::middle::region;
103 use rustc::mir::interpret::{ConstValue, GlobalId};
104 use rustc::traits::{self, ObligationCause, ObligationCauseCode, TraitEngine};
105 use rustc::ty::{
106     self, AdtKind, CanonicalUserType, Ty, TyCtxt, GenericParamDefKind, Visibility,
107     ToPolyTraitRef, ToPredicate, RegionKind, UserType
108 };
109 use rustc::ty::adjustment::{Adjust, Adjustment, AllowTwoPhase, AutoBorrow, AutoBorrowMutability};
110 use rustc::ty::fold::TypeFoldable;
111 use rustc::ty::query::Providers;
112 use rustc::ty::subst::{UnpackedKind, Subst, Substs, UserSelfTy, UserSubsts};
113 use rustc::ty::util::{Representability, IntTypeExt, Discr};
114 use rustc::ty::layout::VariantIdx;
115 use syntax_pos::{self, BytePos, Span, MultiSpan};
116 use syntax::ast;
117 use syntax::attr;
118 use syntax::feature_gate::{GateIssue, emit_feature_err};
119 use syntax::ptr::P;
120 use syntax::source_map::{DUMMY_SP, original_sp};
121 use syntax::symbol::{Symbol, LocalInternedString, keywords};
122 use syntax::util::lev_distance::find_best_match_for_name;
123
124 use std::cell::{Cell, RefCell, Ref, RefMut};
125 use std::collections::hash_map::Entry;
126 use std::cmp;
127 use std::fmt::Display;
128 use std::iter;
129 use std::mem::replace;
130 use std::ops::{self, Deref};
131 use std::slice;
132
133 use require_c_abi_if_variadic;
134 use session::{CompileIncomplete, Session};
135 use session::config::EntryFnType;
136 use TypeAndSubsts;
137 use lint;
138 use util::captures::Captures;
139 use util::common::{ErrorReported, indenter};
140 use util::nodemap::{DefIdMap, DefIdSet, FxHashMap, FxHashSet, NodeMap};
141
142 pub use self::Expectation::*;
143 use self::autoderef::Autoderef;
144 use self::callee::DeferredCallResolution;
145 use self::coercion::{CoerceMany, DynamicCoerceMany};
146 pub use self::compare_method::{compare_impl_method, compare_const_impl};
147 use self::method::{MethodCallee, SelfSource};
148 use self::TupleArgumentsFlag::*;
149
150 /// The type of a local binding, including the revealed type for anon types.
151 #[derive(Copy, Clone)]
152 pub struct LocalTy<'tcx> {
153     decl_ty: Ty<'tcx>,
154     revealed_ty: Ty<'tcx>
155 }
156
157 /// A wrapper for InferCtxt's `in_progress_tables` field.
158 #[derive(Copy, Clone)]
159 struct MaybeInProgressTables<'a, 'tcx: 'a> {
160     maybe_tables: Option<&'a RefCell<ty::TypeckTables<'tcx>>>,
161 }
162
163 impl<'a, 'tcx> MaybeInProgressTables<'a, 'tcx> {
164     fn borrow(self) -> Ref<'a, ty::TypeckTables<'tcx>> {
165         match self.maybe_tables {
166             Some(tables) => tables.borrow(),
167             None => {
168                 bug!("MaybeInProgressTables: inh/fcx.tables.borrow() with no tables")
169             }
170         }
171     }
172
173     fn borrow_mut(self) -> RefMut<'a, ty::TypeckTables<'tcx>> {
174         match self.maybe_tables {
175             Some(tables) => tables.borrow_mut(),
176             None => {
177                 bug!("MaybeInProgressTables: inh/fcx.tables.borrow_mut() with no tables")
178             }
179         }
180     }
181 }
182
183 /// closures defined within the function.  For example:
184 ///
185 ///     fn foo() {
186 ///         bar(move|| { ... })
187 ///     }
188 ///
189 /// Here, the function `foo()` and the closure passed to
190 /// `bar()` will each have their own `FnCtxt`, but they will
191 /// share the inherited fields.
192 pub struct Inherited<'a, 'gcx: 'a+'tcx, 'tcx: 'a> {
193     infcx: InferCtxt<'a, 'gcx, 'tcx>,
194
195     tables: MaybeInProgressTables<'a, 'tcx>,
196
197     locals: RefCell<NodeMap<LocalTy<'tcx>>>,
198
199     fulfillment_cx: RefCell<Box<dyn TraitEngine<'tcx>>>,
200
201     // Some additional `Sized` obligations badly affect type inference.
202     // These obligations are added in a later stage of typeck.
203     deferred_sized_obligations: RefCell<Vec<(Ty<'tcx>, Span, traits::ObligationCauseCode<'tcx>)>>,
204
205     // When we process a call like `c()` where `c` is a closure type,
206     // we may not have decided yet whether `c` is a `Fn`, `FnMut`, or
207     // `FnOnce` closure. In that case, we defer full resolution of the
208     // call until upvar inference can kick in and make the
209     // decision. We keep these deferred resolutions grouped by the
210     // def-id of the closure, so that once we decide, we can easily go
211     // back and process them.
212     deferred_call_resolutions: RefCell<DefIdMap<Vec<DeferredCallResolution<'gcx, 'tcx>>>>,
213
214     deferred_cast_checks: RefCell<Vec<cast::CastCheck<'tcx>>>,
215
216     deferred_generator_interiors: RefCell<Vec<(hir::BodyId, Ty<'tcx>)>>,
217
218     // Opaque types found in explicit return types and their
219     // associated fresh inference variable. Writeback resolves these
220     // variables to get the concrete type, which can be used to
221     // 'de-opaque' OpaqueTypeDecl, after typeck is done with all functions.
222     opaque_types: RefCell<DefIdMap<OpaqueTypeDecl<'tcx>>>,
223
224     /// Each type parameter has an implicit region bound that
225     /// indicates it must outlive at least the function body (the user
226     /// may specify stronger requirements). This field indicates the
227     /// region of the callee. If it is `None`, then the parameter
228     /// environment is for an item or something where the "callee" is
229     /// not clear.
230     implicit_region_bound: Option<ty::Region<'tcx>>,
231
232     body_id: Option<hir::BodyId>,
233 }
234
235 impl<'a, 'gcx, 'tcx> Deref for Inherited<'a, 'gcx, 'tcx> {
236     type Target = InferCtxt<'a, 'gcx, 'tcx>;
237     fn deref(&self) -> &Self::Target {
238         &self.infcx
239     }
240 }
241
242 /// When type-checking an expression, we propagate downward
243 /// whatever type hint we are able in the form of an `Expectation`.
244 #[derive(Copy, Clone, Debug)]
245 pub enum Expectation<'tcx> {
246     /// We know nothing about what type this expression should have.
247     NoExpectation,
248
249     /// This expression is an `if` condition, it must resolve to `bool`.
250     ExpectIfCondition,
251
252     /// This expression should have the type given (or some subtype)
253     ExpectHasType(Ty<'tcx>),
254
255     /// This expression will be cast to the `Ty`
256     ExpectCastableToType(Ty<'tcx>),
257
258     /// This rvalue expression will be wrapped in `&` or `Box` and coerced
259     /// to `&Ty` or `Box<Ty>`, respectively. `Ty` is `[A]` or `Trait`.
260     ExpectRvalueLikeUnsized(Ty<'tcx>),
261 }
262
263 impl<'a, 'gcx, 'tcx> Expectation<'tcx> {
264     // Disregard "castable to" expectations because they
265     // can lead us astray. Consider for example `if cond
266     // {22} else {c} as u8` -- if we propagate the
267     // "castable to u8" constraint to 22, it will pick the
268     // type 22u8, which is overly constrained (c might not
269     // be a u8). In effect, the problem is that the
270     // "castable to" expectation is not the tightest thing
271     // we can say, so we want to drop it in this case.
272     // The tightest thing we can say is "must unify with
273     // else branch". Note that in the case of a "has type"
274     // constraint, this limitation does not hold.
275
276     // If the expected type is just a type variable, then don't use
277     // an expected type. Otherwise, we might write parts of the type
278     // when checking the 'then' block which are incompatible with the
279     // 'else' branch.
280     fn adjust_for_branches(&self, fcx: &FnCtxt<'a, 'gcx, 'tcx>) -> Expectation<'tcx> {
281         match *self {
282             ExpectHasType(ety) => {
283                 let ety = fcx.shallow_resolve(ety);
284                 if !ety.is_ty_var() {
285                     ExpectHasType(ety)
286                 } else {
287                     NoExpectation
288                 }
289             }
290             ExpectRvalueLikeUnsized(ety) => {
291                 ExpectRvalueLikeUnsized(ety)
292             }
293             _ => NoExpectation
294         }
295     }
296
297     /// Provide an expectation for an rvalue expression given an *optional*
298     /// hint, which is not required for type safety (the resulting type might
299     /// be checked higher up, as is the case with `&expr` and `box expr`), but
300     /// is useful in determining the concrete type.
301     ///
302     /// The primary use case is where the expected type is a fat pointer,
303     /// like `&[isize]`. For example, consider the following statement:
304     ///
305     ///    let x: &[isize] = &[1, 2, 3];
306     ///
307     /// In this case, the expected type for the `&[1, 2, 3]` expression is
308     /// `&[isize]`. If however we were to say that `[1, 2, 3]` has the
309     /// expectation `ExpectHasType([isize])`, that would be too strong --
310     /// `[1, 2, 3]` does not have the type `[isize]` but rather `[isize; 3]`.
311     /// It is only the `&[1, 2, 3]` expression as a whole that can be coerced
312     /// to the type `&[isize]`. Therefore, we propagate this more limited hint,
313     /// which still is useful, because it informs integer literals and the like.
314     /// See the test case `test/run-pass/coerce-expect-unsized.rs` and #20169
315     /// for examples of where this comes up,.
316     fn rvalue_hint(fcx: &FnCtxt<'a, 'gcx, 'tcx>, ty: Ty<'tcx>) -> Expectation<'tcx> {
317         match fcx.tcx.struct_tail(ty).sty {
318             ty::Slice(_) | ty::Str | ty::Dynamic(..) => {
319                 ExpectRvalueLikeUnsized(ty)
320             }
321             _ => ExpectHasType(ty)
322         }
323     }
324
325     // Resolves `expected` by a single level if it is a variable. If
326     // there is no expected type or resolution is not possible (e.g.,
327     // no constraints yet present), just returns `None`.
328     fn resolve(self, fcx: &FnCtxt<'a, 'gcx, 'tcx>) -> Expectation<'tcx> {
329         match self {
330             NoExpectation => NoExpectation,
331             ExpectIfCondition => ExpectIfCondition,
332             ExpectCastableToType(t) => {
333                 ExpectCastableToType(fcx.resolve_type_vars_if_possible(&t))
334             }
335             ExpectHasType(t) => {
336                 ExpectHasType(fcx.resolve_type_vars_if_possible(&t))
337             }
338             ExpectRvalueLikeUnsized(t) => {
339                 ExpectRvalueLikeUnsized(fcx.resolve_type_vars_if_possible(&t))
340             }
341         }
342     }
343
344     fn to_option(self, fcx: &FnCtxt<'a, 'gcx, 'tcx>) -> Option<Ty<'tcx>> {
345         match self.resolve(fcx) {
346             NoExpectation => None,
347             ExpectIfCondition => Some(fcx.tcx.types.bool),
348             ExpectCastableToType(ty) |
349             ExpectHasType(ty) |
350             ExpectRvalueLikeUnsized(ty) => Some(ty),
351         }
352     }
353
354     /// It sometimes happens that we want to turn an expectation into
355     /// a **hard constraint** (i.e., something that must be satisfied
356     /// for the program to type-check). `only_has_type` will return
357     /// such a constraint, if it exists.
358     fn only_has_type(self, fcx: &FnCtxt<'a, 'gcx, 'tcx>) -> Option<Ty<'tcx>> {
359         match self.resolve(fcx) {
360             ExpectHasType(ty) => Some(ty),
361             ExpectIfCondition => Some(fcx.tcx.types.bool),
362             NoExpectation | ExpectCastableToType(_) | ExpectRvalueLikeUnsized(_) => None,
363         }
364     }
365
366     /// Like `only_has_type`, but instead of returning `None` if no
367     /// hard constraint exists, creates a fresh type variable.
368     fn coercion_target_type(self, fcx: &FnCtxt<'a, 'gcx, 'tcx>, span: Span) -> Ty<'tcx> {
369         self.only_has_type(fcx)
370             .unwrap_or_else(|| fcx.next_ty_var(TypeVariableOrigin::MiscVariable(span)))
371     }
372 }
373
374 #[derive(Copy, Clone, Debug, PartialEq, Eq)]
375 pub enum Needs {
376     MutPlace,
377     None
378 }
379
380 impl Needs {
381     fn maybe_mut_place(m: hir::Mutability) -> Self {
382         match m {
383             hir::MutMutable => Needs::MutPlace,
384             hir::MutImmutable => Needs::None,
385         }
386     }
387 }
388
389 #[derive(Copy, Clone)]
390 pub struct UnsafetyState {
391     pub def: ast::NodeId,
392     pub unsafety: hir::Unsafety,
393     pub unsafe_push_count: u32,
394     from_fn: bool
395 }
396
397 impl UnsafetyState {
398     pub fn function(unsafety: hir::Unsafety, def: ast::NodeId) -> UnsafetyState {
399         UnsafetyState { def: def, unsafety: unsafety, unsafe_push_count: 0, from_fn: true }
400     }
401
402     pub fn recurse(&mut self, blk: &hir::Block) -> UnsafetyState {
403         match self.unsafety {
404             // If this unsafe, then if the outer function was already marked as
405             // unsafe we shouldn't attribute the unsafe'ness to the block. This
406             // way the block can be warned about instead of ignoring this
407             // extraneous block (functions are never warned about).
408             hir::Unsafety::Unsafe if self.from_fn => *self,
409
410             unsafety => {
411                 let (unsafety, def, count) = match blk.rules {
412                     hir::PushUnsafeBlock(..) =>
413                         (unsafety, blk.id, self.unsafe_push_count.checked_add(1).unwrap()),
414                     hir::PopUnsafeBlock(..) =>
415                         (unsafety, blk.id, self.unsafe_push_count.checked_sub(1).unwrap()),
416                     hir::UnsafeBlock(..) =>
417                         (hir::Unsafety::Unsafe, blk.id, self.unsafe_push_count),
418                     hir::DefaultBlock =>
419                         (unsafety, self.def, self.unsafe_push_count),
420                 };
421                 UnsafetyState{ def,
422                                unsafety,
423                                unsafe_push_count: count,
424                                from_fn: false }
425             }
426         }
427     }
428 }
429
430 #[derive(Debug, Copy, Clone)]
431 pub enum PlaceOp {
432     Deref,
433     Index
434 }
435
436 /// Tracks whether executing a node may exit normally (versus
437 /// return/break/panic, which "diverge", leaving dead code in their
438 /// wake). Tracked semi-automatically (through type variables marked
439 /// as diverging), with some manual adjustments for control-flow
440 /// primitives (approximating a CFG).
441 #[derive(Copy, Clone, Debug, PartialEq, Eq, PartialOrd, Ord)]
442 pub enum Diverges {
443     /// Potentially unknown, some cases converge,
444     /// others require a CFG to determine them.
445     Maybe,
446
447     /// Definitely known to diverge and therefore
448     /// not reach the next sibling or its parent.
449     Always,
450
451     /// Same as `Always` but with a reachability
452     /// warning already emitted
453     WarnedAlways
454 }
455
456 // Convenience impls for combinig `Diverges`.
457
458 impl ops::BitAnd for Diverges {
459     type Output = Self;
460     fn bitand(self, other: Self) -> Self {
461         cmp::min(self, other)
462     }
463 }
464
465 impl ops::BitOr for Diverges {
466     type Output = Self;
467     fn bitor(self, other: Self) -> Self {
468         cmp::max(self, other)
469     }
470 }
471
472 impl ops::BitAndAssign for Diverges {
473     fn bitand_assign(&mut self, other: Self) {
474         *self = *self & other;
475     }
476 }
477
478 impl ops::BitOrAssign for Diverges {
479     fn bitor_assign(&mut self, other: Self) {
480         *self = *self | other;
481     }
482 }
483
484 impl Diverges {
485     fn always(self) -> bool {
486         self >= Diverges::Always
487     }
488 }
489
490 pub struct BreakableCtxt<'gcx: 'tcx, 'tcx> {
491     may_break: bool,
492
493     // this is `null` for loops where break with a value is illegal,
494     // such as `while`, `for`, and `while let`
495     coerce: Option<DynamicCoerceMany<'gcx, 'tcx>>,
496 }
497
498 pub struct EnclosingBreakables<'gcx: 'tcx, 'tcx> {
499     stack: Vec<BreakableCtxt<'gcx, 'tcx>>,
500     by_id: NodeMap<usize>,
501 }
502
503 impl<'gcx, 'tcx> EnclosingBreakables<'gcx, 'tcx> {
504     fn find_breakable(&mut self, target_id: ast::NodeId) -> &mut BreakableCtxt<'gcx, 'tcx> {
505         let ix = *self.by_id.get(&target_id).unwrap_or_else(|| {
506             bug!("could not find enclosing breakable with id {}", target_id);
507         });
508         &mut self.stack[ix]
509     }
510 }
511
512 pub struct FnCtxt<'a, 'gcx: 'a+'tcx, 'tcx: 'a> {
513     body_id: ast::NodeId,
514
515     /// The parameter environment used for proving trait obligations
516     /// in this function. This can change when we descend into
517     /// closures (as they bring new things into scope), hence it is
518     /// not part of `Inherited` (as of the time of this writing,
519     /// closures do not yet change the environment, but they will
520     /// eventually).
521     param_env: ty::ParamEnv<'tcx>,
522
523     // Number of errors that had been reported when we started
524     // checking this function. On exit, if we find that *more* errors
525     // have been reported, we will skip regionck and other work that
526     // expects the types within the function to be consistent.
527     err_count_on_creation: usize,
528
529     ret_coercion: Option<RefCell<DynamicCoerceMany<'gcx, 'tcx>>>,
530     ret_coercion_span: RefCell<Option<Span>>,
531
532     yield_ty: Option<Ty<'tcx>>,
533
534     ps: RefCell<UnsafetyState>,
535
536     /// Whether the last checked node generates a divergence (e.g.,
537     /// `return` will set this to Always). In general, when entering
538     /// an expression or other node in the tree, the initial value
539     /// indicates whether prior parts of the containing expression may
540     /// have diverged. It is then typically set to `Maybe` (and the
541     /// old value remembered) for processing the subparts of the
542     /// current expression. As each subpart is processed, they may set
543     /// the flag to `Always` etc.  Finally, at the end, we take the
544     /// result and "union" it with the original value, so that when we
545     /// return the flag indicates if any subpart of the parent
546     /// expression (up to and including this part) has diverged.  So,
547     /// if you read it after evaluating a subexpression `X`, the value
548     /// you get indicates whether any subexpression that was
549     /// evaluating up to and including `X` diverged.
550     ///
551     /// We currently use this flag only for diagnostic purposes:
552     ///
553     /// - To warn about unreachable code: if, after processing a
554     ///   sub-expression but before we have applied the effects of the
555     ///   current node, we see that the flag is set to `Always`, we
556     ///   can issue a warning. This corresponds to something like
557     ///   `foo(return)`; we warn on the `foo()` expression. (We then
558     ///   update the flag to `WarnedAlways` to suppress duplicate
559     ///   reports.) Similarly, if we traverse to a fresh statement (or
560     ///   tail expression) from a `Always` setting, we will issue a
561     ///   warning. This corresponds to something like `{return;
562     ///   foo();}` or `{return; 22}`, where we would warn on the
563     ///   `foo()` or `22`.
564     ///
565     /// An expression represents dead-code if, after checking it,
566     /// the diverges flag is set to something other than `Maybe`.
567     diverges: Cell<Diverges>,
568
569     /// Whether any child nodes have any type errors.
570     has_errors: Cell<bool>,
571
572     enclosing_breakables: RefCell<EnclosingBreakables<'gcx, 'tcx>>,
573
574     inh: &'a Inherited<'a, 'gcx, 'tcx>,
575 }
576
577 impl<'a, 'gcx, 'tcx> Deref for FnCtxt<'a, 'gcx, 'tcx> {
578     type Target = Inherited<'a, 'gcx, 'tcx>;
579     fn deref(&self) -> &Self::Target {
580         &self.inh
581     }
582 }
583
584 /// Helper type of a temporary returned by Inherited::build(...).
585 /// Necessary because we can't write the following bound:
586 /// F: for<'b, 'tcx> where 'gcx: 'tcx FnOnce(Inherited<'b, 'gcx, 'tcx>).
587 pub struct InheritedBuilder<'a, 'gcx: 'a+'tcx, 'tcx: 'a> {
588     infcx: infer::InferCtxtBuilder<'a, 'gcx, 'tcx>,
589     def_id: DefId,
590 }
591
592 impl<'a, 'gcx, 'tcx> Inherited<'a, 'gcx, 'tcx> {
593     pub fn build(tcx: TyCtxt<'a, 'gcx, 'gcx>, def_id: DefId)
594                  -> InheritedBuilder<'a, 'gcx, 'tcx> {
595         let hir_id_root = if def_id.is_local() {
596             let node_id = tcx.hir().as_local_node_id(def_id).unwrap();
597             let hir_id = tcx.hir().definitions().node_to_hir_id(node_id);
598             DefId::local(hir_id.owner)
599         } else {
600             def_id
601         };
602
603         InheritedBuilder {
604             infcx: tcx.infer_ctxt().with_fresh_in_progress_tables(hir_id_root),
605             def_id,
606         }
607     }
608 }
609
610 impl<'a, 'gcx, 'tcx> InheritedBuilder<'a, 'gcx, 'tcx> {
611     fn enter<F, R>(&'tcx mut self, f: F) -> R
612         where F: for<'b> FnOnce(Inherited<'b, 'gcx, 'tcx>) -> R
613     {
614         let def_id = self.def_id;
615         self.infcx.enter(|infcx| f(Inherited::new(infcx, def_id)))
616     }
617 }
618
619 impl<'a, 'gcx, 'tcx> Inherited<'a, 'gcx, 'tcx> {
620     fn new(infcx: InferCtxt<'a, 'gcx, 'tcx>, def_id: DefId) -> Self {
621         let tcx = infcx.tcx;
622         let item_id = tcx.hir().as_local_node_id(def_id);
623         let body_id = item_id.and_then(|id| tcx.hir().maybe_body_owned_by(id));
624         let implicit_region_bound = body_id.map(|body_id| {
625             let body = tcx.hir().body(body_id);
626             tcx.mk_region(ty::ReScope(region::Scope {
627                 id: body.value.hir_id.local_id,
628                 data: region::ScopeData::CallSite
629             }))
630         });
631
632         Inherited {
633             tables: MaybeInProgressTables {
634                 maybe_tables: infcx.in_progress_tables,
635             },
636             infcx,
637             fulfillment_cx: RefCell::new(TraitEngine::new(tcx)),
638             locals: RefCell::new(Default::default()),
639             deferred_sized_obligations: RefCell::new(Vec::new()),
640             deferred_call_resolutions: RefCell::new(Default::default()),
641             deferred_cast_checks: RefCell::new(Vec::new()),
642             deferred_generator_interiors: RefCell::new(Vec::new()),
643             opaque_types: RefCell::new(Default::default()),
644             implicit_region_bound,
645             body_id,
646         }
647     }
648
649     fn register_predicate(&self, obligation: traits::PredicateObligation<'tcx>) {
650         debug!("register_predicate({:?})", obligation);
651         if obligation.has_escaping_bound_vars() {
652             span_bug!(obligation.cause.span, "escaping bound vars in predicate {:?}",
653                       obligation);
654         }
655         self.fulfillment_cx
656             .borrow_mut()
657             .register_predicate_obligation(self, obligation);
658     }
659
660     fn register_predicates<I>(&self, obligations: I)
661         where I: IntoIterator<Item = traits::PredicateObligation<'tcx>>
662     {
663         for obligation in obligations {
664             self.register_predicate(obligation);
665         }
666     }
667
668     fn register_infer_ok_obligations<T>(&self, infer_ok: InferOk<'tcx, T>) -> T {
669         self.register_predicates(infer_ok.obligations);
670         infer_ok.value
671     }
672
673     fn normalize_associated_types_in<T>(&self,
674                                         span: Span,
675                                         body_id: ast::NodeId,
676                                         param_env: ty::ParamEnv<'tcx>,
677                                         value: &T) -> T
678         where T : TypeFoldable<'tcx>
679     {
680         let ok = self.partially_normalize_associated_types_in(span, body_id, param_env, value);
681         self.register_infer_ok_obligations(ok)
682     }
683 }
684
685 struct CheckItemTypesVisitor<'a, 'tcx: 'a> { tcx: TyCtxt<'a, 'tcx, 'tcx> }
686
687 impl<'a, 'tcx> ItemLikeVisitor<'tcx> for CheckItemTypesVisitor<'a, 'tcx> {
688     fn visit_item(&mut self, i: &'tcx hir::Item) {
689         check_item_type(self.tcx, i);
690     }
691     fn visit_trait_item(&mut self, _: &'tcx hir::TraitItem) { }
692     fn visit_impl_item(&mut self, _: &'tcx hir::ImplItem) { }
693 }
694
695 pub fn check_wf_new<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>) -> Result<(), ErrorReported> {
696     tcx.sess.track_errors(|| {
697         let mut visit = wfcheck::CheckTypeWellFormedVisitor::new(tcx);
698         tcx.hir().krate().visit_all_item_likes(&mut visit);
699     })
700 }
701
702 pub fn check_item_types<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>) -> Result<(), ErrorReported> {
703     tcx.sess.track_errors(|| {
704         for &module in tcx.hir().krate().modules.keys() {
705             tcx.ensure().check_mod_item_types(tcx.hir().local_def_id(module));
706         }
707     })
708 }
709
710 fn check_mod_item_types<'tcx>(tcx: TyCtxt<'_, 'tcx, 'tcx>, module_def_id: DefId) {
711     tcx.hir().visit_item_likes_in_module(module_def_id, &mut CheckItemTypesVisitor { tcx });
712 }
713
714 pub fn check_item_bodies<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>) -> Result<(), CompileIncomplete> {
715     tcx.typeck_item_bodies(LOCAL_CRATE)
716 }
717
718 fn typeck_item_bodies<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, crate_num: CrateNum)
719                                 -> Result<(), CompileIncomplete>
720 {
721     debug_assert!(crate_num == LOCAL_CRATE);
722     Ok(tcx.sess.track_errors(|| {
723         tcx.par_body_owners(|body_owner_def_id| {
724             tcx.ensure().typeck_tables_of(body_owner_def_id);
725         });
726     })?)
727 }
728
729 fn check_item_well_formed<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, def_id: DefId) {
730     wfcheck::check_item_well_formed(tcx, def_id);
731 }
732
733 fn check_trait_item_well_formed<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, def_id: DefId) {
734     wfcheck::check_trait_item(tcx, def_id);
735 }
736
737 fn check_impl_item_well_formed<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, def_id: DefId) {
738     wfcheck::check_impl_item(tcx, def_id);
739 }
740
741 pub fn provide(providers: &mut Providers) {
742     method::provide(providers);
743     *providers = Providers {
744         typeck_item_bodies,
745         typeck_tables_of,
746         has_typeck_tables,
747         adt_destructor,
748         used_trait_imports,
749         check_item_well_formed,
750         check_trait_item_well_formed,
751         check_impl_item_well_formed,
752         check_mod_item_types,
753         ..*providers
754     };
755 }
756
757 fn adt_destructor<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
758                             def_id: DefId)
759                             -> Option<ty::Destructor> {
760     tcx.calculate_dtor(def_id, &mut dropck::check_drop_impl)
761 }
762
763 /// If this def-id is a "primary tables entry", returns `Some((body_id, decl))`
764 /// with information about it's body-id and fn-decl (if any). Otherwise,
765 /// returns `None`.
766 ///
767 /// If this function returns "some", then `typeck_tables(def_id)` will
768 /// succeed; if it returns `None`, then `typeck_tables(def_id)` may or
769 /// may not succeed.  In some cases where this function returns `None`
770 /// (notably closures), `typeck_tables(def_id)` would wind up
771 /// redirecting to the owning function.
772 fn primary_body_of<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
773                              id: ast::NodeId)
774                              -> Option<(hir::BodyId, Option<&'tcx hir::FnDecl>)>
775 {
776     match tcx.hir().get(id) {
777         Node::Item(item) => {
778             match item.node {
779                 hir::ItemKind::Const(_, body) |
780                 hir::ItemKind::Static(_, _, body) =>
781                     Some((body, None)),
782                 hir::ItemKind::Fn(ref decl, .., body) =>
783                     Some((body, Some(decl))),
784                 _ =>
785                     None,
786             }
787         }
788         Node::TraitItem(item) => {
789             match item.node {
790                 hir::TraitItemKind::Const(_, Some(body)) =>
791                     Some((body, None)),
792                 hir::TraitItemKind::Method(ref sig, hir::TraitMethod::Provided(body)) =>
793                     Some((body, Some(&sig.decl))),
794                 _ =>
795                     None,
796             }
797         }
798         Node::ImplItem(item) => {
799             match item.node {
800                 hir::ImplItemKind::Const(_, body) =>
801                     Some((body, None)),
802                 hir::ImplItemKind::Method(ref sig, body) =>
803                     Some((body, Some(&sig.decl))),
804                 _ =>
805                     None,
806             }
807         }
808         Node::AnonConst(constant) => Some((constant.body, None)),
809         _ => None,
810     }
811 }
812
813 fn has_typeck_tables<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
814                                def_id: DefId)
815                                -> bool {
816     // Closures' tables come from their outermost function,
817     // as they are part of the same "inference environment".
818     let outer_def_id = tcx.closure_base_def_id(def_id);
819     if outer_def_id != def_id {
820         return tcx.has_typeck_tables(outer_def_id);
821     }
822
823     let id = tcx.hir().as_local_node_id(def_id).unwrap();
824     primary_body_of(tcx, id).is_some()
825 }
826
827 fn used_trait_imports<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
828                                 def_id: DefId)
829                                 -> Lrc<DefIdSet> {
830     tcx.typeck_tables_of(def_id).used_trait_imports.clone()
831 }
832
833 fn typeck_tables_of<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
834                               def_id: DefId)
835                               -> &'tcx ty::TypeckTables<'tcx> {
836     // Closures' tables come from their outermost function,
837     // as they are part of the same "inference environment".
838     let outer_def_id = tcx.closure_base_def_id(def_id);
839     if outer_def_id != def_id {
840         return tcx.typeck_tables_of(outer_def_id);
841     }
842
843     let id = tcx.hir().as_local_node_id(def_id).unwrap();
844     let span = tcx.hir().span(id);
845
846     // Figure out what primary body this item has.
847     let (body_id, fn_decl) = primary_body_of(tcx, id).unwrap_or_else(|| {
848         span_bug!(span, "can't type-check body of {:?}", def_id);
849     });
850     let body = tcx.hir().body(body_id);
851
852     let tables = Inherited::build(tcx, def_id).enter(|inh| {
853         let param_env = tcx.param_env(def_id);
854         let fcx = if let Some(decl) = fn_decl {
855             let fn_sig = tcx.fn_sig(def_id);
856
857             check_abi(tcx, span, fn_sig.abi());
858
859             // Compute the fty from point of view of inside the fn.
860             let fn_sig =
861                 tcx.liberate_late_bound_regions(def_id, &fn_sig);
862             let fn_sig =
863                 inh.normalize_associated_types_in(body.value.span,
864                                                   body_id.node_id,
865                                                   param_env,
866                                                   &fn_sig);
867
868             let fcx = check_fn(&inh, param_env, fn_sig, decl, id, body, None).0;
869             fcx
870         } else {
871             let fcx = FnCtxt::new(&inh, param_env, body.value.id);
872             let expected_type = tcx.type_of(def_id);
873             let expected_type = fcx.normalize_associated_types_in(body.value.span, &expected_type);
874             fcx.require_type_is_sized(expected_type, body.value.span, traits::ConstSized);
875
876             let revealed_ty = if tcx.features().impl_trait_in_bindings {
877                 fcx.instantiate_opaque_types_from_value(
878                     id,
879                     &expected_type
880                 )
881             } else {
882                 expected_type
883             };
884
885             // Gather locals in statics (because of block expressions).
886             GatherLocalsVisitor { fcx: &fcx, parent_id: id, }.visit_body(body);
887
888             fcx.check_expr_coercable_to_type(&body.value, revealed_ty);
889
890             fcx
891         };
892
893         // All type checking constraints were added, try to fallback unsolved variables.
894         fcx.select_obligations_where_possible(false);
895         let mut fallback_has_occurred = false;
896         for ty in &fcx.unsolved_variables() {
897             fallback_has_occurred |= fcx.fallback_if_possible(ty);
898         }
899         fcx.select_obligations_where_possible(fallback_has_occurred);
900
901         // Even though coercion casts provide type hints, we check casts after fallback for
902         // backwards compatibility. This makes fallback a stronger type hint than a cast coercion.
903         fcx.check_casts();
904
905         // Closure and generator analysis may run after fallback
906         // because they don't constrain other type variables.
907         fcx.closure_analyze(body);
908         assert!(fcx.deferred_call_resolutions.borrow().is_empty());
909         fcx.resolve_generator_interiors(def_id);
910
911         for (ty, span, code) in fcx.deferred_sized_obligations.borrow_mut().drain(..) {
912             let ty = fcx.normalize_ty(span, ty);
913             fcx.require_type_is_sized(ty, span, code);
914         }
915         fcx.select_all_obligations_or_error();
916
917         if fn_decl.is_some() {
918             fcx.regionck_fn(id, body);
919         } else {
920             fcx.regionck_expr(body);
921         }
922
923         fcx.resolve_type_vars_in_body(body)
924     });
925
926     // Consistency check our TypeckTables instance can hold all ItemLocalIds
927     // it will need to hold.
928     assert_eq!(tables.local_id_root,
929                Some(DefId::local(tcx.hir().definitions().node_to_hir_id(id).owner)));
930     tables
931 }
932
933 fn check_abi<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, span: Span, abi: Abi) {
934     if !tcx.sess.target.target.is_abi_supported(abi) {
935         struct_span_err!(tcx.sess, span, E0570,
936             "The ABI `{}` is not supported for the current target", abi).emit()
937     }
938 }
939
940 struct GatherLocalsVisitor<'a, 'gcx: 'a+'tcx, 'tcx: 'a> {
941     fcx: &'a FnCtxt<'a, 'gcx, 'tcx>,
942     parent_id: ast::NodeId,
943 }
944
945 impl<'a, 'gcx, 'tcx> GatherLocalsVisitor<'a, 'gcx, 'tcx> {
946     fn assign(&mut self, span: Span, nid: ast::NodeId, ty_opt: Option<LocalTy<'tcx>>) -> Ty<'tcx> {
947         match ty_opt {
948             None => {
949                 // infer the variable's type
950                 let var_ty = self.fcx.next_ty_var(TypeVariableOrigin::TypeInference(span));
951                 self.fcx.locals.borrow_mut().insert(nid, LocalTy {
952                     decl_ty: var_ty,
953                     revealed_ty: var_ty
954                 });
955                 var_ty
956             }
957             Some(typ) => {
958                 // take type that the user specified
959                 self.fcx.locals.borrow_mut().insert(nid, typ);
960                 typ.revealed_ty
961             }
962         }
963     }
964 }
965
966 impl<'a, 'gcx, 'tcx> Visitor<'gcx> for GatherLocalsVisitor<'a, 'gcx, 'tcx> {
967     fn nested_visit_map<'this>(&'this mut self) -> NestedVisitorMap<'this, 'gcx> {
968         NestedVisitorMap::None
969     }
970
971     // Add explicitly-declared locals.
972     fn visit_local(&mut self, local: &'gcx hir::Local) {
973         let local_ty = match local.ty {
974             Some(ref ty) => {
975                 let o_ty = self.fcx.to_ty(&ty);
976
977                 let revealed_ty = if self.fcx.tcx.features().impl_trait_in_bindings {
978                     self.fcx.instantiate_opaque_types_from_value(
979                         self.parent_id,
980                         &o_ty
981                     )
982                 } else {
983                     o_ty
984                 };
985
986                 let c_ty = self.fcx.inh.infcx.canonicalize_user_type_annotation(
987                     &UserType::Ty(revealed_ty)
988                 );
989                 debug!("visit_local: ty.hir_id={:?} o_ty={:?} revealed_ty={:?} c_ty={:?}",
990                        ty.hir_id, o_ty, revealed_ty, c_ty);
991                 self.fcx.tables.borrow_mut().user_provided_types_mut().insert(ty.hir_id, c_ty);
992
993                 Some(LocalTy { decl_ty: o_ty, revealed_ty })
994             },
995             None => None,
996         };
997         self.assign(local.span, local.id, local_ty);
998
999         debug!("Local variable {:?} is assigned type {}",
1000                local.pat,
1001                self.fcx.ty_to_string(
1002                    self.fcx.locals.borrow().get(&local.id).unwrap().clone().decl_ty));
1003         intravisit::walk_local(self, local);
1004     }
1005
1006     // Add pattern bindings.
1007     fn visit_pat(&mut self, p: &'gcx hir::Pat) {
1008         if let PatKind::Binding(_, _, ident, _) = p.node {
1009             let var_ty = self.assign(p.span, p.id, None);
1010
1011             if !self.fcx.tcx.features().unsized_locals {
1012                 self.fcx.require_type_is_sized(var_ty, p.span,
1013                                                traits::VariableType(p.id));
1014             }
1015
1016             debug!("Pattern binding {} is assigned to {} with type {:?}",
1017                    ident,
1018                    self.fcx.ty_to_string(
1019                        self.fcx.locals.borrow().get(&p.id).unwrap().clone().decl_ty),
1020                    var_ty);
1021         }
1022         intravisit::walk_pat(self, p);
1023     }
1024
1025     // Don't descend into the bodies of nested closures
1026     fn visit_fn(&mut self, _: intravisit::FnKind<'gcx>, _: &'gcx hir::FnDecl,
1027                 _: hir::BodyId, _: Span, _: ast::NodeId) { }
1028 }
1029
1030 /// When `check_fn` is invoked on a generator (i.e., a body that
1031 /// includes yield), it returns back some information about the yield
1032 /// points.
1033 struct GeneratorTypes<'tcx> {
1034     /// Type of value that is yielded.
1035     yield_ty: ty::Ty<'tcx>,
1036
1037     /// Types that are captured (see `GeneratorInterior` for more).
1038     interior: ty::Ty<'tcx>,
1039
1040     /// Indicates if the generator is movable or static (immovable)
1041     movability: hir::GeneratorMovability,
1042 }
1043
1044 /// Helper used for fns and closures. Does the grungy work of checking a function
1045 /// body and returns the function context used for that purpose, since in the case of a fn item
1046 /// there is still a bit more to do.
1047 ///
1048 /// * ...
1049 /// * inherited: other fields inherited from the enclosing fn (if any)
1050 fn check_fn<'a, 'gcx, 'tcx>(inherited: &'a Inherited<'a, 'gcx, 'tcx>,
1051                             param_env: ty::ParamEnv<'tcx>,
1052                             fn_sig: ty::FnSig<'tcx>,
1053                             decl: &'gcx hir::FnDecl,
1054                             fn_id: ast::NodeId,
1055                             body: &'gcx hir::Body,
1056                             can_be_generator: Option<hir::GeneratorMovability>)
1057                             -> (FnCtxt<'a, 'gcx, 'tcx>, Option<GeneratorTypes<'tcx>>)
1058 {
1059     let mut fn_sig = fn_sig.clone();
1060
1061     debug!("check_fn(sig={:?}, fn_id={}, param_env={:?})", fn_sig, fn_id, param_env);
1062
1063     // Create the function context.  This is either derived from scratch or,
1064     // in the case of closures, based on the outer context.
1065     let mut fcx = FnCtxt::new(inherited, param_env, body.value.id);
1066     *fcx.ps.borrow_mut() = UnsafetyState::function(fn_sig.unsafety, fn_id);
1067
1068     let declared_ret_ty = fn_sig.output();
1069     fcx.require_type_is_sized(declared_ret_ty, decl.output.span(), traits::SizedReturnType);
1070     let revealed_ret_ty = fcx.instantiate_opaque_types_from_value(fn_id, &declared_ret_ty);
1071     fcx.ret_coercion = Some(RefCell::new(CoerceMany::new(revealed_ret_ty)));
1072     fn_sig = fcx.tcx.mk_fn_sig(
1073         fn_sig.inputs().iter().cloned(),
1074         revealed_ret_ty,
1075         fn_sig.variadic,
1076         fn_sig.unsafety,
1077         fn_sig.abi
1078     );
1079
1080     let span = body.value.span;
1081
1082     if body.is_generator && can_be_generator.is_some() {
1083         let yield_ty = fcx.next_ty_var(TypeVariableOrigin::TypeInference(span));
1084         fcx.require_type_is_sized(yield_ty, span, traits::SizedYieldType);
1085         fcx.yield_ty = Some(yield_ty);
1086     }
1087
1088     let outer_def_id = fcx.tcx.closure_base_def_id(fcx.tcx.hir().local_def_id(fn_id));
1089     let outer_node_id = fcx.tcx.hir().as_local_node_id(outer_def_id).unwrap();
1090     GatherLocalsVisitor { fcx: &fcx, parent_id: outer_node_id, }.visit_body(body);
1091
1092     // Add formal parameters.
1093     for (arg_ty, arg) in fn_sig.inputs().iter().zip(&body.arguments) {
1094         // Check the pattern.
1095         fcx.check_pat_walk(
1096             &arg.pat,
1097             arg_ty,
1098             ty::BindingMode::BindByValue(hir::Mutability::MutImmutable),
1099             None,
1100         );
1101
1102         // Check that argument is Sized.
1103         // The check for a non-trivial pattern is a hack to avoid duplicate warnings
1104         // for simple cases like `fn foo(x: Trait)`,
1105         // where we would error once on the parameter as a whole, and once on the binding `x`.
1106         if arg.pat.simple_ident().is_none() && !fcx.tcx.features().unsized_locals {
1107             fcx.require_type_is_sized(arg_ty, decl.output.span(), traits::SizedArgumentType);
1108         }
1109
1110         fcx.write_ty(arg.hir_id, arg_ty);
1111     }
1112
1113     let fn_hir_id = fcx.tcx.hir().node_to_hir_id(fn_id);
1114     inherited.tables.borrow_mut().liberated_fn_sigs_mut().insert(fn_hir_id, fn_sig);
1115
1116     fcx.check_return_expr(&body.value);
1117
1118     // We insert the deferred_generator_interiors entry after visiting the body.
1119     // This ensures that all nested generators appear before the entry of this generator.
1120     // resolve_generator_interiors relies on this property.
1121     let gen_ty = if can_be_generator.is_some() && body.is_generator {
1122         let interior = fcx.next_ty_var(TypeVariableOrigin::MiscVariable(span));
1123         fcx.deferred_generator_interiors.borrow_mut().push((body.id(), interior));
1124         Some(GeneratorTypes {
1125             yield_ty: fcx.yield_ty.unwrap(),
1126             interior,
1127             movability: can_be_generator.unwrap(),
1128         })
1129     } else {
1130         None
1131     };
1132
1133     // Finalize the return check by taking the LUB of the return types
1134     // we saw and assigning it to the expected return type. This isn't
1135     // really expected to fail, since the coercions would have failed
1136     // earlier when trying to find a LUB.
1137     //
1138     // However, the behavior around `!` is sort of complex. In the
1139     // event that the `actual_return_ty` comes back as `!`, that
1140     // indicates that the fn either does not return or "returns" only
1141     // values of type `!`. In this case, if there is an expected
1142     // return type that is *not* `!`, that should be ok. But if the
1143     // return type is being inferred, we want to "fallback" to `!`:
1144     //
1145     //     let x = move || panic!();
1146     //
1147     // To allow for that, I am creating a type variable with diverging
1148     // fallback. This was deemed ever so slightly better than unifying
1149     // the return value with `!` because it allows for the caller to
1150     // make more assumptions about the return type (e.g., they could do
1151     //
1152     //     let y: Option<u32> = Some(x());
1153     //
1154     // which would then cause this return type to become `u32`, not
1155     // `!`).
1156     let coercion = fcx.ret_coercion.take().unwrap().into_inner();
1157     let mut actual_return_ty = coercion.complete(&fcx);
1158     if actual_return_ty.is_never() {
1159         actual_return_ty = fcx.next_diverging_ty_var(
1160             TypeVariableOrigin::DivergingFn(span));
1161     }
1162     fcx.demand_suptype(span, revealed_ret_ty, actual_return_ty);
1163
1164     // Check that the main return type implements the termination trait.
1165     if let Some(term_id) = fcx.tcx.lang_items().termination() {
1166         if let Some((def_id, EntryFnType::Main)) = fcx.tcx.entry_fn(LOCAL_CRATE) {
1167             let main_id = fcx.tcx.hir().as_local_node_id(def_id).unwrap();
1168             if main_id == fn_id {
1169                 let substs = fcx.tcx.mk_substs_trait(declared_ret_ty, &[]);
1170                 let trait_ref = ty::TraitRef::new(term_id, substs);
1171                 let return_ty_span = decl.output.span();
1172                 let cause = traits::ObligationCause::new(
1173                     return_ty_span, fn_id, ObligationCauseCode::MainFunctionType);
1174
1175                 inherited.register_predicate(
1176                     traits::Obligation::new(
1177                         cause, param_env, trait_ref.to_predicate()));
1178             }
1179         }
1180     }
1181
1182     // Check that a function marked as `#[panic_handler]` has signature `fn(&PanicInfo) -> !`
1183     if let Some(panic_impl_did) = fcx.tcx.lang_items().panic_impl() {
1184         if panic_impl_did == fcx.tcx.hir().local_def_id(fn_id) {
1185             if let Some(panic_info_did) = fcx.tcx.lang_items().panic_info() {
1186                 // at this point we don't care if there are duplicate handlers or if the handler has
1187                 // the wrong signature as this value we'll be used when writing metadata and that
1188                 // only happens if compilation succeeded
1189                 fcx.tcx.sess.has_panic_handler.try_set_same(true);
1190
1191                 if declared_ret_ty.sty != ty::Never {
1192                     fcx.tcx.sess.span_err(
1193                         decl.output.span(),
1194                         "return type should be `!`",
1195                     );
1196                 }
1197
1198                 let inputs = fn_sig.inputs();
1199                 let span = fcx.tcx.hir().span(fn_id);
1200                 if inputs.len() == 1 {
1201                     let arg_is_panic_info = match inputs[0].sty {
1202                         ty::Ref(region, ty, mutbl) => match ty.sty {
1203                             ty::Adt(ref adt, _) => {
1204                                 adt.did == panic_info_did &&
1205                                     mutbl == hir::Mutability::MutImmutable &&
1206                                     *region != RegionKind::ReStatic
1207                             },
1208                             _ => false,
1209                         },
1210                         _ => false,
1211                     };
1212
1213                     if !arg_is_panic_info {
1214                         fcx.tcx.sess.span_err(
1215                             decl.inputs[0].span,
1216                             "argument should be `&PanicInfo`",
1217                         );
1218                     }
1219
1220                     if let Node::Item(item) = fcx.tcx.hir().get(fn_id) {
1221                         if let ItemKind::Fn(_, _, ref generics, _) = item.node {
1222                             if !generics.params.is_empty() {
1223                                 fcx.tcx.sess.span_err(
1224                                     span,
1225                                     "should have no type parameters",
1226                                 );
1227                             }
1228                         }
1229                     }
1230                 } else {
1231                     let span = fcx.tcx.sess.source_map().def_span(span);
1232                     fcx.tcx.sess.span_err(span, "function should have one argument");
1233                 }
1234             } else {
1235                 fcx.tcx.sess.err("language item required, but not found: `panic_info`");
1236             }
1237         }
1238     }
1239
1240     // Check that a function marked as `#[alloc_error_handler]` has signature `fn(Layout) -> !`
1241     if let Some(alloc_error_handler_did) = fcx.tcx.lang_items().oom() {
1242         if alloc_error_handler_did == fcx.tcx.hir().local_def_id(fn_id) {
1243             if let Some(alloc_layout_did) = fcx.tcx.lang_items().alloc_layout() {
1244                 if declared_ret_ty.sty != ty::Never {
1245                     fcx.tcx.sess.span_err(
1246                         decl.output.span(),
1247                         "return type should be `!`",
1248                     );
1249                 }
1250
1251                 let inputs = fn_sig.inputs();
1252                 let span = fcx.tcx.hir().span(fn_id);
1253                 if inputs.len() == 1 {
1254                     let arg_is_alloc_layout = match inputs[0].sty {
1255                         ty::Adt(ref adt, _) => {
1256                             adt.did == alloc_layout_did
1257                         },
1258                         _ => false,
1259                     };
1260
1261                     if !arg_is_alloc_layout {
1262                         fcx.tcx.sess.span_err(
1263                             decl.inputs[0].span,
1264                             "argument should be `Layout`",
1265                         );
1266                     }
1267
1268                     if let Node::Item(item) = fcx.tcx.hir().get(fn_id) {
1269                         if let ItemKind::Fn(_, _, ref generics, _) = item.node {
1270                             if !generics.params.is_empty() {
1271                                 fcx.tcx.sess.span_err(
1272                                     span,
1273                                     "`#[alloc_error_handler]` function should have no type \
1274                                      parameters",
1275                                 );
1276                             }
1277                         }
1278                     }
1279                 } else {
1280                     let span = fcx.tcx.sess.source_map().def_span(span);
1281                     fcx.tcx.sess.span_err(span, "function should have one argument");
1282                 }
1283             } else {
1284                 fcx.tcx.sess.err("language item required, but not found: `alloc_layout`");
1285             }
1286         }
1287     }
1288
1289     (fcx, gen_ty)
1290 }
1291
1292 fn check_struct<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1293                           id: ast::NodeId,
1294                           span: Span) {
1295     let def_id = tcx.hir().local_def_id(id);
1296     let def = tcx.adt_def(def_id);
1297     def.destructor(tcx); // force the destructor to be evaluated
1298     check_representable(tcx, span, def_id);
1299
1300     if def.repr.simd() {
1301         check_simd(tcx, span, def_id);
1302     }
1303
1304     check_transparent(tcx, span, def_id);
1305     check_packed(tcx, span, def_id);
1306 }
1307
1308 fn check_union<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1309                          id: ast::NodeId,
1310                          span: Span) {
1311     let def_id = tcx.hir().local_def_id(id);
1312     let def = tcx.adt_def(def_id);
1313     def.destructor(tcx); // force the destructor to be evaluated
1314     check_representable(tcx, span, def_id);
1315
1316     check_packed(tcx, span, def_id);
1317 }
1318
1319 fn check_opaque<'a, 'tcx>(
1320     tcx: TyCtxt<'a, 'tcx, 'tcx>,
1321     def_id: DefId,
1322     substs: &'tcx Substs<'tcx>,
1323     span: Span,
1324 ) {
1325     if let Err(partially_expanded_type) = tcx.try_expand_impl_trait_type(def_id, substs) {
1326         let mut err = struct_span_err!(
1327             tcx.sess, span, E0720,
1328             "opaque type expands to a recursive type",
1329         );
1330         err.span_label(span, "expands to self-referential type");
1331         if let ty::Opaque(..) = partially_expanded_type.sty {
1332             err.note("type resolves to itself");
1333         } else {
1334             err.note(&format!("expanded type is `{}`", partially_expanded_type));
1335         }
1336         err.emit();
1337     }
1338 }
1339
1340 pub fn check_item_type<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, it: &'tcx hir::Item) {
1341     debug!(
1342         "check_item_type(it.id={}, it.name={})",
1343         it.id,
1344         tcx.item_path_str(tcx.hir().local_def_id(it.id))
1345     );
1346     let _indenter = indenter();
1347     match it.node {
1348         // Consts can play a role in type-checking, so they are included here.
1349         hir::ItemKind::Static(..) => {
1350             let def_id = tcx.hir().local_def_id(it.id);
1351             tcx.typeck_tables_of(def_id);
1352             maybe_check_static_with_link_section(tcx, def_id, it.span);
1353         }
1354         hir::ItemKind::Const(..) => {
1355             tcx.typeck_tables_of(tcx.hir().local_def_id(it.id));
1356         }
1357         hir::ItemKind::Enum(ref enum_definition, _) => {
1358             check_enum(tcx, it.span, &enum_definition.variants, it.id);
1359         }
1360         hir::ItemKind::Fn(..) => {} // entirely within check_item_body
1361         hir::ItemKind::Impl(.., ref impl_item_refs) => {
1362             debug!("ItemKind::Impl {} with id {}", it.ident, it.id);
1363             let impl_def_id = tcx.hir().local_def_id(it.id);
1364             if let Some(impl_trait_ref) = tcx.impl_trait_ref(impl_def_id) {
1365                 check_impl_items_against_trait(
1366                     tcx,
1367                     it.span,
1368                     impl_def_id,
1369                     impl_trait_ref,
1370                     impl_item_refs,
1371                 );
1372                 let trait_def_id = impl_trait_ref.def_id;
1373                 check_on_unimplemented(tcx, trait_def_id, it);
1374             }
1375         }
1376         hir::ItemKind::Trait(..) => {
1377             let def_id = tcx.hir().local_def_id(it.id);
1378             check_on_unimplemented(tcx, def_id, it);
1379         }
1380         hir::ItemKind::Struct(..) => {
1381             check_struct(tcx, it.id, it.span);
1382         }
1383         hir::ItemKind::Union(..) => {
1384             check_union(tcx, it.id, it.span);
1385         }
1386         hir::ItemKind::Existential(..) => {
1387             let def_id = tcx.hir().local_def_id(it.id);
1388             let pty_ty = tcx.type_of(def_id);
1389             let generics = tcx.generics_of(def_id);
1390
1391             check_bounds_are_used(tcx, &generics, pty_ty);
1392             let substs = Substs::identity_for_item(tcx, def_id);
1393             check_opaque(tcx, def_id, substs, it.span);
1394         }
1395         hir::ItemKind::Ty(..) => {
1396             let def_id = tcx.hir().local_def_id(it.id);
1397             let pty_ty = tcx.type_of(def_id);
1398             let generics = tcx.generics_of(def_id);
1399             check_bounds_are_used(tcx, &generics, pty_ty);
1400         }
1401         hir::ItemKind::ForeignMod(ref m) => {
1402             check_abi(tcx, it.span, m.abi);
1403
1404             if m.abi == Abi::RustIntrinsic {
1405                 for item in &m.items {
1406                     intrinsic::check_intrinsic_type(tcx, item);
1407                 }
1408             } else if m.abi == Abi::PlatformIntrinsic {
1409                 for item in &m.items {
1410                     intrinsic::check_platform_intrinsic_type(tcx, item);
1411                 }
1412             } else {
1413                 for item in &m.items {
1414                     let generics = tcx.generics_of(tcx.hir().local_def_id(item.id));
1415                     if generics.params.len() - generics.own_counts().lifetimes != 0 {
1416                         let mut err = struct_span_err!(
1417                             tcx.sess,
1418                             item.span,
1419                             E0044,
1420                             "foreign items may not have type parameters"
1421                         );
1422                         err.span_label(item.span, "can't have type parameters");
1423                         // FIXME: once we start storing spans for type arguments, turn this into a
1424                         // suggestion.
1425                         err.help(
1426                             "use specialization instead of type parameters by replacing them \
1427                              with concrete types like `u32`",
1428                         );
1429                         err.emit();
1430                     }
1431
1432                     if let hir::ForeignItemKind::Fn(ref fn_decl, _, _) = item.node {
1433                         require_c_abi_if_variadic(tcx, fn_decl, m.abi, item.span);
1434                     }
1435                 }
1436             }
1437         }
1438         _ => { /* nothing to do */ }
1439     }
1440 }
1441
1442 fn maybe_check_static_with_link_section(tcx: TyCtxt, id: DefId, span: Span) {
1443     // Only restricted on wasm32 target for now
1444     if !tcx.sess.opts.target_triple.triple().starts_with("wasm32") {
1445         return
1446     }
1447
1448     // If `#[link_section]` is missing, then nothing to verify
1449     let attrs = tcx.codegen_fn_attrs(id);
1450     if attrs.link_section.is_none() {
1451         return
1452     }
1453
1454     // For the wasm32 target statics with #[link_section] are placed into custom
1455     // sections of the final output file, but this isn't link custom sections of
1456     // other executable formats. Namely we can only embed a list of bytes,
1457     // nothing with pointers to anything else or relocations. If any relocation
1458     // show up, reject them here.
1459     let instance = ty::Instance::mono(tcx, id);
1460     let cid = GlobalId {
1461         instance,
1462         promoted: None
1463     };
1464     let param_env = ty::ParamEnv::reveal_all();
1465     if let Ok(static_) = tcx.const_eval(param_env.and(cid)) {
1466         let alloc = if let ConstValue::ByRef(_, allocation, _) = static_.val {
1467             allocation
1468         } else {
1469             bug!("Matching on non-ByRef static")
1470         };
1471         if alloc.relocations.len() != 0 {
1472             let msg = "statics with a custom `#[link_section]` must be a \
1473                        simple list of bytes on the wasm target with no \
1474                        extra levels of indirection such as references";
1475             tcx.sess.span_err(span, msg);
1476         }
1477     }
1478 }
1479
1480 fn check_on_unimplemented<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1481                                     trait_def_id: DefId,
1482                                     item: &hir::Item) {
1483     let item_def_id = tcx.hir().local_def_id(item.id);
1484     // an error would be reported if this fails.
1485     let _ = traits::OnUnimplementedDirective::of_item(tcx, trait_def_id, item_def_id);
1486 }
1487
1488 fn report_forbidden_specialization<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1489                                              impl_item: &hir::ImplItem,
1490                                              parent_impl: DefId)
1491 {
1492     let mut err = struct_span_err!(
1493         tcx.sess, impl_item.span, E0520,
1494         "`{}` specializes an item from a parent `impl`, but \
1495          that item is not marked `default`",
1496         impl_item.ident);
1497     err.span_label(impl_item.span, format!("cannot specialize default item `{}`",
1498                                             impl_item.ident));
1499
1500     match tcx.span_of_impl(parent_impl) {
1501         Ok(span) => {
1502             err.span_label(span, "parent `impl` is here");
1503             err.note(&format!("to specialize, `{}` in the parent `impl` must be marked `default`",
1504                               impl_item.ident));
1505         }
1506         Err(cname) => {
1507             err.note(&format!("parent implementation is in crate `{}`", cname));
1508         }
1509     }
1510
1511     err.emit();
1512 }
1513
1514 fn check_specialization_validity<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1515                                            trait_def: &ty::TraitDef,
1516                                            trait_item: &ty::AssociatedItem,
1517                                            impl_id: DefId,
1518                                            impl_item: &hir::ImplItem)
1519 {
1520     let ancestors = trait_def.ancestors(tcx, impl_id);
1521
1522     let kind = match impl_item.node {
1523         hir::ImplItemKind::Const(..) => ty::AssociatedKind::Const,
1524         hir::ImplItemKind::Method(..) => ty::AssociatedKind::Method,
1525         hir::ImplItemKind::Existential(..) => ty::AssociatedKind::Existential,
1526         hir::ImplItemKind::Type(_) => ty::AssociatedKind::Type
1527     };
1528
1529     let parent = ancestors.defs(tcx, trait_item.ident, kind, trait_def.def_id).nth(1)
1530         .map(|node_item| node_item.map(|parent| parent.defaultness));
1531
1532     if let Some(parent) = parent {
1533         if tcx.impl_item_is_final(&parent) {
1534             report_forbidden_specialization(tcx, impl_item, parent.node.def_id());
1535         }
1536     }
1537
1538 }
1539
1540 fn check_impl_items_against_trait<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1541                                             impl_span: Span,
1542                                             impl_id: DefId,
1543                                             impl_trait_ref: ty::TraitRef<'tcx>,
1544                                             impl_item_refs: &[hir::ImplItemRef]) {
1545     let impl_span = tcx.sess.source_map().def_span(impl_span);
1546
1547     // If the trait reference itself is erroneous (so the compilation is going
1548     // to fail), skip checking the items here -- the `impl_item` table in `tcx`
1549     // isn't populated for such impls.
1550     if impl_trait_ref.references_error() { return; }
1551
1552     // Locate trait definition and items
1553     let trait_def = tcx.trait_def(impl_trait_ref.def_id);
1554     let mut overridden_associated_type = None;
1555
1556     let impl_items = || impl_item_refs.iter().map(|iiref| tcx.hir().impl_item(iiref.id));
1557
1558     // Check existing impl methods to see if they are both present in trait
1559     // and compatible with trait signature
1560     for impl_item in impl_items() {
1561         let ty_impl_item = tcx.associated_item(tcx.hir().local_def_id(impl_item.id));
1562         let ty_trait_item = tcx.associated_items(impl_trait_ref.def_id)
1563             .find(|ac| Namespace::from(&impl_item.node) == Namespace::from(ac.kind) &&
1564                        tcx.hygienic_eq(ty_impl_item.ident, ac.ident, impl_trait_ref.def_id))
1565             .or_else(|| {
1566                 // Not compatible, but needed for the error message
1567                 tcx.associated_items(impl_trait_ref.def_id)
1568                    .find(|ac| tcx.hygienic_eq(ty_impl_item.ident, ac.ident, impl_trait_ref.def_id))
1569             });
1570
1571         // Check that impl definition matches trait definition
1572         if let Some(ty_trait_item) = ty_trait_item {
1573             match impl_item.node {
1574                 hir::ImplItemKind::Const(..) => {
1575                     // Find associated const definition.
1576                     if ty_trait_item.kind == ty::AssociatedKind::Const {
1577                         compare_const_impl(tcx,
1578                                            &ty_impl_item,
1579                                            impl_item.span,
1580                                            &ty_trait_item,
1581                                            impl_trait_ref);
1582                     } else {
1583                          let mut err = struct_span_err!(tcx.sess, impl_item.span, E0323,
1584                              "item `{}` is an associated const, \
1585                               which doesn't match its trait `{}`",
1586                              ty_impl_item.ident,
1587                              impl_trait_ref);
1588                          err.span_label(impl_item.span, "does not match trait");
1589                          // We can only get the spans from local trait definition
1590                          // Same for E0324 and E0325
1591                          if let Some(trait_span) = tcx.hir().span_if_local(ty_trait_item.def_id) {
1592                             err.span_label(trait_span, "item in trait");
1593                          }
1594                          err.emit()
1595                     }
1596                 }
1597                 hir::ImplItemKind::Method(..) => {
1598                     let trait_span = tcx.hir().span_if_local(ty_trait_item.def_id);
1599                     if ty_trait_item.kind == ty::AssociatedKind::Method {
1600                         compare_impl_method(tcx,
1601                                             &ty_impl_item,
1602                                             impl_item.span,
1603                                             &ty_trait_item,
1604                                             impl_trait_ref,
1605                                             trait_span);
1606                     } else {
1607                         let mut err = struct_span_err!(tcx.sess, impl_item.span, E0324,
1608                             "item `{}` is an associated method, \
1609                              which doesn't match its trait `{}`",
1610                             ty_impl_item.ident,
1611                             impl_trait_ref);
1612                          err.span_label(impl_item.span, "does not match trait");
1613                          if let Some(trait_span) = tcx.hir().span_if_local(ty_trait_item.def_id) {
1614                             err.span_label(trait_span, "item in trait");
1615                          }
1616                          err.emit()
1617                     }
1618                 }
1619                 hir::ImplItemKind::Existential(..) |
1620                 hir::ImplItemKind::Type(_) => {
1621                     if ty_trait_item.kind == ty::AssociatedKind::Type {
1622                         if ty_trait_item.defaultness.has_value() {
1623                             overridden_associated_type = Some(impl_item);
1624                         }
1625                     } else {
1626                         let mut err = struct_span_err!(tcx.sess, impl_item.span, E0325,
1627                             "item `{}` is an associated type, \
1628                              which doesn't match its trait `{}`",
1629                             ty_impl_item.ident,
1630                             impl_trait_ref);
1631                          err.span_label(impl_item.span, "does not match trait");
1632                          if let Some(trait_span) = tcx.hir().span_if_local(ty_trait_item.def_id) {
1633                             err.span_label(trait_span, "item in trait");
1634                          }
1635                          err.emit()
1636                     }
1637                 }
1638             }
1639
1640             check_specialization_validity(tcx, trait_def, &ty_trait_item, impl_id, impl_item);
1641         }
1642     }
1643
1644     // Check for missing items from trait
1645     let mut missing_items = Vec::new();
1646     let mut invalidated_items = Vec::new();
1647     let associated_type_overridden = overridden_associated_type.is_some();
1648     for trait_item in tcx.associated_items(impl_trait_ref.def_id) {
1649         let is_implemented = trait_def.ancestors(tcx, impl_id)
1650             .defs(tcx, trait_item.ident, trait_item.kind, impl_trait_ref.def_id)
1651             .next()
1652             .map(|node_item| !node_item.node.is_from_trait())
1653             .unwrap_or(false);
1654
1655         if !is_implemented && !tcx.impl_is_default(impl_id) {
1656             if !trait_item.defaultness.has_value() {
1657                 missing_items.push(trait_item);
1658             } else if associated_type_overridden {
1659                 invalidated_items.push(trait_item.ident);
1660             }
1661         }
1662     }
1663
1664     if !missing_items.is_empty() {
1665         let mut err = struct_span_err!(tcx.sess, impl_span, E0046,
1666             "not all trait items implemented, missing: `{}`",
1667             missing_items.iter()
1668                 .map(|trait_item| trait_item.ident.to_string())
1669                 .collect::<Vec<_>>().join("`, `"));
1670         err.span_label(impl_span, format!("missing `{}` in implementation",
1671                 missing_items.iter()
1672                     .map(|trait_item| trait_item.ident.to_string())
1673                     .collect::<Vec<_>>().join("`, `")));
1674         for trait_item in missing_items {
1675             if let Some(span) = tcx.hir().span_if_local(trait_item.def_id) {
1676                 err.span_label(span, format!("`{}` from trait", trait_item.ident));
1677             } else {
1678                 err.note_trait_signature(trait_item.ident.to_string(),
1679                                          trait_item.signature(&tcx));
1680             }
1681         }
1682         err.emit();
1683     }
1684
1685     if !invalidated_items.is_empty() {
1686         let invalidator = overridden_associated_type.unwrap();
1687         span_err!(tcx.sess, invalidator.span, E0399,
1688                   "the following trait items need to be reimplemented \
1689                    as `{}` was overridden: `{}`",
1690                   invalidator.ident,
1691                   invalidated_items.iter()
1692                                    .map(|name| name.to_string())
1693                                    .collect::<Vec<_>>().join("`, `"))
1694     }
1695 }
1696
1697 /// Checks whether a type can be represented in memory. In particular, it
1698 /// identifies types that contain themselves without indirection through a
1699 /// pointer, which would mean their size is unbounded.
1700 fn check_representable<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1701                                  sp: Span,
1702                                  item_def_id: DefId)
1703                                  -> bool {
1704     let rty = tcx.type_of(item_def_id);
1705
1706     // Check that it is possible to represent this type. This call identifies
1707     // (1) types that contain themselves and (2) types that contain a different
1708     // recursive type. It is only necessary to throw an error on those that
1709     // contain themselves. For case 2, there must be an inner type that will be
1710     // caught by case 1.
1711     match rty.is_representable(tcx, sp) {
1712         Representability::SelfRecursive(spans) => {
1713             let mut err = tcx.recursive_type_with_infinite_size_error(item_def_id);
1714             for span in spans {
1715                 err.span_label(span, "recursive without indirection");
1716             }
1717             err.emit();
1718             return false
1719         }
1720         Representability::Representable | Representability::ContainsRecursive => (),
1721     }
1722     return true
1723 }
1724
1725 pub fn check_simd<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, sp: Span, def_id: DefId) {
1726     let t = tcx.type_of(def_id);
1727     if let ty::Adt(def, substs) = t.sty {
1728         if def.is_struct() {
1729             let fields = &def.non_enum_variant().fields;
1730             if fields.is_empty() {
1731                 span_err!(tcx.sess, sp, E0075, "SIMD vector cannot be empty");
1732                 return;
1733             }
1734             let e = fields[0].ty(tcx, substs);
1735             if !fields.iter().all(|f| f.ty(tcx, substs) == e) {
1736                 struct_span_err!(tcx.sess, sp, E0076, "SIMD vector should be homogeneous")
1737                                 .span_label(sp, "SIMD elements must have the same type")
1738                                 .emit();
1739                 return;
1740             }
1741             match e.sty {
1742                 ty::Param(_) => { /* struct<T>(T, T, T, T) is ok */ }
1743                 _ if e.is_machine() => { /* struct(u8, u8, u8, u8) is ok */ }
1744                 _ => {
1745                     span_err!(tcx.sess, sp, E0077,
1746                               "SIMD vector element type should be machine type");
1747                     return;
1748                 }
1749             }
1750         }
1751     }
1752 }
1753
1754 fn check_packed<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, sp: Span, def_id: DefId) {
1755     let repr = tcx.adt_def(def_id).repr;
1756     if repr.packed() {
1757         for attr in tcx.get_attrs(def_id).iter() {
1758             for r in attr::find_repr_attrs(&tcx.sess.parse_sess, attr) {
1759                 if let attr::ReprPacked(pack) = r {
1760                     if pack != repr.pack {
1761                         struct_span_err!(tcx.sess, sp, E0634,
1762                                          "type has conflicting packed representation hints").emit();
1763                     }
1764                 }
1765             }
1766         }
1767         if repr.align > 0 {
1768             struct_span_err!(tcx.sess, sp, E0587,
1769                              "type has conflicting packed and align representation hints").emit();
1770         }
1771         else if check_packed_inner(tcx, def_id, &mut Vec::new()) {
1772             struct_span_err!(tcx.sess, sp, E0588,
1773                 "packed type cannot transitively contain a `[repr(align)]` type").emit();
1774         }
1775     }
1776 }
1777
1778 fn check_packed_inner<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1779                                 def_id: DefId,
1780                                 stack: &mut Vec<DefId>) -> bool {
1781     let t = tcx.type_of(def_id);
1782     if stack.contains(&def_id) {
1783         debug!("check_packed_inner: {:?} is recursive", t);
1784         return false;
1785     }
1786     if let ty::Adt(def, substs) = t.sty {
1787         if def.is_struct() || def.is_union() {
1788             if tcx.adt_def(def.did).repr.align > 0 {
1789                 return true;
1790             }
1791             // push struct def_id before checking fields
1792             stack.push(def_id);
1793             for field in &def.non_enum_variant().fields {
1794                 let f = field.ty(tcx, substs);
1795                 if let ty::Adt(def, _) = f.sty {
1796                     if check_packed_inner(tcx, def.did, stack) {
1797                         return true;
1798                     }
1799                 }
1800             }
1801             // only need to pop if not early out
1802             stack.pop();
1803         }
1804     }
1805     false
1806 }
1807
1808 fn check_transparent<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>, sp: Span, def_id: DefId) {
1809     let adt = tcx.adt_def(def_id);
1810     if !adt.repr.transparent() {
1811         return;
1812     }
1813
1814     // For each field, figure out if it's known to be a ZST and align(1)
1815     let field_infos = adt.non_enum_variant().fields.iter().map(|field| {
1816         let ty = field.ty(tcx, Substs::identity_for_item(tcx, field.did));
1817         let param_env = tcx.param_env(field.did);
1818         let layout = tcx.layout_of(param_env.and(ty));
1819         // We are currently checking the type this field came from, so it must be local
1820         let span = tcx.hir().span_if_local(field.did).unwrap();
1821         let zst = layout.map(|layout| layout.is_zst()).unwrap_or(false);
1822         let align1 = layout.map(|layout| layout.align.abi.bytes() == 1).unwrap_or(false);
1823         (span, zst, align1)
1824     });
1825
1826     let non_zst_fields = field_infos.clone().filter(|(_span, zst, _align1)| !*zst);
1827     let non_zst_count = non_zst_fields.clone().count();
1828     if non_zst_count != 1 {
1829         let field_spans: Vec<_> = non_zst_fields.map(|(span, _zst, _align1)| span).collect();
1830         struct_span_err!(tcx.sess, sp, E0690,
1831                          "transparent struct needs exactly one non-zero-sized field, but has {}",
1832                          non_zst_count)
1833         .span_note(field_spans, "non-zero-sized field")
1834         .emit();
1835     }
1836     for (span, zst, align1) in field_infos {
1837         if zst && !align1 {
1838             span_err!(tcx.sess, span, E0691,
1839                       "zero-sized field in transparent struct has alignment larger than 1");
1840         }
1841     }
1842 }
1843
1844 #[allow(trivial_numeric_casts)]
1845 pub fn check_enum<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
1846                             sp: Span,
1847                             vs: &'tcx [hir::Variant],
1848                             id: ast::NodeId) {
1849     let def_id = tcx.hir().local_def_id(id);
1850     let def = tcx.adt_def(def_id);
1851     def.destructor(tcx); // force the destructor to be evaluated
1852
1853     if vs.is_empty() {
1854         let attributes = tcx.get_attrs(def_id);
1855         if let Some(attr) = attr::find_by_name(&attributes, "repr") {
1856             struct_span_err!(
1857                 tcx.sess, attr.span, E0084,
1858                 "unsupported representation for zero-variant enum")
1859                 .span_label(sp, "zero-variant enum")
1860                 .emit();
1861         }
1862     }
1863
1864     let repr_type_ty = def.repr.discr_type().to_ty(tcx);
1865     if repr_type_ty == tcx.types.i128 || repr_type_ty == tcx.types.u128 {
1866         if !tcx.features().repr128 {
1867             emit_feature_err(&tcx.sess.parse_sess,
1868                              "repr128",
1869                              sp,
1870                              GateIssue::Language,
1871                              "repr with 128-bit type is unstable");
1872         }
1873     }
1874
1875     for v in vs {
1876         if let Some(ref e) = v.node.disr_expr {
1877             tcx.typeck_tables_of(tcx.hir().local_def_id(e.id));
1878         }
1879     }
1880
1881     let mut disr_vals: Vec<Discr<'tcx>> = Vec::with_capacity(vs.len());
1882     for ((_, discr), v) in def.discriminants(tcx).zip(vs) {
1883         // Check for duplicate discriminant values
1884         if let Some(i) = disr_vals.iter().position(|&x| x.val == discr.val) {
1885             let variant_did = def.variants[VariantIdx::new(i)].did;
1886             let variant_i_node_id = tcx.hir().as_local_node_id(variant_did).unwrap();
1887             let variant_i = tcx.hir().expect_variant(variant_i_node_id);
1888             let i_span = match variant_i.node.disr_expr {
1889                 Some(ref expr) => tcx.hir().span(expr.id),
1890                 None => tcx.hir().span(variant_i_node_id)
1891             };
1892             let span = match v.node.disr_expr {
1893                 Some(ref expr) => tcx.hir().span(expr.id),
1894                 None => v.span
1895             };
1896             struct_span_err!(tcx.sess, span, E0081,
1897                              "discriminant value `{}` already exists", disr_vals[i])
1898                 .span_label(i_span, format!("first use of `{}`", disr_vals[i]))
1899                 .span_label(span , format!("enum already has `{}`", disr_vals[i]))
1900                 .emit();
1901         }
1902         disr_vals.push(discr);
1903     }
1904
1905     check_representable(tcx, sp, def_id);
1906 }
1907
1908 fn report_unexpected_variant_def<'a, 'gcx, 'tcx>(tcx: TyCtxt<'a, 'gcx, 'tcx>,
1909                                                  def: &Def,
1910                                                  span: Span,
1911                                                  qpath: &QPath) {
1912     span_err!(tcx.sess, span, E0533,
1913               "expected unit struct/variant or constant, found {} `{}`",
1914               def.kind_name(),
1915               hir::print::to_string(tcx.hir(), |s| s.print_qpath(qpath, false)));
1916 }
1917
1918 impl<'a, 'gcx, 'tcx> AstConv<'gcx, 'tcx> for FnCtxt<'a, 'gcx, 'tcx> {
1919     fn tcx<'b>(&'b self) -> TyCtxt<'b, 'gcx, 'tcx> { self.tcx }
1920
1921     fn get_type_parameter_bounds(&self, _: Span, def_id: DefId)
1922                                  -> Lrc<ty::GenericPredicates<'tcx>>
1923     {
1924         let tcx = self.tcx;
1925         let node_id = tcx.hir().as_local_node_id(def_id).unwrap();
1926         let item_id = tcx.hir().ty_param_owner(node_id);
1927         let item_def_id = tcx.hir().local_def_id(item_id);
1928         let generics = tcx.generics_of(item_def_id);
1929         let index = generics.param_def_id_to_index[&def_id];
1930         Lrc::new(ty::GenericPredicates {
1931             parent: None,
1932             predicates: self.param_env.caller_bounds.iter().filter_map(|&predicate| {
1933                 match predicate {
1934                     ty::Predicate::Trait(ref data)
1935                     if data.skip_binder().self_ty().is_param(index) => {
1936                         // HACK(eddyb) should get the original `Span`.
1937                         let span = tcx.def_span(def_id);
1938                         Some((predicate, span))
1939                     }
1940                     _ => None
1941                 }
1942             }).collect()
1943         })
1944     }
1945
1946     fn re_infer(&self, span: Span, def: Option<&ty::GenericParamDef>)
1947                 -> Option<ty::Region<'tcx>> {
1948         let v = match def {
1949             Some(def) => infer::EarlyBoundRegion(span, def.name),
1950             None => infer::MiscVariable(span)
1951         };
1952         Some(self.next_region_var(v))
1953     }
1954
1955     fn ty_infer(&self, span: Span) -> Ty<'tcx> {
1956         self.next_ty_var(TypeVariableOrigin::TypeInference(span))
1957     }
1958
1959     fn ty_infer_for_def(&self,
1960                         ty_param_def: &ty::GenericParamDef,
1961                         span: Span) -> Ty<'tcx> {
1962         if let UnpackedKind::Type(ty) = self.var_for_def(span, ty_param_def).unpack() {
1963             return ty;
1964         }
1965         unreachable!()
1966     }
1967
1968     fn projected_ty_from_poly_trait_ref(&self,
1969                                         span: Span,
1970                                         item_def_id: DefId,
1971                                         poly_trait_ref: ty::PolyTraitRef<'tcx>)
1972                                         -> Ty<'tcx>
1973     {
1974         let (trait_ref, _) = self.replace_bound_vars_with_fresh_vars(
1975             span,
1976             infer::LateBoundRegionConversionTime::AssocTypeProjection(item_def_id),
1977             &poly_trait_ref
1978         );
1979
1980         self.tcx().mk_projection(item_def_id, trait_ref.substs)
1981     }
1982
1983     fn normalize_ty(&self, span: Span, ty: Ty<'tcx>) -> Ty<'tcx> {
1984         if ty.has_escaping_bound_vars() {
1985             ty // FIXME: normalization and escaping regions
1986         } else {
1987             self.normalize_associated_types_in(span, &ty)
1988         }
1989     }
1990
1991     fn set_tainted_by_errors(&self) {
1992         self.infcx.set_tainted_by_errors()
1993     }
1994
1995     fn record_ty(&self, hir_id: hir::HirId, ty: Ty<'tcx>, _span: Span) {
1996         self.write_ty(hir_id, ty)
1997     }
1998 }
1999
2000 /// Controls whether the arguments are tupled. This is used for the call
2001 /// operator.
2002 ///
2003 /// Tupling means that all call-side arguments are packed into a tuple and
2004 /// passed as a single parameter. For example, if tupling is enabled, this
2005 /// function:
2006 ///
2007 ///     fn f(x: (isize, isize))
2008 ///
2009 /// Can be called as:
2010 ///
2011 ///     f(1, 2);
2012 ///
2013 /// Instead of:
2014 ///
2015 ///     f((1, 2));
2016 #[derive(Clone, Eq, PartialEq)]
2017 enum TupleArgumentsFlag {
2018     DontTupleArguments,
2019     TupleArguments,
2020 }
2021
2022 impl<'a, 'gcx, 'tcx> FnCtxt<'a, 'gcx, 'tcx> {
2023     pub fn new(inh: &'a Inherited<'a, 'gcx, 'tcx>,
2024                param_env: ty::ParamEnv<'tcx>,
2025                body_id: ast::NodeId)
2026                -> FnCtxt<'a, 'gcx, 'tcx> {
2027         FnCtxt {
2028             body_id,
2029             param_env,
2030             err_count_on_creation: inh.tcx.sess.err_count(),
2031             ret_coercion: None,
2032             ret_coercion_span: RefCell::new(None),
2033             yield_ty: None,
2034             ps: RefCell::new(UnsafetyState::function(hir::Unsafety::Normal,
2035                                                      ast::CRATE_NODE_ID)),
2036             diverges: Cell::new(Diverges::Maybe),
2037             has_errors: Cell::new(false),
2038             enclosing_breakables: RefCell::new(EnclosingBreakables {
2039                 stack: Vec::new(),
2040                 by_id: Default::default(),
2041             }),
2042             inh,
2043         }
2044     }
2045
2046     pub fn sess(&self) -> &Session {
2047         &self.tcx.sess
2048     }
2049
2050     pub fn err_count_since_creation(&self) -> usize {
2051         self.tcx.sess.err_count() - self.err_count_on_creation
2052     }
2053
2054     /// Produce warning on the given node, if the current point in the
2055     /// function is unreachable, and there hasn't been another warning.
2056     fn warn_if_unreachable(&self, id: ast::NodeId, span: Span, kind: &str) {
2057         if self.diverges.get() == Diverges::Always {
2058             self.diverges.set(Diverges::WarnedAlways);
2059
2060             debug!("warn_if_unreachable: id={:?} span={:?} kind={}", id, span, kind);
2061
2062             self.tcx().lint_node(
2063                 lint::builtin::UNREACHABLE_CODE,
2064                 id, span,
2065                 &format!("unreachable {}", kind));
2066         }
2067     }
2068
2069     pub fn cause(&self,
2070                  span: Span,
2071                  code: ObligationCauseCode<'tcx>)
2072                  -> ObligationCause<'tcx> {
2073         ObligationCause::new(span, self.body_id, code)
2074     }
2075
2076     pub fn misc(&self, span: Span) -> ObligationCause<'tcx> {
2077         self.cause(span, ObligationCauseCode::MiscObligation)
2078     }
2079
2080     /// Resolves type variables in `ty` if possible. Unlike the infcx
2081     /// version (resolve_type_vars_if_possible), this version will
2082     /// also select obligations if it seems useful, in an effort
2083     /// to get more type information.
2084     fn resolve_type_vars_with_obligations(&self, mut ty: Ty<'tcx>) -> Ty<'tcx> {
2085         debug!("resolve_type_vars_with_obligations(ty={:?})", ty);
2086
2087         // No Infer()? Nothing needs doing.
2088         if !ty.has_infer_types() {
2089             debug!("resolve_type_vars_with_obligations: ty={:?}", ty);
2090             return ty;
2091         }
2092
2093         // If `ty` is a type variable, see whether we already know what it is.
2094         ty = self.resolve_type_vars_if_possible(&ty);
2095         if !ty.has_infer_types() {
2096             debug!("resolve_type_vars_with_obligations: ty={:?}", ty);
2097             return ty;
2098         }
2099
2100         // If not, try resolving pending obligations as much as
2101         // possible. This can help substantially when there are
2102         // indirect dependencies that don't seem worth tracking
2103         // precisely.
2104         self.select_obligations_where_possible(false);
2105         ty = self.resolve_type_vars_if_possible(&ty);
2106
2107         debug!("resolve_type_vars_with_obligations: ty={:?}", ty);
2108         ty
2109     }
2110
2111     fn record_deferred_call_resolution(&self,
2112                                        closure_def_id: DefId,
2113                                        r: DeferredCallResolution<'gcx, 'tcx>) {
2114         let mut deferred_call_resolutions = self.deferred_call_resolutions.borrow_mut();
2115         deferred_call_resolutions.entry(closure_def_id).or_default().push(r);
2116     }
2117
2118     fn remove_deferred_call_resolutions(&self,
2119                                         closure_def_id: DefId)
2120                                         -> Vec<DeferredCallResolution<'gcx, 'tcx>>
2121     {
2122         let mut deferred_call_resolutions = self.deferred_call_resolutions.borrow_mut();
2123         deferred_call_resolutions.remove(&closure_def_id).unwrap_or(vec![])
2124     }
2125
2126     pub fn tag(&self) -> String {
2127         let self_ptr: *const FnCtxt = self;
2128         format!("{:?}", self_ptr)
2129     }
2130
2131     pub fn local_ty(&self, span: Span, nid: ast::NodeId) -> LocalTy<'tcx> {
2132         self.locals.borrow().get(&nid).cloned().unwrap_or_else(||
2133             span_bug!(span, "no type for local variable {}",
2134                       self.tcx.hir().node_to_string(nid))
2135         )
2136     }
2137
2138     #[inline]
2139     pub fn write_ty(&self, id: hir::HirId, ty: Ty<'tcx>) {
2140         debug!("write_ty({:?}, {:?}) in fcx {}",
2141                id, self.resolve_type_vars_if_possible(&ty), self.tag());
2142         self.tables.borrow_mut().node_types_mut().insert(id, ty);
2143
2144         if ty.references_error() {
2145             self.has_errors.set(true);
2146             self.set_tainted_by_errors();
2147         }
2148     }
2149
2150     pub fn write_field_index(&self, node_id: ast::NodeId, index: usize) {
2151         let hir_id = self.tcx.hir().node_to_hir_id(node_id);
2152         self.tables.borrow_mut().field_indices_mut().insert(hir_id, index);
2153     }
2154
2155     pub fn write_method_call(&self,
2156                              hir_id: hir::HirId,
2157                              method: MethodCallee<'tcx>) {
2158         debug!("write_method_call(hir_id={:?}, method={:?})", hir_id, method);
2159         self.tables
2160             .borrow_mut()
2161             .type_dependent_defs_mut()
2162             .insert(hir_id, Def::Method(method.def_id));
2163
2164         self.write_substs(hir_id, method.substs);
2165
2166         // When the method is confirmed, the `method.substs` includes
2167         // parameters from not just the method, but also the impl of
2168         // the method -- in particular, the `Self` type will be fully
2169         // resolved. However, those are not something that the "user
2170         // specified" -- i.e., those types come from the inferred type
2171         // of the receiver, not something the user wrote. So when we
2172         // create the user-substs, we want to replace those earlier
2173         // types with just the types that the user actually wrote --
2174         // that is, those that appear on the *method itself*.
2175         //
2176         // As an example, if the user wrote something like
2177         // `foo.bar::<u32>(...)` -- the `Self` type here will be the
2178         // type of `foo` (possibly adjusted), but we don't want to
2179         // include that. We want just the `[_, u32]` part.
2180         if !method.substs.is_noop() {
2181             let method_generics = self.tcx.generics_of(method.def_id);
2182             if !method_generics.params.is_empty() {
2183                 let user_type_annotation = self.infcx.probe(|_| {
2184                     let user_substs = UserSubsts {
2185                         substs: Substs::for_item(self.tcx, method.def_id, |param, _| {
2186                             let i = param.index as usize;
2187                             if i < method_generics.parent_count {
2188                                 self.infcx.var_for_def(DUMMY_SP, param)
2189                             } else {
2190                                 method.substs[i]
2191                             }
2192                         }),
2193                         user_self_ty: None, // not relevant here
2194                     };
2195
2196                     self.infcx.canonicalize_user_type_annotation(&UserType::TypeOf(
2197                         method.def_id,
2198                         user_substs,
2199                     ))
2200                 });
2201
2202                 debug!("write_method_call: user_type_annotation={:?}", user_type_annotation);
2203                 self.write_user_type_annotation(hir_id, user_type_annotation);
2204             }
2205         }
2206     }
2207
2208     pub fn write_substs(&self, node_id: hir::HirId, substs: &'tcx Substs<'tcx>) {
2209         if !substs.is_noop() {
2210             debug!("write_substs({:?}, {:?}) in fcx {}",
2211                    node_id,
2212                    substs,
2213                    self.tag());
2214
2215             self.tables.borrow_mut().node_substs_mut().insert(node_id, substs);
2216         }
2217     }
2218
2219     /// Given the substs that we just converted from the HIR, try to
2220     /// canonicalize them and store them as user-given substitutions
2221     /// (i.e., substitutions that must be respected by the NLL check).
2222     ///
2223     /// This should be invoked **before any unifications have
2224     /// occurred**, so that annotations like `Vec<_>` are preserved
2225     /// properly.
2226     pub fn write_user_type_annotation_from_substs(
2227         &self,
2228         hir_id: hir::HirId,
2229         def_id: DefId,
2230         substs: &'tcx Substs<'tcx>,
2231         user_self_ty: Option<UserSelfTy<'tcx>>,
2232     ) {
2233         debug!(
2234             "write_user_type_annotation_from_substs: hir_id={:?} def_id={:?} substs={:?} \
2235              user_self_ty={:?} in fcx {}",
2236             hir_id, def_id, substs, user_self_ty, self.tag(),
2237         );
2238
2239         if !substs.is_noop() {
2240             let canonicalized = self.infcx.canonicalize_user_type_annotation(
2241                 &UserType::TypeOf(def_id, UserSubsts {
2242                     substs,
2243                     user_self_ty,
2244                 })
2245             );
2246             debug!("write_user_type_annotation_from_substs: canonicalized={:?}", canonicalized);
2247             self.write_user_type_annotation(hir_id, canonicalized);
2248         }
2249     }
2250
2251     pub fn write_user_type_annotation(
2252         &self,
2253         hir_id: hir::HirId,
2254         canonical_user_type_annotation: CanonicalUserType<'tcx>,
2255     ) {
2256         debug!(
2257             "write_user_type_annotation: hir_id={:?} canonical_user_type_annotation={:?} tag={}",
2258             hir_id, canonical_user_type_annotation, self.tag(),
2259         );
2260
2261         if !canonical_user_type_annotation.is_identity() {
2262             self.tables.borrow_mut().user_provided_types_mut().insert(
2263                 hir_id, canonical_user_type_annotation
2264             );
2265         } else {
2266             debug!("write_user_type_annotation: skipping identity substs");
2267         }
2268     }
2269
2270     pub fn apply_adjustments(&self, expr: &hir::Expr, adj: Vec<Adjustment<'tcx>>) {
2271         debug!("apply_adjustments(expr={:?}, adj={:?})", expr, adj);
2272
2273         if adj.is_empty() {
2274             return;
2275         }
2276
2277         match self.tables.borrow_mut().adjustments_mut().entry(expr.hir_id) {
2278             Entry::Vacant(entry) => { entry.insert(adj); },
2279             Entry::Occupied(mut entry) => {
2280                 debug!(" - composing on top of {:?}", entry.get());
2281                 match (&entry.get()[..], &adj[..]) {
2282                     // Applying any adjustment on top of a NeverToAny
2283                     // is a valid NeverToAny adjustment, because it can't
2284                     // be reached.
2285                     (&[Adjustment { kind: Adjust::NeverToAny, .. }], _) => return,
2286                     (&[
2287                         Adjustment { kind: Adjust::Deref(_), .. },
2288                         Adjustment { kind: Adjust::Borrow(AutoBorrow::Ref(..)), .. },
2289                     ], &[
2290                         Adjustment { kind: Adjust::Deref(_), .. },
2291                         .. // Any following adjustments are allowed.
2292                     ]) => {
2293                         // A reborrow has no effect before a dereference.
2294                     }
2295                     // FIXME: currently we never try to compose autoderefs
2296                     // and ReifyFnPointer/UnsafeFnPointer, but we could.
2297                     _ =>
2298                         bug!("while adjusting {:?}, can't compose {:?} and {:?}",
2299                              expr, entry.get(), adj)
2300                 };
2301                 *entry.get_mut() = adj;
2302             }
2303         }
2304     }
2305
2306     /// Basically whenever we are converting from a type scheme into
2307     /// the fn body space, we always want to normalize associated
2308     /// types as well. This function combines the two.
2309     fn instantiate_type_scheme<T>(&self,
2310                                   span: Span,
2311                                   substs: &Substs<'tcx>,
2312                                   value: &T)
2313                                   -> T
2314         where T : TypeFoldable<'tcx>
2315     {
2316         let value = value.subst(self.tcx, substs);
2317         let result = self.normalize_associated_types_in(span, &value);
2318         debug!("instantiate_type_scheme(value={:?}, substs={:?}) = {:?}",
2319                value,
2320                substs,
2321                result);
2322         result
2323     }
2324
2325     /// As `instantiate_type_scheme`, but for the bounds found in a
2326     /// generic type scheme.
2327     fn instantiate_bounds(&self, span: Span, def_id: DefId, substs: &Substs<'tcx>)
2328                           -> ty::InstantiatedPredicates<'tcx> {
2329         let bounds = self.tcx.predicates_of(def_id);
2330         let result = bounds.instantiate(self.tcx, substs);
2331         let result = self.normalize_associated_types_in(span, &result);
2332         debug!("instantiate_bounds(bounds={:?}, substs={:?}) = {:?}",
2333                bounds,
2334                substs,
2335                result);
2336         result
2337     }
2338
2339     /// Replace the opaque types from the given value with type variables,
2340     /// and records the `OpaqueTypeMap` for later use during writeback. See
2341     /// `InferCtxt::instantiate_opaque_types` for more details.
2342     fn instantiate_opaque_types_from_value<T: TypeFoldable<'tcx>>(
2343         &self,
2344         parent_id: ast::NodeId,
2345         value: &T,
2346     ) -> T {
2347         let parent_def_id = self.tcx.hir().local_def_id(parent_id);
2348         debug!("instantiate_opaque_types_from_value(parent_def_id={:?}, value={:?})",
2349                parent_def_id,
2350                value);
2351
2352         let (value, opaque_type_map) = self.register_infer_ok_obligations(
2353             self.instantiate_opaque_types(
2354                 parent_def_id,
2355                 self.body_id,
2356                 self.param_env,
2357                 value,
2358             )
2359         );
2360
2361         let mut opaque_types = self.opaque_types.borrow_mut();
2362         for (ty, decl) in opaque_type_map {
2363             let old_value = opaque_types.insert(ty, decl);
2364             assert!(old_value.is_none(), "instantiated twice: {:?}/{:?}", ty, decl);
2365         }
2366
2367         value
2368     }
2369
2370     fn normalize_associated_types_in<T>(&self, span: Span, value: &T) -> T
2371         where T : TypeFoldable<'tcx>
2372     {
2373         self.inh.normalize_associated_types_in(span, self.body_id, self.param_env, value)
2374     }
2375
2376     fn normalize_associated_types_in_as_infer_ok<T>(&self, span: Span, value: &T)
2377                                                     -> InferOk<'tcx, T>
2378         where T : TypeFoldable<'tcx>
2379     {
2380         self.inh.partially_normalize_associated_types_in(span,
2381                                                          self.body_id,
2382                                                          self.param_env,
2383                                                          value)
2384     }
2385
2386     pub fn require_type_meets(&self,
2387                               ty: Ty<'tcx>,
2388                               span: Span,
2389                               code: traits::ObligationCauseCode<'tcx>,
2390                               def_id: DefId)
2391     {
2392         self.register_bound(
2393             ty,
2394             def_id,
2395             traits::ObligationCause::new(span, self.body_id, code));
2396     }
2397
2398     pub fn require_type_is_sized(&self,
2399                                  ty: Ty<'tcx>,
2400                                  span: Span,
2401                                  code: traits::ObligationCauseCode<'tcx>)
2402     {
2403         let lang_item = self.tcx.require_lang_item(lang_items::SizedTraitLangItem);
2404         self.require_type_meets(ty, span, code, lang_item);
2405     }
2406
2407     pub fn require_type_is_sized_deferred(&self,
2408                                           ty: Ty<'tcx>,
2409                                           span: Span,
2410                                           code: traits::ObligationCauseCode<'tcx>)
2411     {
2412         self.deferred_sized_obligations.borrow_mut().push((ty, span, code));
2413     }
2414
2415     pub fn register_bound(&self,
2416                           ty: Ty<'tcx>,
2417                           def_id: DefId,
2418                           cause: traits::ObligationCause<'tcx>)
2419     {
2420         self.fulfillment_cx.borrow_mut()
2421                            .register_bound(self, self.param_env, ty, def_id, cause);
2422     }
2423
2424     pub fn to_ty(&self, ast_t: &hir::Ty) -> Ty<'tcx> {
2425         let t = AstConv::ast_ty_to_ty(self, ast_t);
2426         self.register_wf_obligation(t, ast_t.span, traits::MiscObligation);
2427         t
2428     }
2429
2430     pub fn to_ty_saving_user_provided_ty(&self, ast_ty: &hir::Ty) -> Ty<'tcx> {
2431         let ty = self.to_ty(ast_ty);
2432         debug!("to_ty_saving_user_provided_ty: ty={:?}", ty);
2433
2434         // If the type given by the user has free regions, save it for
2435         // later, since NLL would like to enforce those. Also pass in
2436         // types that involve projections, since those can resolve to
2437         // `'static` bounds (modulo #54940, which hopefully will be
2438         // fixed by the time you see this comment, dear reader,
2439         // although I have my doubts). Also pass in types with inference
2440         // types, because they may be repeated. Other sorts of things
2441         // are already sufficiently enforced with erased regions. =)
2442         if ty.has_free_regions() || ty.has_projections() || ty.has_infer_types() {
2443             let c_ty = self.infcx.canonicalize_response(&UserType::Ty(ty));
2444             debug!("to_ty_saving_user_provided_ty: c_ty={:?}", c_ty);
2445             self.tables.borrow_mut().user_provided_types_mut().insert(ast_ty.hir_id, c_ty);
2446         }
2447
2448         ty
2449     }
2450
2451     pub fn node_ty(&self, id: hir::HirId) -> Ty<'tcx> {
2452         match self.tables.borrow().node_types().get(id) {
2453             Some(&t) => t,
2454             None if self.is_tainted_by_errors() => self.tcx.types.err,
2455             None => {
2456                 let node_id = self.tcx.hir().hir_to_node_id(id);
2457                 bug!("no type for node {}: {} in fcx {}",
2458                      node_id, self.tcx.hir().node_to_string(node_id),
2459                      self.tag());
2460             }
2461         }
2462     }
2463
2464     /// Registers an obligation for checking later, during regionck, that the type `ty` must
2465     /// outlive the region `r`.
2466     pub fn register_wf_obligation(&self,
2467                                   ty: Ty<'tcx>,
2468                                   span: Span,
2469                                   code: traits::ObligationCauseCode<'tcx>)
2470     {
2471         // WF obligations never themselves fail, so no real need to give a detailed cause:
2472         let cause = traits::ObligationCause::new(span, self.body_id, code);
2473         self.register_predicate(traits::Obligation::new(cause,
2474                                                         self.param_env,
2475                                                         ty::Predicate::WellFormed(ty)));
2476     }
2477
2478     /// Registers obligations that all types appearing in `substs` are well-formed.
2479     pub fn add_wf_bounds(&self, substs: &Substs<'tcx>, expr: &hir::Expr) {
2480         for ty in substs.types() {
2481             self.register_wf_obligation(ty, expr.span, traits::MiscObligation);
2482         }
2483     }
2484
2485     /// Given a fully substituted set of bounds (`generic_bounds`), and the values with which each
2486     /// type/region parameter was instantiated (`substs`), creates and registers suitable
2487     /// trait/region obligations.
2488     ///
2489     /// For example, if there is a function:
2490     ///
2491     /// ```
2492     /// fn foo<'a,T:'a>(...)
2493     /// ```
2494     ///
2495     /// and a reference:
2496     ///
2497     /// ```
2498     /// let f = foo;
2499     /// ```
2500     ///
2501     /// Then we will create a fresh region variable `'$0` and a fresh type variable `$1` for `'a`
2502     /// and `T`. This routine will add a region obligation `$1:'$0` and register it locally.
2503     pub fn add_obligations_for_parameters(&self,
2504                                           cause: traits::ObligationCause<'tcx>,
2505                                           predicates: &ty::InstantiatedPredicates<'tcx>)
2506     {
2507         assert!(!predicates.has_escaping_bound_vars());
2508
2509         debug!("add_obligations_for_parameters(predicates={:?})",
2510                predicates);
2511
2512         for obligation in traits::predicates_for_generics(cause, self.param_env, predicates) {
2513             self.register_predicate(obligation);
2514         }
2515     }
2516
2517     // FIXME(arielb1): use this instead of field.ty everywhere
2518     // Only for fields! Returns <none> for methods>
2519     // Indifferent to privacy flags
2520     pub fn field_ty(&self,
2521                     span: Span,
2522                     field: &'tcx ty::FieldDef,
2523                     substs: &Substs<'tcx>)
2524                     -> Ty<'tcx>
2525     {
2526         self.normalize_associated_types_in(span, &field.ty(self.tcx, substs))
2527     }
2528
2529     fn check_casts(&self) {
2530         let mut deferred_cast_checks = self.deferred_cast_checks.borrow_mut();
2531         for cast in deferred_cast_checks.drain(..) {
2532             cast.check(self);
2533         }
2534     }
2535
2536     fn resolve_generator_interiors(&self, def_id: DefId) {
2537         let mut generators = self.deferred_generator_interiors.borrow_mut();
2538         for (body_id, interior) in generators.drain(..) {
2539             self.select_obligations_where_possible(false);
2540             generator_interior::resolve_interior(self, def_id, body_id, interior);
2541         }
2542     }
2543
2544     // Tries to apply a fallback to `ty` if it is an unsolved variable.
2545     // Non-numerics get replaced with ! or () (depending on whether
2546     // feature(never_type) is enabled, unconstrained ints with i32,
2547     // unconstrained floats with f64.
2548     // Fallback becomes very dubious if we have encountered type-checking errors.
2549     // In that case, fallback to Error.
2550     // The return value indicates whether fallback has occurred.
2551     fn fallback_if_possible(&self, ty: Ty<'tcx>) -> bool {
2552         use rustc::ty::error::UnconstrainedNumeric::Neither;
2553         use rustc::ty::error::UnconstrainedNumeric::{UnconstrainedInt, UnconstrainedFloat};
2554
2555         assert!(ty.is_ty_infer());
2556         let fallback = match self.type_is_unconstrained_numeric(ty) {
2557             _ if self.is_tainted_by_errors() => self.tcx().types.err,
2558             UnconstrainedInt => self.tcx.types.i32,
2559             UnconstrainedFloat => self.tcx.types.f64,
2560             Neither if self.type_var_diverges(ty) => self.tcx.mk_diverging_default(),
2561             Neither => return false,
2562         };
2563         debug!("default_type_parameters: defaulting `{:?}` to `{:?}`", ty, fallback);
2564         self.demand_eqtype(syntax_pos::DUMMY_SP, ty, fallback);
2565         true
2566     }
2567
2568     fn select_all_obligations_or_error(&self) {
2569         debug!("select_all_obligations_or_error");
2570         if let Err(errors) = self.fulfillment_cx.borrow_mut().select_all_or_error(&self) {
2571             self.report_fulfillment_errors(&errors, self.inh.body_id, false);
2572         }
2573     }
2574
2575     /// Select as many obligations as we can at present.
2576     fn select_obligations_where_possible(&self, fallback_has_occurred: bool) {
2577         if let Err(errors) = self.fulfillment_cx.borrow_mut().select_where_possible(self) {
2578             self.report_fulfillment_errors(&errors, self.inh.body_id, fallback_has_occurred);
2579         }
2580     }
2581
2582     /// For the overloaded place expressions (`*x`, `x[3]`), the trait
2583     /// returns a type of `&T`, but the actual type we assign to the
2584     /// *expression* is `T`. So this function just peels off the return
2585     /// type by one layer to yield `T`.
2586     fn make_overloaded_place_return_type(&self,
2587                                           method: MethodCallee<'tcx>)
2588                                           -> ty::TypeAndMut<'tcx>
2589     {
2590         // extract method return type, which will be &T;
2591         let ret_ty = method.sig.output();
2592
2593         // method returns &T, but the type as visible to user is T, so deref
2594         ret_ty.builtin_deref(true).unwrap()
2595     }
2596
2597     fn lookup_indexing(&self,
2598                        expr: &hir::Expr,
2599                        base_expr: &'gcx hir::Expr,
2600                        base_ty: Ty<'tcx>,
2601                        idx_ty: Ty<'tcx>,
2602                        needs: Needs)
2603                        -> Option<(/*index type*/ Ty<'tcx>, /*element type*/ Ty<'tcx>)>
2604     {
2605         // FIXME(#18741) -- this is almost but not quite the same as the
2606         // autoderef that normal method probing does. They could likely be
2607         // consolidated.
2608
2609         let mut autoderef = self.autoderef(base_expr.span, base_ty);
2610         let mut result = None;
2611         while result.is_none() && autoderef.next().is_some() {
2612             result = self.try_index_step(expr, base_expr, &autoderef, needs, idx_ty);
2613         }
2614         autoderef.finalize(self);
2615         result
2616     }
2617
2618     /// To type-check `base_expr[index_expr]`, we progressively autoderef
2619     /// (and otherwise adjust) `base_expr`, looking for a type which either
2620     /// supports builtin indexing or overloaded indexing.
2621     /// This loop implements one step in that search; the autoderef loop
2622     /// is implemented by `lookup_indexing`.
2623     fn try_index_step(&self,
2624                       expr: &hir::Expr,
2625                       base_expr: &hir::Expr,
2626                       autoderef: &Autoderef<'a, 'gcx, 'tcx>,
2627                       needs: Needs,
2628                       index_ty: Ty<'tcx>)
2629                       -> Option<(/*index type*/ Ty<'tcx>, /*element type*/ Ty<'tcx>)>
2630     {
2631         let adjusted_ty = autoderef.unambiguous_final_ty(self);
2632         debug!("try_index_step(expr={:?}, base_expr={:?}, adjusted_ty={:?}, \
2633                                index_ty={:?})",
2634                expr,
2635                base_expr,
2636                adjusted_ty,
2637                index_ty);
2638
2639         for &unsize in &[false, true] {
2640             let mut self_ty = adjusted_ty;
2641             if unsize {
2642                 // We only unsize arrays here.
2643                 if let ty::Array(element_ty, _) = adjusted_ty.sty {
2644                     self_ty = self.tcx.mk_slice(element_ty);
2645                 } else {
2646                     continue;
2647                 }
2648             }
2649
2650             // If some lookup succeeds, write callee into table and extract index/element
2651             // type from the method signature.
2652             // If some lookup succeeded, install method in table
2653             let input_ty = self.next_ty_var(TypeVariableOrigin::AutoDeref(base_expr.span));
2654             let method = self.try_overloaded_place_op(
2655                 expr.span, self_ty, &[input_ty], needs, PlaceOp::Index);
2656
2657             let result = method.map(|ok| {
2658                 debug!("try_index_step: success, using overloaded indexing");
2659                 let method = self.register_infer_ok_obligations(ok);
2660
2661                 let mut adjustments = autoderef.adjust_steps(self, needs);
2662                 if let ty::Ref(region, _, r_mutbl) = method.sig.inputs()[0].sty {
2663                     let mutbl = match r_mutbl {
2664                         hir::MutImmutable => AutoBorrowMutability::Immutable,
2665                         hir::MutMutable => AutoBorrowMutability::Mutable {
2666                             // Indexing can be desugared to a method call,
2667                             // so maybe we could use two-phase here.
2668                             // See the documentation of AllowTwoPhase for why that's
2669                             // not the case today.
2670                             allow_two_phase_borrow: AllowTwoPhase::No,
2671                         }
2672                     };
2673                     adjustments.push(Adjustment {
2674                         kind: Adjust::Borrow(AutoBorrow::Ref(region, mutbl)),
2675                         target: self.tcx.mk_ref(region, ty::TypeAndMut {
2676                             mutbl: r_mutbl,
2677                             ty: adjusted_ty
2678                         })
2679                     });
2680                 }
2681                 if unsize {
2682                     adjustments.push(Adjustment {
2683                         kind: Adjust::Unsize,
2684                         target: method.sig.inputs()[0]
2685                     });
2686                 }
2687                 self.apply_adjustments(base_expr, adjustments);
2688
2689                 self.write_method_call(expr.hir_id, method);
2690                 (input_ty, self.make_overloaded_place_return_type(method).ty)
2691             });
2692             if result.is_some() {
2693                 return result;
2694             }
2695         }
2696
2697         None
2698     }
2699
2700     fn resolve_place_op(&self, op: PlaceOp, is_mut: bool) -> (Option<DefId>, ast::Ident) {
2701         let (tr, name) = match (op, is_mut) {
2702             (PlaceOp::Deref, false) =>
2703                 (self.tcx.lang_items().deref_trait(), "deref"),
2704             (PlaceOp::Deref, true) =>
2705                 (self.tcx.lang_items().deref_mut_trait(), "deref_mut"),
2706             (PlaceOp::Index, false) =>
2707                 (self.tcx.lang_items().index_trait(), "index"),
2708             (PlaceOp::Index, true) =>
2709                 (self.tcx.lang_items().index_mut_trait(), "index_mut"),
2710         };
2711         (tr, ast::Ident::from_str(name))
2712     }
2713
2714     fn try_overloaded_place_op(&self,
2715                                 span: Span,
2716                                 base_ty: Ty<'tcx>,
2717                                 arg_tys: &[Ty<'tcx>],
2718                                 needs: Needs,
2719                                 op: PlaceOp)
2720                                 -> Option<InferOk<'tcx, MethodCallee<'tcx>>>
2721     {
2722         debug!("try_overloaded_place_op({:?},{:?},{:?},{:?})",
2723                span,
2724                base_ty,
2725                needs,
2726                op);
2727
2728         // Try Mut first, if needed.
2729         let (mut_tr, mut_op) = self.resolve_place_op(op, true);
2730         let method = match (needs, mut_tr) {
2731             (Needs::MutPlace, Some(trait_did)) => {
2732                 self.lookup_method_in_trait(span, mut_op, trait_did, base_ty, Some(arg_tys))
2733             }
2734             _ => None,
2735         };
2736
2737         // Otherwise, fall back to the immutable version.
2738         let (imm_tr, imm_op) = self.resolve_place_op(op, false);
2739         let method = match (method, imm_tr) {
2740             (None, Some(trait_did)) => {
2741                 self.lookup_method_in_trait(span, imm_op, trait_did, base_ty, Some(arg_tys))
2742             }
2743             (method, _) => method,
2744         };
2745
2746         method
2747     }
2748
2749     fn check_method_argument_types(&self,
2750                                    sp: Span,
2751                                    expr_sp: Span,
2752                                    method: Result<MethodCallee<'tcx>, ()>,
2753                                    args_no_rcvr: &'gcx [hir::Expr],
2754                                    tuple_arguments: TupleArgumentsFlag,
2755                                    expected: Expectation<'tcx>)
2756                                    -> Ty<'tcx> {
2757         let has_error = match method {
2758             Ok(method) => {
2759                 method.substs.references_error() || method.sig.references_error()
2760             }
2761             Err(_) => true
2762         };
2763         if has_error {
2764             let err_inputs = self.err_args(args_no_rcvr.len());
2765
2766             let err_inputs = match tuple_arguments {
2767                 DontTupleArguments => err_inputs,
2768                 TupleArguments => vec![self.tcx.intern_tup(&err_inputs[..])],
2769             };
2770
2771             self.check_argument_types(sp, expr_sp, &err_inputs[..], &[], args_no_rcvr,
2772                                       false, tuple_arguments, None);
2773             return self.tcx.types.err;
2774         }
2775
2776         let method = method.unwrap();
2777         // HACK(eddyb) ignore self in the definition (see above).
2778         let expected_arg_tys = self.expected_inputs_for_expected_output(
2779             sp,
2780             expected,
2781             method.sig.output(),
2782             &method.sig.inputs()[1..]
2783         );
2784         self.check_argument_types(sp, expr_sp, &method.sig.inputs()[1..], &expected_arg_tys[..],
2785                                   args_no_rcvr, method.sig.variadic, tuple_arguments,
2786                                   self.tcx.hir().span_if_local(method.def_id));
2787         method.sig.output()
2788     }
2789
2790     fn self_type_matches_expected_vid(
2791         &self,
2792         trait_ref: ty::PolyTraitRef<'tcx>,
2793         expected_vid: ty::TyVid,
2794     ) -> bool {
2795         let self_ty = self.shallow_resolve(trait_ref.self_ty());
2796         debug!(
2797             "self_type_matches_expected_vid(trait_ref={:?}, self_ty={:?}, expected_vid={:?})",
2798             trait_ref, self_ty, expected_vid
2799         );
2800         match self_ty.sty {
2801             ty::Infer(ty::TyVar(found_vid)) => {
2802                 // FIXME: consider using `sub_root_var` here so we
2803                 // can see through subtyping.
2804                 let found_vid = self.root_var(found_vid);
2805                 debug!("self_type_matches_expected_vid - found_vid={:?}", found_vid);
2806                 expected_vid == found_vid
2807             }
2808             _ => false
2809         }
2810     }
2811
2812     fn obligations_for_self_ty<'b>(&'b self, self_ty: ty::TyVid)
2813         -> impl Iterator<Item=(ty::PolyTraitRef<'tcx>, traits::PredicateObligation<'tcx>)>
2814            + Captures<'gcx> + 'b
2815     {
2816         // FIXME: consider using `sub_root_var` here so we
2817         // can see through subtyping.
2818         let ty_var_root = self.root_var(self_ty);
2819         debug!("obligations_for_self_ty: self_ty={:?} ty_var_root={:?} pending_obligations={:?}",
2820                self_ty, ty_var_root,
2821                self.fulfillment_cx.borrow().pending_obligations());
2822
2823         self.fulfillment_cx
2824             .borrow()
2825             .pending_obligations()
2826             .into_iter()
2827             .filter_map(move |obligation| match obligation.predicate {
2828                 ty::Predicate::Projection(ref data) =>
2829                     Some((data.to_poly_trait_ref(self.tcx), obligation)),
2830                 ty::Predicate::Trait(ref data) =>
2831                     Some((data.to_poly_trait_ref(), obligation)),
2832                 ty::Predicate::Subtype(..) => None,
2833                 ty::Predicate::RegionOutlives(..) => None,
2834                 ty::Predicate::TypeOutlives(..) => None,
2835                 ty::Predicate::WellFormed(..) => None,
2836                 ty::Predicate::ObjectSafe(..) => None,
2837                 ty::Predicate::ConstEvaluatable(..) => None,
2838                 // N.B., this predicate is created by breaking down a
2839                 // `ClosureType: FnFoo()` predicate, where
2840                 // `ClosureType` represents some `Closure`. It can't
2841                 // possibly be referring to the current closure,
2842                 // because we haven't produced the `Closure` for
2843                 // this closure yet; this is exactly why the other
2844                 // code is looking for a self type of a unresolved
2845                 // inference variable.
2846                 ty::Predicate::ClosureKind(..) => None,
2847             }).filter(move |(tr, _)| self.self_type_matches_expected_vid(*tr, ty_var_root))
2848     }
2849
2850     fn type_var_is_sized(&self, self_ty: ty::TyVid) -> bool {
2851         self.obligations_for_self_ty(self_ty).any(|(tr, _)| {
2852             Some(tr.def_id()) == self.tcx.lang_items().sized_trait()
2853         })
2854     }
2855
2856     /// Generic function that factors out common logic from function calls,
2857     /// method calls and overloaded operators.
2858     fn check_argument_types(&self,
2859                             sp: Span,
2860                             expr_sp: Span,
2861                             fn_inputs: &[Ty<'tcx>],
2862                             mut expected_arg_tys: &[Ty<'tcx>],
2863                             args: &'gcx [hir::Expr],
2864                             variadic: bool,
2865                             tuple_arguments: TupleArgumentsFlag,
2866                             def_span: Option<Span>) {
2867         let tcx = self.tcx;
2868
2869         // Grab the argument types, supplying fresh type variables
2870         // if the wrong number of arguments were supplied
2871         let supplied_arg_count = if tuple_arguments == DontTupleArguments {
2872             args.len()
2873         } else {
2874             1
2875         };
2876
2877         // All the input types from the fn signature must outlive the call
2878         // so as to validate implied bounds.
2879         for &fn_input_ty in fn_inputs {
2880             self.register_wf_obligation(fn_input_ty, sp, traits::MiscObligation);
2881         }
2882
2883         let expected_arg_count = fn_inputs.len();
2884
2885         let param_count_error = |expected_count: usize,
2886                                  arg_count: usize,
2887                                  error_code: &str,
2888                                  variadic: bool,
2889                                  sugg_unit: bool| {
2890             let mut err = tcx.sess.struct_span_err_with_code(sp,
2891                 &format!("this function takes {}{} but {} {} supplied",
2892                     if variadic {"at least "} else {""},
2893                     potentially_plural_count(expected_count, "parameter"),
2894                     potentially_plural_count(arg_count, "parameter"),
2895                     if arg_count == 1 {"was"} else {"were"}),
2896                 DiagnosticId::Error(error_code.to_owned()));
2897
2898             if let Some(def_s) = def_span.map(|sp| tcx.sess.source_map().def_span(sp)) {
2899                 err.span_label(def_s, "defined here");
2900             }
2901             if sugg_unit {
2902                 let sugg_span = tcx.sess.source_map().end_point(expr_sp);
2903                 // remove closing `)` from the span
2904                 let sugg_span = sugg_span.shrink_to_lo();
2905                 err.span_suggestion(
2906                     sugg_span,
2907                     "expected the unit value `()`; create it with empty parentheses",
2908                     String::from("()"),
2909                     Applicability::MachineApplicable);
2910             } else {
2911                 err.span_label(sp, format!("expected {}{}",
2912                                            if variadic {"at least "} else {""},
2913                                            potentially_plural_count(expected_count, "parameter")));
2914             }
2915             err.emit();
2916         };
2917
2918         let formal_tys = if tuple_arguments == TupleArguments {
2919             let tuple_type = self.structurally_resolved_type(sp, fn_inputs[0]);
2920             match tuple_type.sty {
2921                 ty::Tuple(arg_types) if arg_types.len() != args.len() => {
2922                     param_count_error(arg_types.len(), args.len(), "E0057", false, false);
2923                     expected_arg_tys = &[];
2924                     self.err_args(args.len())
2925                 }
2926                 ty::Tuple(arg_types) => {
2927                     expected_arg_tys = match expected_arg_tys.get(0) {
2928                         Some(&ty) => match ty.sty {
2929                             ty::Tuple(ref tys) => &tys,
2930                             _ => &[]
2931                         },
2932                         None => &[]
2933                     };
2934                     arg_types.to_vec()
2935                 }
2936                 _ => {
2937                     span_err!(tcx.sess, sp, E0059,
2938                         "cannot use call notation; the first type parameter \
2939                          for the function trait is neither a tuple nor unit");
2940                     expected_arg_tys = &[];
2941                     self.err_args(args.len())
2942                 }
2943             }
2944         } else if expected_arg_count == supplied_arg_count {
2945             fn_inputs.to_vec()
2946         } else if variadic {
2947             if supplied_arg_count >= expected_arg_count {
2948                 fn_inputs.to_vec()
2949             } else {
2950                 param_count_error(expected_arg_count, supplied_arg_count, "E0060", true, false);
2951                 expected_arg_tys = &[];
2952                 self.err_args(supplied_arg_count)
2953             }
2954         } else {
2955             // is the missing argument of type `()`?
2956             let sugg_unit = if expected_arg_tys.len() == 1 && supplied_arg_count == 0 {
2957                 self.resolve_type_vars_if_possible(&expected_arg_tys[0]).is_unit()
2958             } else if fn_inputs.len() == 1 && supplied_arg_count == 0 {
2959                 self.resolve_type_vars_if_possible(&fn_inputs[0]).is_unit()
2960             } else {
2961                 false
2962             };
2963             param_count_error(expected_arg_count, supplied_arg_count, "E0061", false, sugg_unit);
2964
2965             expected_arg_tys = &[];
2966             self.err_args(supplied_arg_count)
2967         };
2968         // If there is no expectation, expect formal_tys.
2969         let expected_arg_tys = if !expected_arg_tys.is_empty() {
2970             expected_arg_tys
2971         } else {
2972             &formal_tys
2973         };
2974
2975         debug!("check_argument_types: formal_tys={:?}",
2976                formal_tys.iter().map(|t| self.ty_to_string(*t)).collect::<Vec<String>>());
2977
2978         // Check the arguments.
2979         // We do this in a pretty awful way: first we type-check any arguments
2980         // that are not closures, then we type-check the closures. This is so
2981         // that we have more information about the types of arguments when we
2982         // type-check the functions. This isn't really the right way to do this.
2983         for &check_closures in &[false, true] {
2984             debug!("check_closures={}", check_closures);
2985
2986             // More awful hacks: before we check argument types, try to do
2987             // an "opportunistic" vtable resolution of any trait bounds on
2988             // the call. This helps coercions.
2989             if check_closures {
2990                 self.select_obligations_where_possible(false);
2991             }
2992
2993             // For variadic functions, we don't have a declared type for all of
2994             // the arguments hence we only do our usual type checking with
2995             // the arguments who's types we do know.
2996             let t = if variadic {
2997                 expected_arg_count
2998             } else if tuple_arguments == TupleArguments {
2999                 args.len()
3000             } else {
3001                 supplied_arg_count
3002             };
3003             for (i, arg) in args.iter().take(t).enumerate() {
3004                 // Warn only for the first loop (the "no closures" one).
3005                 // Closure arguments themselves can't be diverging, but
3006                 // a previous argument can, e.g., `foo(panic!(), || {})`.
3007                 if !check_closures {
3008                     self.warn_if_unreachable(arg.id, arg.span, "expression");
3009                 }
3010
3011                 let is_closure = match arg.node {
3012                     ExprKind::Closure(..) => true,
3013                     _ => false
3014                 };
3015
3016                 if is_closure != check_closures {
3017                     continue;
3018                 }
3019
3020                 debug!("checking the argument");
3021                 let formal_ty = formal_tys[i];
3022
3023                 // The special-cased logic below has three functions:
3024                 // 1. Provide as good of an expected type as possible.
3025                 let expected = Expectation::rvalue_hint(self, expected_arg_tys[i]);
3026
3027                 let checked_ty = self.check_expr_with_expectation(&arg, expected);
3028
3029                 // 2. Coerce to the most detailed type that could be coerced
3030                 //    to, which is `expected_ty` if `rvalue_hint` returns an
3031                 //    `ExpectHasType(expected_ty)`, or the `formal_ty` otherwise.
3032                 let coerce_ty = expected.only_has_type(self).unwrap_or(formal_ty);
3033                 // We're processing function arguments so we definitely want to use
3034                 // two-phase borrows.
3035                 self.demand_coerce(&arg, checked_ty, coerce_ty, AllowTwoPhase::Yes);
3036
3037                 // 3. Relate the expected type and the formal one,
3038                 //    if the expected type was used for the coercion.
3039                 self.demand_suptype(arg.span, formal_ty, coerce_ty);
3040             }
3041         }
3042
3043         // We also need to make sure we at least write the ty of the other
3044         // arguments which we skipped above.
3045         if variadic {
3046             fn variadic_error<'tcx>(s: &Session, span: Span, t: Ty<'tcx>, cast_ty: &str) {
3047                 use structured_errors::{VariadicError, StructuredDiagnostic};
3048                 VariadicError::new(s, span, t, cast_ty).diagnostic().emit();
3049             }
3050
3051             for arg in args.iter().skip(expected_arg_count) {
3052                 let arg_ty = self.check_expr(&arg);
3053
3054                 // There are a few types which get autopromoted when passed via varargs
3055                 // in C but we just error out instead and require explicit casts.
3056                 let arg_ty = self.structurally_resolved_type(arg.span, arg_ty);
3057                 match arg_ty.sty {
3058                     ty::Float(ast::FloatTy::F32) => {
3059                         variadic_error(tcx.sess, arg.span, arg_ty, "c_double");
3060                     }
3061                     ty::Int(ast::IntTy::I8) | ty::Int(ast::IntTy::I16) | ty::Bool => {
3062                         variadic_error(tcx.sess, arg.span, arg_ty, "c_int");
3063                     }
3064                     ty::Uint(ast::UintTy::U8) | ty::Uint(ast::UintTy::U16) => {
3065                         variadic_error(tcx.sess, arg.span, arg_ty, "c_uint");
3066                     }
3067                     ty::FnDef(..) => {
3068                         let ptr_ty = self.tcx.mk_fn_ptr(arg_ty.fn_sig(self.tcx));
3069                         let ptr_ty = self.resolve_type_vars_if_possible(&ptr_ty);
3070                         variadic_error(tcx.sess, arg.span, arg_ty, &ptr_ty.to_string());
3071                     }
3072                     _ => {}
3073                 }
3074             }
3075         }
3076     }
3077
3078     fn err_args(&self, len: usize) -> Vec<Ty<'tcx>> {
3079         vec![self.tcx.types.err; len]
3080     }
3081
3082     // AST fragment checking
3083     fn check_lit(&self,
3084                  lit: &ast::Lit,
3085                  expected: Expectation<'tcx>)
3086                  -> Ty<'tcx>
3087     {
3088         let tcx = self.tcx;
3089
3090         match lit.node {
3091             ast::LitKind::Str(..) => tcx.mk_static_str(),
3092             ast::LitKind::ByteStr(ref v) => {
3093                 tcx.mk_imm_ref(tcx.types.re_static,
3094                                tcx.mk_array(tcx.types.u8, v.len() as u64))
3095             }
3096             ast::LitKind::Byte(_) => tcx.types.u8,
3097             ast::LitKind::Char(_) => tcx.types.char,
3098             ast::LitKind::Int(_, ast::LitIntType::Signed(t)) => tcx.mk_mach_int(t),
3099             ast::LitKind::Int(_, ast::LitIntType::Unsigned(t)) => tcx.mk_mach_uint(t),
3100             ast::LitKind::Int(_, ast::LitIntType::Unsuffixed) => {
3101                 let opt_ty = expected.to_option(self).and_then(|ty| {
3102                     match ty.sty {
3103                         ty::Int(_) | ty::Uint(_) => Some(ty),
3104                         ty::Char => Some(tcx.types.u8),
3105                         ty::RawPtr(..) => Some(tcx.types.usize),
3106                         ty::FnDef(..) | ty::FnPtr(_) => Some(tcx.types.usize),
3107                         _ => None
3108                     }
3109                 });
3110                 opt_ty.unwrap_or_else(
3111                     || tcx.mk_int_var(self.next_int_var_id()))
3112             }
3113             ast::LitKind::Float(_, t) => tcx.mk_mach_float(t),
3114             ast::LitKind::FloatUnsuffixed(_) => {
3115                 let opt_ty = expected.to_option(self).and_then(|ty| {
3116                     match ty.sty {
3117                         ty::Float(_) => Some(ty),
3118                         _ => None
3119                     }
3120                 });
3121                 opt_ty.unwrap_or_else(
3122                     || tcx.mk_float_var(self.next_float_var_id()))
3123             }
3124             ast::LitKind::Bool(_) => tcx.types.bool,
3125             ast::LitKind::Err(_) => tcx.types.err,
3126         }
3127     }
3128
3129     fn check_expr_eq_type(&self,
3130                           expr: &'gcx hir::Expr,
3131                           expected: Ty<'tcx>) {
3132         let ty = self.check_expr_with_hint(expr, expected);
3133         self.demand_eqtype(expr.span, expected, ty);
3134     }
3135
3136     pub fn check_expr_has_type_or_error(&self,
3137                                         expr: &'gcx hir::Expr,
3138                                         expected: Ty<'tcx>) -> Ty<'tcx> {
3139         self.check_expr_meets_expectation_or_error(expr, ExpectHasType(expected))
3140     }
3141
3142     fn check_expr_meets_expectation_or_error(&self,
3143                                              expr: &'gcx hir::Expr,
3144                                              expected: Expectation<'tcx>) -> Ty<'tcx> {
3145         let expected_ty = expected.to_option(&self).unwrap_or(self.tcx.types.bool);
3146         let mut ty = self.check_expr_with_expectation(expr, expected);
3147
3148         // While we don't allow *arbitrary* coercions here, we *do* allow
3149         // coercions from ! to `expected`.
3150         if ty.is_never() {
3151             assert!(!self.tables.borrow().adjustments().contains_key(expr.hir_id),
3152                     "expression with never type wound up being adjusted");
3153             let adj_ty = self.next_diverging_ty_var(
3154                 TypeVariableOrigin::AdjustmentType(expr.span));
3155             self.apply_adjustments(expr, vec![Adjustment {
3156                 kind: Adjust::NeverToAny,
3157                 target: adj_ty
3158             }]);
3159             ty = adj_ty;
3160         }
3161
3162         if let Some(mut err) = self.demand_suptype_diag(expr.span, expected_ty, ty) {
3163             // Add help to type error if this is an `if` condition with an assignment.
3164             if let (ExpectIfCondition, &ExprKind::Assign(ref lhs, ref rhs))
3165                  = (expected, &expr.node)
3166             {
3167                 let msg = "try comparing for equality";
3168                 if let (Ok(left), Ok(right)) = (
3169                     self.tcx.sess.source_map().span_to_snippet(lhs.span),
3170                     self.tcx.sess.source_map().span_to_snippet(rhs.span))
3171                 {
3172                     err.span_suggestion(
3173                         expr.span,
3174                         msg,
3175                         format!("{} == {}", left, right),
3176                         Applicability::MaybeIncorrect);
3177                 } else {
3178                     err.help(msg);
3179                 }
3180             }
3181             err.emit();
3182         }
3183         ty
3184     }
3185
3186     fn check_expr_coercable_to_type(&self,
3187                                     expr: &'gcx hir::Expr,
3188                                     expected: Ty<'tcx>) -> Ty<'tcx> {
3189         let ty = self.check_expr_with_hint(expr, expected);
3190         // checks don't need two phase
3191         self.demand_coerce(expr, ty, expected, AllowTwoPhase::No)
3192     }
3193
3194     fn check_expr_with_hint(&self,
3195                             expr: &'gcx hir::Expr,
3196                             expected: Ty<'tcx>) -> Ty<'tcx> {
3197         self.check_expr_with_expectation(expr, ExpectHasType(expected))
3198     }
3199
3200     fn check_expr_with_expectation(&self,
3201                                    expr: &'gcx hir::Expr,
3202                                    expected: Expectation<'tcx>) -> Ty<'tcx> {
3203         self.check_expr_with_expectation_and_needs(expr, expected, Needs::None)
3204     }
3205
3206     fn check_expr(&self, expr: &'gcx hir::Expr) -> Ty<'tcx> {
3207         self.check_expr_with_expectation(expr, NoExpectation)
3208     }
3209
3210     fn check_expr_with_needs(&self, expr: &'gcx hir::Expr, needs: Needs) -> Ty<'tcx> {
3211         self.check_expr_with_expectation_and_needs(expr, NoExpectation, needs)
3212     }
3213
3214     // Determine the `Self` type, using fresh variables for all variables
3215     // declared on the impl declaration e.g., `impl<A,B> for Vec<(A,B)>`
3216     // would return `($0, $1)` where `$0` and `$1` are freshly instantiated type
3217     // variables.
3218     pub fn impl_self_ty(&self,
3219                         span: Span, // (potential) receiver for this impl
3220                         did: DefId)
3221                         -> TypeAndSubsts<'tcx> {
3222         let ity = self.tcx.type_of(did);
3223         debug!("impl_self_ty: ity={:?}", ity);
3224
3225         let substs = self.fresh_substs_for_item(span, did);
3226         let substd_ty = self.instantiate_type_scheme(span, &substs, &ity);
3227
3228         TypeAndSubsts { substs: substs, ty: substd_ty }
3229     }
3230
3231     /// Unifies the output type with the expected type early, for more coercions
3232     /// and forward type information on the input expressions.
3233     fn expected_inputs_for_expected_output(&self,
3234                                            call_span: Span,
3235                                            expected_ret: Expectation<'tcx>,
3236                                            formal_ret: Ty<'tcx>,
3237                                            formal_args: &[Ty<'tcx>])
3238                                            -> Vec<Ty<'tcx>> {
3239         let formal_ret = self.resolve_type_vars_with_obligations(formal_ret);
3240         let ret_ty = match expected_ret.only_has_type(self) {
3241             Some(ret) => ret,
3242             None => return Vec::new()
3243         };
3244         let expect_args = self.fudge_regions_if_ok(&RegionVariableOrigin::Coercion(call_span), || {
3245             // Attempt to apply a subtyping relationship between the formal
3246             // return type (likely containing type variables if the function
3247             // is polymorphic) and the expected return type.
3248             // No argument expectations are produced if unification fails.
3249             let origin = self.misc(call_span);
3250             let ures = self.at(&origin, self.param_env).sup(ret_ty, &formal_ret);
3251
3252             // FIXME(#27336) can't use ? here, Try::from_error doesn't default
3253             // to identity so the resulting type is not constrained.
3254             match ures {
3255                 Ok(ok) => {
3256                     // Process any obligations locally as much as
3257                     // we can.  We don't care if some things turn
3258                     // out unconstrained or ambiguous, as we're
3259                     // just trying to get hints here.
3260                     self.save_and_restore_in_snapshot_flag(|_| {
3261                         let mut fulfill = TraitEngine::new(self.tcx);
3262                         for obligation in ok.obligations {
3263                             fulfill.register_predicate_obligation(self, obligation);
3264                         }
3265                         fulfill.select_where_possible(self)
3266                     }).map_err(|_| ())?;
3267                 }
3268                 Err(_) => return Err(()),
3269             }
3270
3271             // Record all the argument types, with the substitutions
3272             // produced from the above subtyping unification.
3273             Ok(formal_args.iter().map(|ty| {
3274                 self.resolve_type_vars_if_possible(ty)
3275             }).collect())
3276         }).unwrap_or_default();
3277         debug!("expected_inputs_for_expected_output(formal={:?} -> {:?}, expected={:?} -> {:?})",
3278                formal_args, formal_ret,
3279                expect_args, expected_ret);
3280         expect_args
3281     }
3282
3283     // Checks a method call.
3284     fn check_method_call(&self,
3285                          expr: &'gcx hir::Expr,
3286                          segment: &hir::PathSegment,
3287                          span: Span,
3288                          args: &'gcx [hir::Expr],
3289                          expected: Expectation<'tcx>,
3290                          needs: Needs) -> Ty<'tcx> {
3291         let rcvr = &args[0];
3292         let rcvr_t = self.check_expr_with_needs(&rcvr, needs);
3293         // no need to check for bot/err -- callee does that
3294         let rcvr_t = self.structurally_resolved_type(args[0].span, rcvr_t);
3295
3296         let method = match self.lookup_method(rcvr_t,
3297                                               segment,
3298                                               span,
3299                                               expr,
3300                                               rcvr) {
3301             Ok(method) => {
3302                 self.write_method_call(expr.hir_id, method);
3303                 Ok(method)
3304             }
3305             Err(error) => {
3306                 if segment.ident.name != keywords::Invalid.name() {
3307                     self.report_method_error(span,
3308                                              rcvr_t,
3309                                              segment.ident,
3310                                              SelfSource::MethodCall(rcvr),
3311                                              error,
3312                                              Some(args));
3313                 }
3314                 Err(())
3315             }
3316         };
3317
3318         // Call the generic checker.
3319         self.check_method_argument_types(span,
3320                                          expr.span,
3321                                          method,
3322                                          &args[1..],
3323                                          DontTupleArguments,
3324                                          expected)
3325     }
3326
3327     fn check_return_expr(&self, return_expr: &'gcx hir::Expr) {
3328         let ret_coercion =
3329             self.ret_coercion
3330                 .as_ref()
3331                 .unwrap_or_else(|| span_bug!(return_expr.span,
3332                                              "check_return_expr called outside fn body"));
3333
3334         let ret_ty = ret_coercion.borrow().expected_ty();
3335         let return_expr_ty = self.check_expr_with_hint(return_expr, ret_ty.clone());
3336         ret_coercion.borrow_mut()
3337                     .coerce(self,
3338                             &self.cause(return_expr.span,
3339                                         ObligationCauseCode::ReturnType(return_expr.id)),
3340                             return_expr,
3341                             return_expr_ty);
3342     }
3343
3344     // A generic function for checking the 'then' and 'else' clauses in an 'if'
3345     // or 'if-else' expression.
3346     fn check_then_else(&self,
3347                        cond_expr: &'gcx hir::Expr,
3348                        then_expr: &'gcx hir::Expr,
3349                        opt_else_expr: Option<&'gcx hir::Expr>,
3350                        sp: Span,
3351                        expected: Expectation<'tcx>) -> Ty<'tcx> {
3352         let cond_ty = self.check_expr_meets_expectation_or_error(cond_expr, ExpectIfCondition);
3353         let cond_diverges = self.diverges.get();
3354         self.diverges.set(Diverges::Maybe);
3355
3356         let expected = expected.adjust_for_branches(self);
3357         let then_ty = self.check_expr_with_expectation(then_expr, expected);
3358         let then_diverges = self.diverges.get();
3359         self.diverges.set(Diverges::Maybe);
3360
3361         // We've already taken the expected type's preferences
3362         // into account when typing the `then` branch. To figure
3363         // out the initial shot at a LUB, we thus only consider
3364         // `expected` if it represents a *hard* constraint
3365         // (`only_has_type`); otherwise, we just go with a
3366         // fresh type variable.
3367         let coerce_to_ty = expected.coercion_target_type(self, sp);
3368         let mut coerce: DynamicCoerceMany = CoerceMany::new(coerce_to_ty);
3369
3370         coerce.coerce(self, &self.misc(sp), then_expr, then_ty);
3371
3372         if let Some(else_expr) = opt_else_expr {
3373             let else_ty = self.check_expr_with_expectation(else_expr, expected);
3374             let else_diverges = self.diverges.get();
3375
3376             let mut outer_sp = if self.tcx.sess.source_map().is_multiline(sp) {
3377                 // The `if`/`else` isn't in one line in the output, include some context to make it
3378                 // clear it is an if/else expression:
3379                 // ```
3380                 // LL |      let x = if true {
3381                 //    | _____________-
3382                 // LL ||         10i32
3383                 //    ||         ----- expected because of this
3384                 // LL ||     } else {
3385                 // LL ||         10u32
3386                 //    ||         ^^^^^ expected i32, found u32
3387                 // LL ||     };
3388                 //    ||_____- if and else have incompatible types
3389                 // ```
3390                 Some(sp)
3391             } else {
3392                 // The entire expression is in one line, only point at the arms
3393                 // ```
3394                 // LL |     let x = if true { 10i32 } else { 10u32 };
3395                 //    |                       -----          ^^^^^ expected i32, found u32
3396                 //    |                       |
3397                 //    |                       expected because of this
3398                 // ```
3399                 None
3400             };
3401             let mut remove_semicolon = None;
3402             let error_sp = if let ExprKind::Block(block, _) = &else_expr.node {
3403                 if let Some(expr) = &block.expr {
3404                     expr.span
3405                 } else if let Some(stmt) = block.stmts.last() {
3406                     // possibly incorrect trailing `;` in the else arm
3407                     remove_semicolon = self.could_remove_semicolon(block, then_ty);
3408                     stmt.span
3409                 } else {  // empty block, point at its entirety
3410                     // Avoid overlapping spans that aren't as readable:
3411                     // ```
3412                     // 2 |        let x = if true {
3413                     //   |   _____________-
3414                     // 3 |  |         3
3415                     //   |  |         - expected because of this
3416                     // 4 |  |     } else {
3417                     //   |  |____________^
3418                     // 5 | ||
3419                     // 6 | ||     };
3420                     //   | ||     ^
3421                     //   | ||_____|
3422                     //   | |______if and else have incompatible types
3423                     //   |        expected integer, found ()
3424                     // ```
3425                     // by not pointing at the entire expression:
3426                     // ```
3427                     // 2 |       let x = if true {
3428                     //   |               ------- if and else have incompatible types
3429                     // 3 |           3
3430                     //   |           - expected because of this
3431                     // 4 |       } else {
3432                     //   |  ____________^
3433                     // 5 | |
3434                     // 6 | |     };
3435                     //   | |_____^ expected integer, found ()
3436                     // ```
3437                     if outer_sp.is_some() {
3438                         outer_sp = Some(self.tcx.sess.source_map().def_span(sp));
3439                     }
3440                     else_expr.span
3441                 }
3442             } else { // shouldn't happen unless the parser has done something weird
3443                 else_expr.span
3444             };
3445             let then_sp = if let ExprKind::Block(block, _) = &then_expr.node {
3446                 if let Some(expr) = &block.expr {
3447                     expr.span
3448                 } else if let Some(stmt) = block.stmts.last() {
3449                     // possibly incorrect trailing `;` in the else arm
3450                     remove_semicolon = remove_semicolon.or(
3451                         self.could_remove_semicolon(block, else_ty));
3452                     stmt.span
3453                 } else {  // empty block, point at its entirety
3454                     outer_sp = None;  // same as in `error_sp`, cleanup output
3455                     then_expr.span
3456                 }
3457             } else {  // shouldn't happen unless the parser has done something weird
3458                 then_expr.span
3459             };
3460
3461             let if_cause = self.cause(error_sp, ObligationCauseCode::IfExpression {
3462                 then: then_sp,
3463                 outer: outer_sp,
3464                 semicolon: remove_semicolon,
3465             });
3466
3467             coerce.coerce(self, &if_cause, else_expr, else_ty);
3468
3469             // We won't diverge unless both branches do (or the condition does).
3470             self.diverges.set(cond_diverges | then_diverges & else_diverges);
3471         } else {
3472             let else_cause = self.cause(sp, ObligationCauseCode::IfExpressionWithNoElse);
3473             coerce.coerce_forced_unit(self, &else_cause, &mut |_| (), true);
3474
3475             // If the condition is false we can't diverge.
3476             self.diverges.set(cond_diverges);
3477         }
3478
3479         let result_ty = coerce.complete(self);
3480         if cond_ty.references_error() {
3481             self.tcx.types.err
3482         } else {
3483             result_ty
3484         }
3485     }
3486
3487     // Check field access expressions
3488     fn check_field(&self,
3489                    expr: &'gcx hir::Expr,
3490                    needs: Needs,
3491                    base: &'gcx hir::Expr,
3492                    field: ast::Ident) -> Ty<'tcx> {
3493         let expr_t = self.check_expr_with_needs(base, needs);
3494         let expr_t = self.structurally_resolved_type(base.span,
3495                                                      expr_t);
3496         let mut private_candidate = None;
3497         let mut autoderef = self.autoderef(expr.span, expr_t);
3498         while let Some((base_t, _)) = autoderef.next() {
3499             match base_t.sty {
3500                 ty::Adt(base_def, substs) if !base_def.is_enum() => {
3501                     debug!("struct named {:?}",  base_t);
3502                     let (ident, def_scope) =
3503                         self.tcx.adjust_ident(field, base_def.did, self.body_id);
3504                     let fields = &base_def.non_enum_variant().fields;
3505                     if let Some(index) = fields.iter().position(|f| f.ident.modern() == ident) {
3506                         let field = &fields[index];
3507                         let field_ty = self.field_ty(expr.span, field, substs);
3508                         // Save the index of all fields regardless of their visibility in case
3509                         // of error recovery.
3510                         self.write_field_index(expr.id, index);
3511                         if field.vis.is_accessible_from(def_scope, self.tcx) {
3512                             let adjustments = autoderef.adjust_steps(self, needs);
3513                             self.apply_adjustments(base, adjustments);
3514                             autoderef.finalize(self);
3515
3516                             self.tcx.check_stability(field.did, Some(expr.id), expr.span);
3517                             return field_ty;
3518                         }
3519                         private_candidate = Some((base_def.did, field_ty));
3520                     }
3521                 }
3522                 ty::Tuple(ref tys) => {
3523                     let fstr = field.as_str();
3524                     if let Ok(index) = fstr.parse::<usize>() {
3525                         if fstr == index.to_string() {
3526                             if let Some(field_ty) = tys.get(index) {
3527                                 let adjustments = autoderef.adjust_steps(self, needs);
3528                                 self.apply_adjustments(base, adjustments);
3529                                 autoderef.finalize(self);
3530
3531                                 self.write_field_index(expr.id, index);
3532                                 return field_ty;
3533                             }
3534                         }
3535                     }
3536                 }
3537                 _ => {}
3538             }
3539         }
3540         autoderef.unambiguous_final_ty(self);
3541
3542         if let Some((did, field_ty)) = private_candidate {
3543             let struct_path = self.tcx().item_path_str(did);
3544             let mut err = struct_span_err!(self.tcx().sess, expr.span, E0616,
3545                                            "field `{}` of struct `{}` is private",
3546                                            field, struct_path);
3547             // Also check if an accessible method exists, which is often what is meant.
3548             if self.method_exists(field, expr_t, expr.id, false) && !self.expr_in_place(expr.id) {
3549                 self.suggest_method_call(
3550                     &mut err,
3551                     &format!("a method `{}` also exists, call it with parentheses", field),
3552                     field,
3553                     expr_t,
3554                     expr.id,
3555                 );
3556             }
3557             err.emit();
3558             field_ty
3559         } else if field.name == keywords::Invalid.name() {
3560             self.tcx().types.err
3561         } else if self.method_exists(field, expr_t, expr.id, true) {
3562             let mut err = type_error_struct!(self.tcx().sess, field.span, expr_t, E0615,
3563                                "attempted to take value of method `{}` on type `{}`",
3564                                field, expr_t);
3565
3566             if !self.expr_in_place(expr.id) {
3567                 self.suggest_method_call(
3568                     &mut err,
3569                     "use parentheses to call the method",
3570                     field,
3571                     expr_t,
3572                     expr.id
3573                 );
3574             } else {
3575                 err.help("methods are immutable and cannot be assigned to");
3576             }
3577
3578             err.emit();
3579             self.tcx().types.err
3580         } else {
3581             if !expr_t.is_primitive_ty() {
3582                 let mut err = self.no_such_field_err(field.span, field, expr_t);
3583
3584                 match expr_t.sty {
3585                     ty::Adt(def, _) if !def.is_enum() => {
3586                         if let Some(suggested_field_name) =
3587                             Self::suggest_field_name(def.non_enum_variant(),
3588                                                      &field.as_str(), vec![]) {
3589                                 err.span_suggestion(
3590                                     field.span,
3591                                     "a field with a similar name exists",
3592                                     suggested_field_name.to_string(),
3593                                     Applicability::MaybeIncorrect,
3594                                 );
3595                             } else {
3596                                 err.span_label(field.span, "unknown field");
3597                                 let struct_variant_def = def.non_enum_variant();
3598                                 let field_names = self.available_field_names(struct_variant_def);
3599                                 if !field_names.is_empty() {
3600                                     err.note(&format!("available fields are: {}",
3601                                                       self.name_series_display(field_names)));
3602                                 }
3603                             };
3604                     }
3605                     ty::Array(_, len) => {
3606                         if let (Some(len), Ok(user_index)) = (
3607                             len.assert_usize(self.tcx),
3608                             field.as_str().parse::<u64>()
3609                         ) {
3610                             let base = self.tcx.sess.source_map()
3611                                 .span_to_snippet(base.span)
3612                                 .unwrap_or_else(|_| self.tcx.hir().node_to_pretty_string(base.id));
3613                             let help = "instead of using tuple indexing, use array indexing";
3614                             let suggestion = format!("{}[{}]", base, field);
3615                             let applicability = if len < user_index {
3616                                 Applicability::MachineApplicable
3617                             } else {
3618                                 Applicability::MaybeIncorrect
3619                             };
3620                             err.span_suggestion(
3621                                 expr.span, help, suggestion, applicability
3622                             );
3623                         }
3624                     }
3625                     ty::RawPtr(..) => {
3626                         let base = self.tcx.sess.source_map()
3627                             .span_to_snippet(base.span)
3628                             .unwrap_or_else(|_| self.tcx.hir().node_to_pretty_string(base.id));
3629                         let msg = format!("`{}` is a raw pointer; try dereferencing it", base);
3630                         let suggestion = format!("(*{}).{}", base, field);
3631                         err.span_suggestion(
3632                             expr.span,
3633                             &msg,
3634                             suggestion,
3635                             Applicability::MaybeIncorrect,
3636                         );
3637                     }
3638                     _ => {}
3639                 }
3640                 err
3641             } else {
3642                 type_error_struct!(self.tcx().sess, field.span, expr_t, E0610,
3643                                    "`{}` is a primitive type and therefore doesn't have fields",
3644                                    expr_t)
3645             }.emit();
3646             self.tcx().types.err
3647         }
3648     }
3649
3650     // Return an hint about the closest match in field names
3651     fn suggest_field_name(variant: &'tcx ty::VariantDef,
3652                           field: &str,
3653                           skip: Vec<LocalInternedString>)
3654                           -> Option<Symbol> {
3655         let names = variant.fields.iter().filter_map(|field| {
3656             // ignore already set fields and private fields from non-local crates
3657             if skip.iter().any(|x| *x == field.ident.as_str()) ||
3658                (variant.did.krate != LOCAL_CRATE && field.vis != Visibility::Public) {
3659                 None
3660             } else {
3661                 Some(&field.ident.name)
3662             }
3663         });
3664
3665         find_best_match_for_name(names, field, None)
3666     }
3667
3668     fn available_field_names(&self, variant: &'tcx ty::VariantDef) -> Vec<ast::Name> {
3669         variant.fields.iter().filter(|field| {
3670             let def_scope = self.tcx.adjust_ident(field.ident, variant.did, self.body_id).1;
3671             field.vis.is_accessible_from(def_scope, self.tcx)
3672         })
3673         .map(|field| field.ident.name)
3674         .collect()
3675     }
3676
3677     fn name_series_display(&self, names: Vec<ast::Name>) -> String {
3678         // dynamic limit, to never omit just one field
3679         let limit = if names.len() == 6 { 6 } else { 5 };
3680         let mut display = names.iter().take(limit)
3681             .map(|n| format!("`{}`", n)).collect::<Vec<_>>().join(", ");
3682         if names.len() > limit {
3683             display = format!("{} ... and {} others", display, names.len() - limit);
3684         }
3685         display
3686     }
3687
3688     fn no_such_field_err<T: Display>(&self, span: Span, field: T, expr_t: &ty::TyS)
3689         -> DiagnosticBuilder {
3690         type_error_struct!(self.tcx().sess, span, expr_t, E0609,
3691                            "no field `{}` on type `{}`",
3692                            field, expr_t)
3693     }
3694
3695     fn report_unknown_field(&self,
3696                             ty: Ty<'tcx>,
3697                             variant: &'tcx ty::VariantDef,
3698                             field: &hir::Field,
3699                             skip_fields: &[hir::Field],
3700                             kind_name: &str) {
3701         let mut err = self.type_error_struct_with_diag(
3702             field.ident.span,
3703             |actual| match ty.sty {
3704                 ty::Adt(adt, ..) if adt.is_enum() => {
3705                     struct_span_err!(self.tcx.sess, field.ident.span, E0559,
3706                                      "{} `{}::{}` has no field named `{}`",
3707                                      kind_name, actual, variant.ident, field.ident)
3708                 }
3709                 _ => {
3710                     struct_span_err!(self.tcx.sess, field.ident.span, E0560,
3711                                      "{} `{}` has no field named `{}`",
3712                                      kind_name, actual, field.ident)
3713                 }
3714             },
3715             ty);
3716         // prevent all specified fields from being suggested
3717         let skip_fields = skip_fields.iter().map(|ref x| x.ident.as_str());
3718         if let Some(field_name) = Self::suggest_field_name(variant,
3719                                                            &field.ident.as_str(),
3720                                                            skip_fields.collect()) {
3721             err.span_suggestion(
3722                 field.ident.span,
3723                 "a field with a similar name exists",
3724                 field_name.to_string(),
3725                 Applicability::MaybeIncorrect,
3726             );
3727         } else {
3728             match ty.sty {
3729                 ty::Adt(adt, ..) => {
3730                     if adt.is_enum() {
3731                         err.span_label(field.ident.span,
3732                                        format!("`{}::{}` does not have this field",
3733                                                ty, variant.ident));
3734                     } else {
3735                         err.span_label(field.ident.span,
3736                                        format!("`{}` does not have this field", ty));
3737                     }
3738                     let available_field_names = self.available_field_names(variant);
3739                     if !available_field_names.is_empty() {
3740                         err.note(&format!("available fields are: {}",
3741                                           self.name_series_display(available_field_names)));
3742                     }
3743                 }
3744                 _ => bug!("non-ADT passed to report_unknown_field")
3745             }
3746         };
3747         err.emit();
3748     }
3749
3750     fn check_expr_struct_fields(&self,
3751                                 adt_ty: Ty<'tcx>,
3752                                 expected: Expectation<'tcx>,
3753                                 expr_id: ast::NodeId,
3754                                 span: Span,
3755                                 variant: &'tcx ty::VariantDef,
3756                                 ast_fields: &'gcx [hir::Field],
3757                                 check_completeness: bool) -> bool {
3758         let tcx = self.tcx;
3759
3760         let adt_ty_hint =
3761             self.expected_inputs_for_expected_output(span, expected, adt_ty, &[adt_ty])
3762                 .get(0).cloned().unwrap_or(adt_ty);
3763         // re-link the regions that EIfEO can erase.
3764         self.demand_eqtype(span, adt_ty_hint, adt_ty);
3765
3766         let (substs, adt_kind, kind_name) = match &adt_ty.sty {
3767             &ty::Adt(adt, substs) => {
3768                 (substs, adt.adt_kind(), adt.variant_descr())
3769             }
3770             _ => span_bug!(span, "non-ADT passed to check_expr_struct_fields")
3771         };
3772
3773         let mut remaining_fields = variant.fields.iter().enumerate().map(|(i, field)|
3774             (field.ident.modern(), (i, field))
3775         ).collect::<FxHashMap<_, _>>();
3776
3777         let mut seen_fields = FxHashMap::default();
3778
3779         let mut error_happened = false;
3780
3781         // Type-check each field.
3782         for field in ast_fields {
3783             let ident = tcx.adjust_ident(field.ident, variant.did, self.body_id).0;
3784             let field_type = if let Some((i, v_field)) = remaining_fields.remove(&ident) {
3785                 seen_fields.insert(ident, field.span);
3786                 self.write_field_index(field.id, i);
3787
3788                 // We don't look at stability attributes on
3789                 // struct-like enums (yet...), but it's definitely not
3790                 // a bug to have constructed one.
3791                 if adt_kind != AdtKind::Enum {
3792                     tcx.check_stability(v_field.did, Some(expr_id), field.span);
3793                 }
3794
3795                 self.field_ty(field.span, v_field, substs)
3796             } else {
3797                 error_happened = true;
3798                 if let Some(prev_span) = seen_fields.get(&ident) {
3799                     let mut err = struct_span_err!(self.tcx.sess,
3800                                                    field.ident.span,
3801                                                    E0062,
3802                                                    "field `{}` specified more than once",
3803                                                    ident);
3804
3805                     err.span_label(field.ident.span, "used more than once");
3806                     err.span_label(*prev_span, format!("first use of `{}`", ident));
3807
3808                     err.emit();
3809                 } else {
3810                     self.report_unknown_field(adt_ty, variant, field, ast_fields, kind_name);
3811                 }
3812
3813                 tcx.types.err
3814             };
3815
3816             // Make sure to give a type to the field even if there's
3817             // an error, so we can continue type-checking.
3818             self.check_expr_coercable_to_type(&field.expr, field_type);
3819         }
3820
3821         // Make sure the programmer specified correct number of fields.
3822         if kind_name == "union" {
3823             if ast_fields.len() != 1 {
3824                 tcx.sess.span_err(span, "union expressions should have exactly one field");
3825             }
3826         } else if check_completeness && !error_happened && !remaining_fields.is_empty() {
3827             let len = remaining_fields.len();
3828
3829             let mut displayable_field_names = remaining_fields
3830                                               .keys()
3831                                               .map(|ident| ident.as_str())
3832                                               .collect::<Vec<_>>();
3833
3834             displayable_field_names.sort();
3835
3836             let truncated_fields_error = if len <= 3 {
3837                 String::new()
3838             } else {
3839                 format!(" and {} other field{}", (len - 3), if len - 3 == 1 {""} else {"s"})
3840             };
3841
3842             let remaining_fields_names = displayable_field_names.iter().take(3)
3843                                         .map(|n| format!("`{}`", n))
3844                                         .collect::<Vec<_>>()
3845                                         .join(", ");
3846
3847             struct_span_err!(tcx.sess, span, E0063,
3848                              "missing field{} {}{} in initializer of `{}`",
3849                              if remaining_fields.len() == 1 { "" } else { "s" },
3850                              remaining_fields_names,
3851                              truncated_fields_error,
3852                              adt_ty)
3853                 .span_label(span, format!("missing {}{}",
3854                                           remaining_fields_names,
3855                                           truncated_fields_error))
3856                 .emit();
3857         }
3858         error_happened
3859     }
3860
3861     fn check_struct_fields_on_error(&self,
3862                                     fields: &'gcx [hir::Field],
3863                                     base_expr: &'gcx Option<P<hir::Expr>>) {
3864         for field in fields {
3865             self.check_expr(&field.expr);
3866         }
3867         if let Some(ref base) = *base_expr {
3868             self.check_expr(&base);
3869         }
3870     }
3871
3872     pub fn check_struct_path(&self,
3873                              qpath: &QPath,
3874                              node_id: ast::NodeId)
3875                              -> Option<(&'tcx ty::VariantDef,  Ty<'tcx>)> {
3876         let path_span = match *qpath {
3877             QPath::Resolved(_, ref path) => path.span,
3878             QPath::TypeRelative(ref qself, _) => qself.span
3879         };
3880         let (def, ty) = self.finish_resolving_struct_path(qpath, path_span, node_id);
3881         let variant = match def {
3882             Def::Err => {
3883                 self.set_tainted_by_errors();
3884                 return None;
3885             }
3886             Def::Variant(..) => {
3887                 match ty.sty {
3888                     ty::Adt(adt, substs) => {
3889                         Some((adt.variant_of_def(def), adt.did, substs))
3890                     }
3891                     _ => bug!("unexpected type: {:?}", ty.sty)
3892                 }
3893             }
3894             Def::Struct(..) | Def::Union(..) | Def::TyAlias(..) |
3895             Def::AssociatedTy(..) | Def::SelfTy(..) => {
3896                 match ty.sty {
3897                     ty::Adt(adt, substs) if !adt.is_enum() => {
3898                         Some((adt.non_enum_variant(), adt.did, substs))
3899                     }
3900                     _ => None,
3901                 }
3902             }
3903             _ => bug!("unexpected definition: {:?}", def)
3904         };
3905
3906         if let Some((variant, did, substs)) = variant {
3907             debug!("check_struct_path: did={:?} substs={:?}", did, substs);
3908             let hir_id = self.tcx.hir().node_to_hir_id(node_id);
3909             self.write_user_type_annotation_from_substs(hir_id, did, substs, None);
3910
3911             // Check bounds on type arguments used in the path.
3912             let bounds = self.instantiate_bounds(path_span, did, substs);
3913             let cause = traits::ObligationCause::new(path_span, self.body_id,
3914                                                      traits::ItemObligation(did));
3915             self.add_obligations_for_parameters(cause, &bounds);
3916
3917             Some((variant, ty))
3918         } else {
3919             struct_span_err!(self.tcx.sess, path_span, E0071,
3920                              "expected struct, variant or union type, found {}",
3921                              ty.sort_string(self.tcx))
3922                 .span_label(path_span, "not a struct")
3923                 .emit();
3924             None
3925         }
3926     }
3927
3928     fn check_expr_struct(&self,
3929                          expr: &hir::Expr,
3930                          expected: Expectation<'tcx>,
3931                          qpath: &QPath,
3932                          fields: &'gcx [hir::Field],
3933                          base_expr: &'gcx Option<P<hir::Expr>>) -> Ty<'tcx>
3934     {
3935         // Find the relevant variant
3936         let (variant, adt_ty) =
3937             if let Some(variant_ty) = self.check_struct_path(qpath, expr.id) {
3938                 variant_ty
3939             } else {
3940                 self.check_struct_fields_on_error(fields, base_expr);
3941                 return self.tcx.types.err;
3942             };
3943
3944         let path_span = match *qpath {
3945             QPath::Resolved(_, ref path) => path.span,
3946             QPath::TypeRelative(ref qself, _) => qself.span
3947         };
3948
3949         // Prohibit struct expressions when non-exhaustive flag is set.
3950         let adt = adt_ty.ty_adt_def().expect("`check_struct_path` returned non-ADT type");
3951         if !adt.did.is_local() && variant.is_field_list_non_exhaustive() {
3952             span_err!(self.tcx.sess, expr.span, E0639,
3953                       "cannot create non-exhaustive {} using struct expression",
3954                       adt.variant_descr());
3955         }
3956
3957         let error_happened = self.check_expr_struct_fields(adt_ty, expected, expr.id, path_span,
3958                                                            variant, fields, base_expr.is_none());
3959         if let &Some(ref base_expr) = base_expr {
3960             // If check_expr_struct_fields hit an error, do not attempt to populate
3961             // the fields with the base_expr. This could cause us to hit errors later
3962             // when certain fields are assumed to exist that in fact do not.
3963             if !error_happened {
3964                 self.check_expr_has_type_or_error(base_expr, adt_ty);
3965                 match adt_ty.sty {
3966                     ty::Adt(adt, substs) if adt.is_struct() => {
3967                         let fru_field_types = adt.non_enum_variant().fields.iter().map(|f| {
3968                             self.normalize_associated_types_in(expr.span, &f.ty(self.tcx, substs))
3969                         }).collect();
3970
3971                         self.tables
3972                             .borrow_mut()
3973                             .fru_field_types_mut()
3974                             .insert(expr.hir_id, fru_field_types);
3975                     }
3976                     _ => {
3977                         span_err!(self.tcx.sess, base_expr.span, E0436,
3978                                   "functional record update syntax requires a struct");
3979                     }
3980                 }
3981             }
3982         }
3983         self.require_type_is_sized(adt_ty, expr.span, traits::StructInitializerSized);
3984         adt_ty
3985     }
3986
3987
3988     /// Invariant:
3989     /// If an expression has any sub-expressions that result in a type error,
3990     /// inspecting that expression's type with `ty.references_error()` will return
3991     /// true. Likewise, if an expression is known to diverge, inspecting its
3992     /// type with `ty::type_is_bot` will return true (n.b.: since Rust is
3993     /// strict, _|_ can appear in the type of an expression that does not,
3994     /// itself, diverge: for example, fn() -> _|_.)
3995     /// Note that inspecting a type's structure *directly* may expose the fact
3996     /// that there are actually multiple representations for `Error`, so avoid
3997     /// that when err needs to be handled differently.
3998     fn check_expr_with_expectation_and_needs(&self,
3999                                              expr: &'gcx hir::Expr,
4000                                              expected: Expectation<'tcx>,
4001                                              needs: Needs) -> Ty<'tcx> {
4002         debug!(">> type-checking: expr={:?} expected={:?}",
4003                expr, expected);
4004
4005         // Warn for expressions after diverging siblings.
4006         self.warn_if_unreachable(expr.id, expr.span, "expression");
4007
4008         // Hide the outer diverging and has_errors flags.
4009         let old_diverges = self.diverges.get();
4010         let old_has_errors = self.has_errors.get();
4011         self.diverges.set(Diverges::Maybe);
4012         self.has_errors.set(false);
4013
4014         let ty = self.check_expr_kind(expr, expected, needs);
4015
4016         // Warn for non-block expressions with diverging children.
4017         match expr.node {
4018             ExprKind::Block(..) |
4019             ExprKind::Loop(..) | ExprKind::While(..) |
4020             ExprKind::If(..) | ExprKind::Match(..) => {}
4021
4022             _ => self.warn_if_unreachable(expr.id, expr.span, "expression")
4023         }
4024
4025         // Any expression that produces a value of type `!` must have diverged
4026         if ty.is_never() {
4027             self.diverges.set(self.diverges.get() | Diverges::Always);
4028         }
4029
4030         // Record the type, which applies it effects.
4031         // We need to do this after the warning above, so that
4032         // we don't warn for the diverging expression itself.
4033         self.write_ty(expr.hir_id, ty);
4034
4035         // Combine the diverging and has_error flags.
4036         self.diverges.set(self.diverges.get() | old_diverges);
4037         self.has_errors.set(self.has_errors.get() | old_has_errors);
4038
4039         debug!("type of {} is...", self.tcx.hir().node_to_string(expr.id));
4040         debug!("... {:?}, expected is {:?}", ty, expected);
4041
4042         ty
4043     }
4044
4045     fn check_expr_kind(
4046         &self,
4047         expr: &'gcx hir::Expr,
4048         expected: Expectation<'tcx>,
4049         needs: Needs
4050     ) -> Ty<'tcx> {
4051         debug!(
4052             "check_expr_kind(expr={:?}, expected={:?}, needs={:?})",
4053             expr,
4054             expected,
4055             needs,
4056         );
4057
4058         let tcx = self.tcx;
4059         let id = expr.id;
4060         match expr.node {
4061             ExprKind::Box(ref subexpr) => {
4062                 let expected_inner = expected.to_option(self).map_or(NoExpectation, |ty| {
4063                     match ty.sty {
4064                         ty::Adt(def, _) if def.is_box()
4065                             => Expectation::rvalue_hint(self, ty.boxed_ty()),
4066                         _ => NoExpectation
4067                     }
4068                 });
4069                 let referent_ty = self.check_expr_with_expectation(subexpr, expected_inner);
4070                 tcx.mk_box(referent_ty)
4071             }
4072
4073             ExprKind::Lit(ref lit) => {
4074                 self.check_lit(&lit, expected)
4075             }
4076             ExprKind::Binary(op, ref lhs, ref rhs) => {
4077                 self.check_binop(expr, op, lhs, rhs)
4078             }
4079             ExprKind::AssignOp(op, ref lhs, ref rhs) => {
4080                 self.check_binop_assign(expr, op, lhs, rhs)
4081             }
4082             ExprKind::Unary(unop, ref oprnd) => {
4083                 let expected_inner = match unop {
4084                     hir::UnNot | hir::UnNeg => {
4085                         expected
4086                     }
4087                     hir::UnDeref => {
4088                         NoExpectation
4089                     }
4090                 };
4091                 let needs = match unop {
4092                     hir::UnDeref => needs,
4093                     _ => Needs::None
4094                 };
4095                 let mut oprnd_t = self.check_expr_with_expectation_and_needs(&oprnd,
4096                                                                              expected_inner,
4097                                                                              needs);
4098
4099                 if !oprnd_t.references_error() {
4100                     oprnd_t = self.structurally_resolved_type(expr.span, oprnd_t);
4101                     match unop {
4102                         hir::UnDeref => {
4103                             if let Some(mt) = oprnd_t.builtin_deref(true) {
4104                                 oprnd_t = mt.ty;
4105                             } else if let Some(ok) = self.try_overloaded_deref(
4106                                     expr.span, oprnd_t, needs) {
4107                                 let method = self.register_infer_ok_obligations(ok);
4108                                 if let ty::Ref(region, _, mutbl) = method.sig.inputs()[0].sty {
4109                                     let mutbl = match mutbl {
4110                                         hir::MutImmutable => AutoBorrowMutability::Immutable,
4111                                         hir::MutMutable => AutoBorrowMutability::Mutable {
4112                                             // (It shouldn't actually matter for unary ops whether
4113                                             // we enable two-phase borrows or not, since a unary
4114                                             // op has no additional operands.)
4115                                             allow_two_phase_borrow: AllowTwoPhase::No,
4116                                         }
4117                                     };
4118                                     self.apply_adjustments(oprnd, vec![Adjustment {
4119                                         kind: Adjust::Borrow(AutoBorrow::Ref(region, mutbl)),
4120                                         target: method.sig.inputs()[0]
4121                                     }]);
4122                                 }
4123                                 oprnd_t = self.make_overloaded_place_return_type(method).ty;
4124                                 self.write_method_call(expr.hir_id, method);
4125                             } else {
4126                                 type_error_struct!(tcx.sess, expr.span, oprnd_t, E0614,
4127                                                    "type `{}` cannot be dereferenced",
4128                                                    oprnd_t).emit();
4129                                 oprnd_t = tcx.types.err;
4130                             }
4131                         }
4132                         hir::UnNot => {
4133                             let result = self.check_user_unop(expr, oprnd_t, unop);
4134                             // If it's builtin, we can reuse the type, this helps inference.
4135                             if !(oprnd_t.is_integral() || oprnd_t.sty == ty::Bool) {
4136                                 oprnd_t = result;
4137                             }
4138                         }
4139                         hir::UnNeg => {
4140                             let result = self.check_user_unop(expr, oprnd_t, unop);
4141                             // If it's builtin, we can reuse the type, this helps inference.
4142                             if !(oprnd_t.is_integral() || oprnd_t.is_fp()) {
4143                                 oprnd_t = result;
4144                             }
4145                         }
4146                     }
4147                 }
4148                 oprnd_t
4149             }
4150             ExprKind::AddrOf(mutbl, ref oprnd) => {
4151                 let hint = expected.only_has_type(self).map_or(NoExpectation, |ty| {
4152                     match ty.sty {
4153                         ty::Ref(_, ty, _) | ty::RawPtr(ty::TypeAndMut { ty, .. }) => {
4154                             if oprnd.is_place_expr() {
4155                                 // Places may legitimately have unsized types.
4156                                 // For example, dereferences of a fat pointer and
4157                                 // the last field of a struct can be unsized.
4158                                 ExpectHasType(ty)
4159                             } else {
4160                                 Expectation::rvalue_hint(self, ty)
4161                             }
4162                         }
4163                         _ => NoExpectation
4164                     }
4165                 });
4166                 let needs = Needs::maybe_mut_place(mutbl);
4167                 let ty = self.check_expr_with_expectation_and_needs(&oprnd, hint, needs);
4168
4169                 let tm = ty::TypeAndMut { ty: ty, mutbl: mutbl };
4170                 if tm.ty.references_error() {
4171                     tcx.types.err
4172                 } else {
4173                     // Note: at this point, we cannot say what the best lifetime
4174                     // is to use for resulting pointer.  We want to use the
4175                     // shortest lifetime possible so as to avoid spurious borrowck
4176                     // errors.  Moreover, the longest lifetime will depend on the
4177                     // precise details of the value whose address is being taken
4178                     // (and how long it is valid), which we don't know yet until type
4179                     // inference is complete.
4180                     //
4181                     // Therefore, here we simply generate a region variable.  The
4182                     // region inferencer will then select the ultimate value.
4183                     // Finally, borrowck is charged with guaranteeing that the
4184                     // value whose address was taken can actually be made to live
4185                     // as long as it needs to live.
4186                     let region = self.next_region_var(infer::AddrOfRegion(expr.span));
4187                     tcx.mk_ref(region, tm)
4188                 }
4189             }
4190             ExprKind::Path(ref qpath) => {
4191                 let (def, opt_ty, segs) = self.resolve_ty_and_def_ufcs(qpath, expr.id, expr.span);
4192                 let ty = match def {
4193                     Def::Err => {
4194                         self.set_tainted_by_errors();
4195                         tcx.types.err
4196                     }
4197                     Def::VariantCtor(_, CtorKind::Fictive) => {
4198                         report_unexpected_variant_def(tcx, &def, expr.span, qpath);
4199                         tcx.types.err
4200                     }
4201                     _ => self.instantiate_value_path(segs, opt_ty, def, expr.span, id).0,
4202                 };
4203
4204                 if let ty::FnDef(..) = ty.sty {
4205                     let fn_sig = ty.fn_sig(tcx);
4206                     if !tcx.features().unsized_locals {
4207                         // We want to remove some Sized bounds from std functions,
4208                         // but don't want to expose the removal to stable Rust.
4209                         // i.e., we don't want to allow
4210                         //
4211                         // ```rust
4212                         // drop as fn(str);
4213                         // ```
4214                         //
4215                         // to work in stable even if the Sized bound on `drop` is relaxed.
4216                         for i in 0..fn_sig.inputs().skip_binder().len() {
4217                             // We just want to check sizedness, so instead of introducing
4218                             // placeholder lifetimes with probing, we just replace higher lifetimes
4219                             // with fresh vars.
4220                             let input = self.replace_bound_vars_with_fresh_vars(
4221                                 expr.span,
4222                                 infer::LateBoundRegionConversionTime::FnCall,
4223                                 &fn_sig.input(i)).0;
4224                             self.require_type_is_sized_deferred(input, expr.span,
4225                                                                 traits::SizedArgumentType);
4226                         }
4227                     }
4228                     // Here we want to prevent struct constructors from returning unsized types.
4229                     // There were two cases this happened: fn pointer coercion in stable
4230                     // and usual function call in presense of unsized_locals.
4231                     // Also, as we just want to check sizedness, instead of introducing
4232                     // placeholder lifetimes with probing, we just replace higher lifetimes
4233                     // with fresh vars.
4234                     let output = self.replace_bound_vars_with_fresh_vars(
4235                         expr.span,
4236                         infer::LateBoundRegionConversionTime::FnCall,
4237                         &fn_sig.output()).0;
4238                     self.require_type_is_sized_deferred(output, expr.span, traits::SizedReturnType);
4239                 }
4240
4241                 // We always require that the type provided as the value for
4242                 // a type parameter outlives the moment of instantiation.
4243                 let substs = self.tables.borrow().node_substs(expr.hir_id);
4244                 self.add_wf_bounds(substs, expr);
4245
4246                 ty
4247             }
4248             ExprKind::InlineAsm(_, ref outputs, ref inputs) => {
4249                 for expr in outputs.iter().chain(inputs.iter()) {
4250                     self.check_expr(expr);
4251                 }
4252                 tcx.mk_unit()
4253             }
4254             ExprKind::Break(destination, ref expr_opt) => {
4255                 if let Ok(target_id) = destination.target_id {
4256                     let (e_ty, cause);
4257                     if let Some(ref e) = *expr_opt {
4258                         // If this is a break with a value, we need to type-check
4259                         // the expression. Get an expected type from the loop context.
4260                         let opt_coerce_to = {
4261                             let mut enclosing_breakables = self.enclosing_breakables.borrow_mut();
4262                             enclosing_breakables.find_breakable(target_id)
4263                                                 .coerce
4264                                                 .as_ref()
4265                                                 .map(|coerce| coerce.expected_ty())
4266                         };
4267
4268                         // If the loop context is not a `loop { }`, then break with
4269                         // a value is illegal, and `opt_coerce_to` will be `None`.
4270                         // Just set expectation to error in that case.
4271                         let coerce_to = opt_coerce_to.unwrap_or(tcx.types.err);
4272
4273                         // Recurse without `enclosing_breakables` borrowed.
4274                         e_ty = self.check_expr_with_hint(e, coerce_to);
4275                         cause = self.misc(e.span);
4276                     } else {
4277                         // Otherwise, this is a break *without* a value. That's
4278                         // always legal, and is equivalent to `break ()`.
4279                         e_ty = tcx.mk_unit();
4280                         cause = self.misc(expr.span);
4281                     }
4282
4283                     // Now that we have type-checked `expr_opt`, borrow
4284                     // the `enclosing_loops` field and let's coerce the
4285                     // type of `expr_opt` into what is expected.
4286                     let mut enclosing_breakables = self.enclosing_breakables.borrow_mut();
4287                     let ctxt = enclosing_breakables.find_breakable(target_id);
4288                     if let Some(ref mut coerce) = ctxt.coerce {
4289                         if let Some(ref e) = *expr_opt {
4290                             coerce.coerce(self, &cause, e, e_ty);
4291                         } else {
4292                             assert!(e_ty.is_unit());
4293                             coerce.coerce_forced_unit(self, &cause, &mut |_| (), true);
4294                         }
4295                     } else {
4296                         // If `ctxt.coerce` is `None`, we can just ignore
4297                         // the type of the expresison.  This is because
4298                         // either this was a break *without* a value, in
4299                         // which case it is always a legal type (`()`), or
4300                         // else an error would have been flagged by the
4301                         // `loops` pass for using break with an expression
4302                         // where you are not supposed to.
4303                         assert!(expr_opt.is_none() || self.tcx.sess.err_count() > 0);
4304                     }
4305
4306                     ctxt.may_break = true;
4307
4308                     // the type of a `break` is always `!`, since it diverges
4309                     tcx.types.never
4310                 } else {
4311                     // Otherwise, we failed to find the enclosing loop;
4312                     // this can only happen if the `break` was not
4313                     // inside a loop at all, which is caught by the
4314                     // loop-checking pass.
4315                     if self.tcx.sess.err_count() == 0 {
4316                         self.tcx.sess.delay_span_bug(expr.span,
4317                             "break was outside loop, but no error was emitted");
4318                     }
4319
4320                     // We still need to assign a type to the inner expression to
4321                     // prevent the ICE in #43162.
4322                     if let Some(ref e) = *expr_opt {
4323                         self.check_expr_with_hint(e, tcx.types.err);
4324
4325                         // ... except when we try to 'break rust;'.
4326                         // ICE this expression in particular (see #43162).
4327                         if let ExprKind::Path(QPath::Resolved(_, ref path)) = e.node {
4328                             if path.segments.len() == 1 && path.segments[0].ident.name == "rust" {
4329                                 fatally_break_rust(self.tcx.sess);
4330                             }
4331                         }
4332                     }
4333                     // There was an error; make type-check fail.
4334                     tcx.types.err
4335                 }
4336
4337             }
4338             ExprKind::Continue(destination) => {
4339                 if destination.target_id.is_ok() {
4340                     tcx.types.never
4341                 } else {
4342                     // There was an error; make type-check fail.
4343                     tcx.types.err
4344                 }
4345             }
4346             ExprKind::Ret(ref expr_opt) => {
4347                 if self.ret_coercion.is_none() {
4348                     struct_span_err!(self.tcx.sess, expr.span, E0572,
4349                                      "return statement outside of function body").emit();
4350                 } else if let Some(ref e) = *expr_opt {
4351                     if self.ret_coercion_span.borrow().is_none() {
4352                         *self.ret_coercion_span.borrow_mut() = Some(e.span);
4353                     }
4354                     self.check_return_expr(e);
4355                 } else {
4356                     let mut coercion = self.ret_coercion.as_ref().unwrap().borrow_mut();
4357                     if self.ret_coercion_span.borrow().is_none() {
4358                         *self.ret_coercion_span.borrow_mut() = Some(expr.span);
4359                     }
4360                     let cause = self.cause(expr.span, ObligationCauseCode::ReturnNoExpression);
4361                     if let Some((fn_decl, _)) = self.get_fn_decl(expr.id) {
4362                         coercion.coerce_forced_unit(
4363                             self,
4364                             &cause,
4365                             &mut |db| {
4366                                 db.span_label(
4367                                     fn_decl.output.span(),
4368                                     format!(
4369                                         "expected `{}` because of this return type",
4370                                         fn_decl.output,
4371                                     ),
4372                                 );
4373                             },
4374                             true,
4375                         );
4376                     } else {
4377                         coercion.coerce_forced_unit(self, &cause, &mut |_| (), true);
4378                     }
4379                 }
4380                 tcx.types.never
4381             }
4382             ExprKind::Assign(ref lhs, ref rhs) => {
4383                 let lhs_ty = self.check_expr_with_needs(&lhs, Needs::MutPlace);
4384
4385                 let rhs_ty = self.check_expr_coercable_to_type(&rhs, lhs_ty);
4386
4387                 match expected {
4388                     ExpectIfCondition => {
4389                         self.tcx.sess.delay_span_bug(lhs.span, "invalid lhs expression in if;\
4390                                                                 expected error elsehwere");
4391                     }
4392                     _ => {
4393                         // Only check this if not in an `if` condition, as the
4394                         // mistyped comparison help is more appropriate.
4395                         if !lhs.is_place_expr() {
4396                             struct_span_err!(self.tcx.sess, expr.span, E0070,
4397                                                 "invalid left-hand side expression")
4398                                 .span_label(expr.span, "left-hand of expression not valid")
4399                                 .emit();
4400                         }
4401                     }
4402                 }
4403
4404                 self.require_type_is_sized(lhs_ty, lhs.span, traits::AssignmentLhsSized);
4405
4406                 if lhs_ty.references_error() || rhs_ty.references_error() {
4407                     tcx.types.err
4408                 } else {
4409                     tcx.mk_unit()
4410                 }
4411             }
4412             ExprKind::If(ref cond, ref then_expr, ref opt_else_expr) => {
4413                 self.check_then_else(&cond, then_expr, opt_else_expr.as_ref().map(|e| &**e),
4414                                      expr.span, expected)
4415             }
4416             ExprKind::While(ref cond, ref body, _) => {
4417                 let ctxt = BreakableCtxt {
4418                     // cannot use break with a value from a while loop
4419                     coerce: None,
4420                     may_break: false,  // Will get updated if/when we find a `break`.
4421                 };
4422
4423                 let (ctxt, ()) = self.with_breakable_ctxt(expr.id, ctxt, || {
4424                     self.check_expr_has_type_or_error(&cond, tcx.types.bool);
4425                     let cond_diverging = self.diverges.get();
4426                     self.check_block_no_value(&body);
4427
4428                     // We may never reach the body so it diverging means nothing.
4429                     self.diverges.set(cond_diverging);
4430                 });
4431
4432                 if ctxt.may_break {
4433                     // No way to know whether it's diverging because
4434                     // of a `break` or an outer `break` or `return`.
4435                     self.diverges.set(Diverges::Maybe);
4436                 }
4437
4438                 self.tcx.mk_unit()
4439             }
4440             ExprKind::Loop(ref body, _, source) => {
4441                 let coerce = match source {
4442                     // you can only use break with a value from a normal `loop { }`
4443                     hir::LoopSource::Loop => {
4444                         let coerce_to = expected.coercion_target_type(self, body.span);
4445                         Some(CoerceMany::new(coerce_to))
4446                     }
4447
4448                     hir::LoopSource::WhileLet |
4449                     hir::LoopSource::ForLoop => {
4450                         None
4451                     }
4452                 };
4453
4454                 let ctxt = BreakableCtxt {
4455                     coerce,
4456                     may_break: false, // Will get updated if/when we find a `break`.
4457                 };
4458
4459                 let (ctxt, ()) = self.with_breakable_ctxt(expr.id, ctxt, || {
4460                     self.check_block_no_value(&body);
4461                 });
4462
4463                 if ctxt.may_break {
4464                     // No way to know whether it's diverging because
4465                     // of a `break` or an outer `break` or `return`.
4466                     self.diverges.set(Diverges::Maybe);
4467                 }
4468
4469                 // If we permit break with a value, then result type is
4470                 // the LUB of the breaks (possibly ! if none); else, it
4471                 // is nil. This makes sense because infinite loops
4472                 // (which would have type !) are only possible iff we
4473                 // permit break with a value [1].
4474                 if ctxt.coerce.is_none() && !ctxt.may_break {
4475                     // [1]
4476                     self.tcx.sess.delay_span_bug(body.span, "no coercion, but loop may not break");
4477                 }
4478                 ctxt.coerce.map(|c| c.complete(self)).unwrap_or_else(|| self.tcx.mk_unit())
4479             }
4480             ExprKind::Match(ref discrim, ref arms, match_src) => {
4481                 self.check_match(expr, &discrim, arms, expected, match_src)
4482             }
4483             ExprKind::Closure(capture, ref decl, body_id, _, gen) => {
4484                 self.check_expr_closure(expr, capture, &decl, body_id, gen, expected)
4485             }
4486             ExprKind::Block(ref body, _) => {
4487                 self.check_block_with_expected(&body, expected)
4488             }
4489             ExprKind::Call(ref callee, ref args) => {
4490                 self.check_call(expr, &callee, args, expected)
4491             }
4492             ExprKind::MethodCall(ref segment, span, ref args) => {
4493                 self.check_method_call(expr, segment, span, args, expected, needs)
4494             }
4495             ExprKind::Cast(ref e, ref t) => {
4496                 // Find the type of `e`. Supply hints based on the type we are casting to,
4497                 // if appropriate.
4498                 let t_cast = self.to_ty_saving_user_provided_ty(t);
4499                 let t_cast = self.resolve_type_vars_if_possible(&t_cast);
4500                 let t_expr = self.check_expr_with_expectation(e, ExpectCastableToType(t_cast));
4501                 let t_cast = self.resolve_type_vars_if_possible(&t_cast);
4502
4503                 // Eagerly check for some obvious errors.
4504                 if t_expr.references_error() || t_cast.references_error() {
4505                     tcx.types.err
4506                 } else {
4507                     // Defer other checks until we're done type checking.
4508                     let mut deferred_cast_checks = self.deferred_cast_checks.borrow_mut();
4509                     match cast::CastCheck::new(self, e, t_expr, t_cast, t.span, expr.span) {
4510                         Ok(cast_check) => {
4511                             deferred_cast_checks.push(cast_check);
4512                             t_cast
4513                         }
4514                         Err(ErrorReported) => {
4515                             tcx.types.err
4516                         }
4517                     }
4518                 }
4519             }
4520             ExprKind::Type(ref e, ref t) => {
4521                 let ty = self.to_ty_saving_user_provided_ty(&t);
4522                 self.check_expr_eq_type(&e, ty);
4523                 ty
4524             }
4525             ExprKind::Array(ref args) => {
4526                 let uty = expected.to_option(self).and_then(|uty| {
4527                     match uty.sty {
4528                         ty::Array(ty, _) | ty::Slice(ty) => Some(ty),
4529                         _ => None
4530                     }
4531                 });
4532
4533                 let element_ty = if !args.is_empty() {
4534                     let coerce_to = uty.unwrap_or_else(
4535                         || self.next_ty_var(TypeVariableOrigin::TypeInference(expr.span)));
4536                     let mut coerce = CoerceMany::with_coercion_sites(coerce_to, args);
4537                     assert_eq!(self.diverges.get(), Diverges::Maybe);
4538                     for e in args {
4539                         let e_ty = self.check_expr_with_hint(e, coerce_to);
4540                         let cause = self.misc(e.span);
4541                         coerce.coerce(self, &cause, e, e_ty);
4542                     }
4543                     coerce.complete(self)
4544                 } else {
4545                     self.next_ty_var(TypeVariableOrigin::TypeInference(expr.span))
4546                 };
4547                 tcx.mk_array(element_ty, args.len() as u64)
4548             }
4549             ExprKind::Repeat(ref element, ref count) => {
4550                 let count_def_id = tcx.hir().local_def_id(count.id);
4551                 let param_env = ty::ParamEnv::empty();
4552                 let substs = Substs::identity_for_item(tcx.global_tcx(), count_def_id);
4553                 let instance = ty::Instance::resolve(
4554                     tcx.global_tcx(),
4555                     param_env,
4556                     count_def_id,
4557                     substs,
4558                 ).unwrap();
4559                 let global_id = GlobalId {
4560                     instance,
4561                     promoted: None
4562                 };
4563                 let count = tcx.const_eval(param_env.and(global_id));
4564
4565                 let uty = match expected {
4566                     ExpectHasType(uty) => {
4567                         match uty.sty {
4568                             ty::Array(ty, _) | ty::Slice(ty) => Some(ty),
4569                             _ => None
4570                         }
4571                     }
4572                     _ => None
4573                 };
4574
4575                 let (element_ty, t) = match uty {
4576                     Some(uty) => {
4577                         self.check_expr_coercable_to_type(&element, uty);
4578                         (uty, uty)
4579                     }
4580                     None => {
4581                         let ty = self.next_ty_var(TypeVariableOrigin::MiscVariable(element.span));
4582                         let element_ty = self.check_expr_has_type_or_error(&element, ty);
4583                         (element_ty, ty)
4584                     }
4585                 };
4586
4587                 if let Ok(count) = count {
4588                     let zero_or_one = count.assert_usize(tcx).map_or(false, |count| count <= 1);
4589                     if !zero_or_one {
4590                         // For [foo, ..n] where n > 1, `foo` must have
4591                         // Copy type:
4592                         let lang_item = self.tcx.require_lang_item(lang_items::CopyTraitLangItem);
4593                         self.require_type_meets(t, expr.span, traits::RepeatVec, lang_item);
4594                     }
4595                 }
4596
4597                 if element_ty.references_error() {
4598                     tcx.types.err
4599                 } else if let Ok(count) = count {
4600                     tcx.mk_ty(ty::Array(t, tcx.intern_lazy_const(ty::LazyConst::Evaluated(count))))
4601                 } else {
4602                     tcx.types.err
4603                 }
4604             }
4605             ExprKind::Tup(ref elts) => {
4606                 let flds = expected.only_has_type(self).and_then(|ty| {
4607                     let ty = self.resolve_type_vars_with_obligations(ty);
4608                     match ty.sty {
4609                         ty::Tuple(ref flds) => Some(&flds[..]),
4610                         _ => None
4611                     }
4612                 });
4613
4614                 let elt_ts_iter = elts.iter().enumerate().map(|(i, e)| {
4615                     let t = match flds {
4616                         Some(ref fs) if i < fs.len() => {
4617                             let ety = fs[i];
4618                             self.check_expr_coercable_to_type(&e, ety);
4619                             ety
4620                         }
4621                         _ => {
4622                             self.check_expr_with_expectation(&e, NoExpectation)
4623                         }
4624                     };
4625                     t
4626                 });
4627                 let tuple = tcx.mk_tup(elt_ts_iter);
4628                 if tuple.references_error() {
4629                     tcx.types.err
4630                 } else {
4631                     self.require_type_is_sized(tuple, expr.span, traits::TupleInitializerSized);
4632                     tuple
4633                 }
4634             }
4635             ExprKind::Struct(ref qpath, ref fields, ref base_expr) => {
4636                 self.check_expr_struct(expr, expected, qpath, fields, base_expr)
4637             }
4638             ExprKind::Field(ref base, field) => {
4639                 self.check_field(expr, needs, &base, field)
4640             }
4641             ExprKind::Index(ref base, ref idx) => {
4642                 let base_t = self.check_expr_with_needs(&base, needs);
4643                 let idx_t = self.check_expr(&idx);
4644
4645                 if base_t.references_error() {
4646                     base_t
4647                 } else if idx_t.references_error() {
4648                     idx_t
4649                 } else {
4650                     let base_t = self.structurally_resolved_type(base.span, base_t);
4651                     match self.lookup_indexing(expr, base, base_t, idx_t, needs) {
4652                         Some((index_ty, element_ty)) => {
4653                             // two-phase not needed because index_ty is never mutable
4654                             self.demand_coerce(idx, idx_t, index_ty, AllowTwoPhase::No);
4655                             element_ty
4656                         }
4657                         None => {
4658                             let mut err =
4659                                 type_error_struct!(tcx.sess, expr.span, base_t, E0608,
4660                                                    "cannot index into a value of type `{}`",
4661                                                    base_t);
4662                             // Try to give some advice about indexing tuples.
4663                             if let ty::Tuple(..) = base_t.sty {
4664                                 let mut needs_note = true;
4665                                 // If the index is an integer, we can show the actual
4666                                 // fixed expression:
4667                                 if let ExprKind::Lit(ref lit) = idx.node {
4668                                     if let ast::LitKind::Int(i,
4669                                             ast::LitIntType::Unsuffixed) = lit.node {
4670                                         let snip = tcx.sess.source_map().span_to_snippet(base.span);
4671                                         if let Ok(snip) = snip {
4672                                             err.span_suggestion(
4673                                                 expr.span,
4674                                                 "to access tuple elements, use",
4675                                                 format!("{}.{}", snip, i),
4676                                                 Applicability::MachineApplicable,
4677                                             );
4678                                             needs_note = false;
4679                                         }
4680                                     }
4681                                 }
4682                                 if needs_note {
4683                                     err.help("to access tuple elements, use tuple indexing \
4684                                               syntax (e.g., `tuple.0`)");
4685                                 }
4686                             }
4687                             err.emit();
4688                             self.tcx.types.err
4689                         }
4690                     }
4691                 }
4692             }
4693             ExprKind::Yield(ref value) => {
4694                 match self.yield_ty {
4695                     Some(ty) => {
4696                         self.check_expr_coercable_to_type(&value, ty);
4697                     }
4698                     None => {
4699                         struct_span_err!(self.tcx.sess, expr.span, E0627,
4700                                          "yield statement outside of generator literal").emit();
4701                     }
4702                 }
4703                 tcx.mk_unit()
4704             }
4705             hir::ExprKind::Err => {
4706                 tcx.types.err
4707             }
4708         }
4709     }
4710
4711     // Finish resolving a path in a struct expression or pattern `S::A { .. }` if necessary.
4712     // The newly resolved definition is written into `type_dependent_defs`.
4713     fn finish_resolving_struct_path(&self,
4714                                     qpath: &QPath,
4715                                     path_span: Span,
4716                                     node_id: ast::NodeId)
4717                                     -> (Def, Ty<'tcx>)
4718     {
4719         match *qpath {
4720             QPath::Resolved(ref maybe_qself, ref path) => {
4721                 let self_ty = maybe_qself.as_ref().map(|qself| self.to_ty(qself));
4722                 let ty = AstConv::def_to_ty(self, self_ty, path, true);
4723                 (path.def, ty)
4724             }
4725             QPath::TypeRelative(ref qself, ref segment) => {
4726                 let ty = self.to_ty(qself);
4727
4728                 let def = if let hir::TyKind::Path(QPath::Resolved(_, ref path)) = qself.node {
4729                     path.def
4730                 } else {
4731                     Def::Err
4732                 };
4733                 let (ty, def) = AstConv::associated_path_to_ty(self, node_id, path_span,
4734                                                                ty, def, segment, true);
4735
4736                 // Write back the new resolution.
4737                 let hir_id = self.tcx.hir().node_to_hir_id(node_id);
4738                 self.tables.borrow_mut().type_dependent_defs_mut().insert(hir_id, def);
4739
4740                 (def, ty)
4741             }
4742         }
4743     }
4744
4745     // Resolve associated value path into a base type and associated constant or method definition.
4746     // The newly resolved definition is written into `type_dependent_defs`.
4747     pub fn resolve_ty_and_def_ufcs<'b>(&self,
4748                                        qpath: &'b QPath,
4749                                        node_id: ast::NodeId,
4750                                        span: Span)
4751                                        -> (Def, Option<Ty<'tcx>>, &'b [hir::PathSegment])
4752     {
4753         debug!("resolve_ty_and_def_ufcs: qpath={:?} node_id={:?} span={:?}", qpath, node_id, span);
4754         let (ty, qself, item_segment) = match *qpath {
4755             QPath::Resolved(ref opt_qself, ref path) => {
4756                 return (path.def,
4757                         opt_qself.as_ref().map(|qself| self.to_ty(qself)),
4758                         &path.segments[..]);
4759             }
4760             QPath::TypeRelative(ref qself, ref segment) => {
4761                 (self.to_ty(qself), qself, segment)
4762             }
4763         };
4764         let hir_id = self.tcx.hir().node_to_hir_id(node_id);
4765         if let Some(cached_def) = self.tables.borrow().type_dependent_defs().get(hir_id) {
4766             // Return directly on cache hit. This is useful to avoid doubly reporting
4767             // errors with default match binding modes. See #44614.
4768             return (*cached_def, Some(ty), slice::from_ref(&**item_segment))
4769         }
4770         let item_name = item_segment.ident;
4771         let def = match self.resolve_ufcs(span, item_name, ty, node_id) {
4772             Ok(def) => def,
4773             Err(error) => {
4774                 let def = match error {
4775                     method::MethodError::PrivateMatch(def, _) => def,
4776                     _ => Def::Err,
4777                 };
4778                 if item_name.name != keywords::Invalid.name() {
4779                     self.report_method_error(span,
4780                                              ty,
4781                                              item_name,
4782                                              SelfSource::QPath(qself),
4783                                              error,
4784                                              None);
4785                 }
4786                 def
4787             }
4788         };
4789
4790         // Write back the new resolution.
4791         self.tables.borrow_mut().type_dependent_defs_mut().insert(hir_id, def);
4792         (def, Some(ty), slice::from_ref(&**item_segment))
4793     }
4794
4795     pub fn check_decl_initializer(&self,
4796                                   local: &'gcx hir::Local,
4797                                   init: &'gcx hir::Expr) -> Ty<'tcx>
4798     {
4799         // FIXME(tschottdorf): `contains_explicit_ref_binding()` must be removed
4800         // for #42640 (default match binding modes).
4801         //
4802         // See #44848.
4803         let ref_bindings = local.pat.contains_explicit_ref_binding();
4804
4805         let local_ty = self.local_ty(init.span, local.id).revealed_ty;
4806         if let Some(m) = ref_bindings {
4807             // Somewhat subtle: if we have a `ref` binding in the pattern,
4808             // we want to avoid introducing coercions for the RHS. This is
4809             // both because it helps preserve sanity and, in the case of
4810             // ref mut, for soundness (issue #23116). In particular, in
4811             // the latter case, we need to be clear that the type of the
4812             // referent for the reference that results is *equal to* the
4813             // type of the place it is referencing, and not some
4814             // supertype thereof.
4815             let init_ty = self.check_expr_with_needs(init, Needs::maybe_mut_place(m));
4816             self.demand_eqtype(init.span, local_ty, init_ty);
4817             init_ty
4818         } else {
4819             self.check_expr_coercable_to_type(init, local_ty)
4820         }
4821     }
4822
4823     pub fn check_decl_local(&self, local: &'gcx hir::Local) {
4824         let t = self.local_ty(local.span, local.id).decl_ty;
4825         self.write_ty(local.hir_id, t);
4826
4827         if let Some(ref init) = local.init {
4828             let init_ty = self.check_decl_initializer(local, &init);
4829             if init_ty.references_error() {
4830                 self.write_ty(local.hir_id, init_ty);
4831             }
4832         }
4833
4834         self.check_pat_walk(
4835             &local.pat,
4836             t,
4837             ty::BindingMode::BindByValue(hir::Mutability::MutImmutable),
4838             None,
4839         );
4840         let pat_ty = self.node_ty(local.pat.hir_id);
4841         if pat_ty.references_error() {
4842             self.write_ty(local.hir_id, pat_ty);
4843         }
4844     }
4845
4846     pub fn check_stmt(&self, stmt: &'gcx hir::Stmt) {
4847         // Don't do all the complex logic below for `DeclItem`.
4848         match stmt.node {
4849             hir::StmtKind::Item(..) => return,
4850             hir::StmtKind::Local(..) | hir::StmtKind::Expr(..) | hir::StmtKind::Semi(..) => {}
4851         }
4852
4853         self.warn_if_unreachable(stmt.id, stmt.span, "statement");
4854
4855         // Hide the outer diverging and `has_errors` flags.
4856         let old_diverges = self.diverges.get();
4857         let old_has_errors = self.has_errors.get();
4858         self.diverges.set(Diverges::Maybe);
4859         self.has_errors.set(false);
4860
4861         match stmt.node {
4862             hir::StmtKind::Local(ref l) => {
4863                 self.check_decl_local(&l);
4864             }
4865             // Ignore for now.
4866             hir::StmtKind::Item(_) => {}
4867             hir::StmtKind::Expr(ref expr) => {
4868                 // Check with expected type of `()`.
4869                 self.check_expr_has_type_or_error(&expr, self.tcx.mk_unit());
4870             }
4871             hir::StmtKind::Semi(ref expr) => {
4872                 self.check_expr(&expr);
4873             }
4874         }
4875
4876         // Combine the diverging and `has_error` flags.
4877         self.diverges.set(self.diverges.get() | old_diverges);
4878         self.has_errors.set(self.has_errors.get() | old_has_errors);
4879     }
4880
4881     pub fn check_block_no_value(&self, blk: &'gcx hir::Block)  {
4882         let unit = self.tcx.mk_unit();
4883         let ty = self.check_block_with_expected(blk, ExpectHasType(unit));
4884
4885         // if the block produces a `!` value, that can always be
4886         // (effectively) coerced to unit.
4887         if !ty.is_never() {
4888             self.demand_suptype(blk.span, unit, ty);
4889         }
4890     }
4891
4892     fn check_block_with_expected(&self,
4893                                  blk: &'gcx hir::Block,
4894                                  expected: Expectation<'tcx>) -> Ty<'tcx> {
4895         let prev = {
4896             let mut fcx_ps = self.ps.borrow_mut();
4897             let unsafety_state = fcx_ps.recurse(blk);
4898             replace(&mut *fcx_ps, unsafety_state)
4899         };
4900
4901         // In some cases, blocks have just one exit, but other blocks
4902         // can be targeted by multiple breaks. This can happen both
4903         // with labeled blocks as well as when we desugar
4904         // a `try { ... }` expression.
4905         //
4906         // Example 1:
4907         //
4908         //    'a: { if true { break 'a Err(()); } Ok(()) }
4909         //
4910         // Here we would wind up with two coercions, one from
4911         // `Err(())` and the other from the tail expression
4912         // `Ok(())`. If the tail expression is omitted, that's a
4913         // "forced unit" -- unless the block diverges, in which
4914         // case we can ignore the tail expression (e.g., `'a: {
4915         // break 'a 22; }` would not force the type of the block
4916         // to be `()`).
4917         let tail_expr = blk.expr.as_ref();
4918         let coerce_to_ty = expected.coercion_target_type(self, blk.span);
4919         let coerce = if blk.targeted_by_break {
4920             CoerceMany::new(coerce_to_ty)
4921         } else {
4922             let tail_expr: &[P<hir::Expr>] = match tail_expr {
4923                 Some(e) => slice::from_ref(e),
4924                 None => &[],
4925             };
4926             CoerceMany::with_coercion_sites(coerce_to_ty, tail_expr)
4927         };
4928
4929         let prev_diverges = self.diverges.get();
4930         let ctxt = BreakableCtxt {
4931             coerce: Some(coerce),
4932             may_break: false,
4933         };
4934
4935         let (ctxt, ()) = self.with_breakable_ctxt(blk.id, ctxt, || {
4936             for s in &blk.stmts {
4937                 self.check_stmt(s);
4938             }
4939
4940             // check the tail expression **without** holding the
4941             // `enclosing_breakables` lock below.
4942             let tail_expr_ty = tail_expr.map(|t| self.check_expr_with_expectation(t, expected));
4943
4944             let mut enclosing_breakables = self.enclosing_breakables.borrow_mut();
4945             let ctxt = enclosing_breakables.find_breakable(blk.id);
4946             let coerce = ctxt.coerce.as_mut().unwrap();
4947             if let Some(tail_expr_ty) = tail_expr_ty {
4948                 let tail_expr = tail_expr.unwrap();
4949                 let cause = self.cause(tail_expr.span,
4950                                        ObligationCauseCode::BlockTailExpression(blk.id));
4951                 coerce.coerce(self,
4952                               &cause,
4953                               tail_expr,
4954                               tail_expr_ty);
4955             } else {
4956                 // Subtle: if there is no explicit tail expression,
4957                 // that is typically equivalent to a tail expression
4958                 // of `()` -- except if the block diverges. In that
4959                 // case, there is no value supplied from the tail
4960                 // expression (assuming there are no other breaks,
4961                 // this implies that the type of the block will be
4962                 // `!`).
4963                 //
4964                 // #41425 -- label the implicit `()` as being the
4965                 // "found type" here, rather than the "expected type".
4966                 if !self.diverges.get().always() {
4967                     // #50009 -- Do not point at the entire fn block span, point at the return type
4968                     // span, as it is the cause of the requirement, and
4969                     // `consider_hint_about_removing_semicolon` will point at the last expression
4970                     // if it were a relevant part of the error. This improves usability in editors
4971                     // that highlight errors inline.
4972                     let mut sp = blk.span;
4973                     let mut fn_span = None;
4974                     if let Some((decl, ident)) = self.get_parent_fn_decl(blk.id) {
4975                         let ret_sp = decl.output.span();
4976                         if let Some(block_sp) = self.parent_item_span(blk.id) {
4977                             // HACK: on some cases (`ui/liveness/liveness-issue-2163.rs`) the
4978                             // output would otherwise be incorrect and even misleading. Make sure
4979                             // the span we're aiming at correspond to a `fn` body.
4980                             if block_sp == blk.span {
4981                                 sp = ret_sp;
4982                                 fn_span = Some(ident.span);
4983                             }
4984                         }
4985                     }
4986                     coerce.coerce_forced_unit(self, &self.misc(sp), &mut |err| {
4987                         if let Some(expected_ty) = expected.only_has_type(self) {
4988                             self.consider_hint_about_removing_semicolon(blk, expected_ty, err);
4989                         }
4990                         if let Some(fn_span) = fn_span {
4991                             err.span_label(fn_span, "this function's body doesn't return");
4992                         }
4993                     }, false);
4994                 }
4995             }
4996         });
4997
4998         if ctxt.may_break {
4999             // If we can break from the block, then the block's exit is always reachable
5000             // (... as long as the entry is reachable) - regardless of the tail of the block.
5001             self.diverges.set(prev_diverges);
5002         }
5003
5004         let mut ty = ctxt.coerce.unwrap().complete(self);
5005
5006         if self.has_errors.get() || ty.references_error() {
5007             ty = self.tcx.types.err
5008         }
5009
5010         self.write_ty(blk.hir_id, ty);
5011
5012         *self.ps.borrow_mut() = prev;
5013         ty
5014     }
5015
5016     fn parent_item_span(&self, id: ast::NodeId) -> Option<Span> {
5017         let node = self.tcx.hir().get(self.tcx.hir().get_parent(id));
5018         match node {
5019             Node::Item(&hir::Item {
5020                 node: hir::ItemKind::Fn(_, _, _, body_id), ..
5021             }) |
5022             Node::ImplItem(&hir::ImplItem {
5023                 node: hir::ImplItemKind::Method(_, body_id), ..
5024             }) => {
5025                 let body = self.tcx.hir().body(body_id);
5026                 if let ExprKind::Block(block, _) = &body.value.node {
5027                     return Some(block.span);
5028                 }
5029             }
5030             _ => {}
5031         }
5032         None
5033     }
5034
5035     /// Given a function block's `NodeId`, return its `FnDecl` if it exists, or `None` otherwise.
5036     fn get_parent_fn_decl(&self, blk_id: ast::NodeId) -> Option<(hir::FnDecl, ast::Ident)> {
5037         let parent = self.tcx.hir().get(self.tcx.hir().get_parent(blk_id));
5038         self.get_node_fn_decl(parent).map(|(fn_decl, ident, _)| (fn_decl, ident))
5039     }
5040
5041     /// Given a function `Node`, return its `FnDecl` if it exists, or `None` otherwise.
5042     fn get_node_fn_decl(&self, node: Node) -> Option<(hir::FnDecl, ast::Ident, bool)> {
5043         match node {
5044             Node::Item(&hir::Item {
5045                 ident, node: hir::ItemKind::Fn(ref decl, ..), ..
5046             }) => decl.clone().and_then(|decl| {
5047                 // This is less than ideal, it will not suggest a return type span on any
5048                 // method called `main`, regardless of whether it is actually the entry point,
5049                 // but it will still present it as the reason for the expected type.
5050                 Some((decl, ident, ident.name != Symbol::intern("main")))
5051             }),
5052             Node::TraitItem(&hir::TraitItem {
5053                 ident, node: hir::TraitItemKind::Method(hir::MethodSig {
5054                     ref decl, ..
5055                 }, ..), ..
5056             }) => decl.clone().and_then(|decl| Some((decl, ident, true))),
5057             Node::ImplItem(&hir::ImplItem {
5058                 ident, node: hir::ImplItemKind::Method(hir::MethodSig {
5059                     ref decl, ..
5060                 }, ..), ..
5061             }) => decl.clone().and_then(|decl| Some((decl, ident, false))),
5062             _ => None,
5063         }
5064     }
5065
5066     /// Given a `NodeId`, return the `FnDecl` of the method it is enclosed by and whether a
5067     /// suggestion can be made, `None` otherwise.
5068     pub fn get_fn_decl(&self, blk_id: ast::NodeId) -> Option<(hir::FnDecl, bool)> {
5069         // Get enclosing Fn, if it is a function or a trait method, unless there's a `loop` or
5070         // `while` before reaching it, as block tail returns are not available in them.
5071         self.tcx.hir().get_return_block(blk_id).and_then(|blk_id| {
5072             let parent = self.tcx.hir().get(blk_id);
5073             self.get_node_fn_decl(parent).map(|(fn_decl, _, is_main)| (fn_decl, is_main))
5074         })
5075     }
5076
5077     /// On implicit return expressions with mismatched types, provide the following suggestions:
5078     ///
5079     ///  - Point out the method's return type as the reason for the expected type
5080     ///  - Possible missing semicolon
5081     ///  - Possible missing return type if the return type is the default, and not `fn main()`
5082     pub fn suggest_mismatched_types_on_tail(
5083         &self,
5084         err: &mut DiagnosticBuilder<'tcx>,
5085         expression: &'gcx hir::Expr,
5086         expected: Ty<'tcx>,
5087         found: Ty<'tcx>,
5088         cause_span: Span,
5089         blk_id: ast::NodeId,
5090     ) -> bool {
5091         self.suggest_missing_semicolon(err, expression, expected, cause_span);
5092         let mut pointing_at_return_type = false;
5093         if let Some((fn_decl, can_suggest)) = self.get_fn_decl(blk_id) {
5094             pointing_at_return_type = self.suggest_missing_return_type(
5095                 err, &fn_decl, expected, found, can_suggest);
5096         }
5097         self.suggest_ref_or_into(err, expression, expected, found);
5098         pointing_at_return_type
5099     }
5100
5101     pub fn suggest_ref_or_into(
5102         &self,
5103         err: &mut DiagnosticBuilder<'tcx>,
5104         expr: &hir::Expr,
5105         expected: Ty<'tcx>,
5106         found: Ty<'tcx>,
5107     ) {
5108         if let Some((sp, msg, suggestion)) = self.check_ref(expr, found, expected) {
5109             err.span_suggestion(
5110                 sp,
5111                 msg,
5112                 suggestion,
5113                 Applicability::MachineApplicable,
5114             );
5115         } else if !self.check_for_cast(err, expr, found, expected) {
5116             let methods = self.get_conversion_methods(expr.span, expected, found);
5117             if let Ok(expr_text) = self.sess().source_map().span_to_snippet(expr.span) {
5118                 let mut suggestions = iter::repeat(&expr_text).zip(methods.iter())
5119                     .filter_map(|(receiver, method)| {
5120                         let method_call = format!(".{}()", method.ident);
5121                         if receiver.ends_with(&method_call) {
5122                             None  // do not suggest code that is already there (#53348)
5123                         } else {
5124                             let method_call_list = [".to_vec()", ".to_string()"];
5125                             if receiver.ends_with(".clone()")
5126                                     && method_call_list.contains(&method_call.as_str()) {
5127                                 let max_len = receiver.rfind(".").unwrap();
5128                                 Some(format!("{}{}", &receiver[..max_len], method_call))
5129                             }
5130                             else {
5131                                 Some(format!("{}{}", receiver, method_call))
5132                             }
5133                         }
5134                     }).peekable();
5135                 if suggestions.peek().is_some() {
5136                     err.span_suggestions(
5137                         expr.span,
5138                         "try using a conversion method",
5139                         suggestions,
5140                         Applicability::MaybeIncorrect,
5141                     );
5142                 }
5143             }
5144         }
5145     }
5146
5147     /// A common error is to forget to add a semicolon at the end of a block:
5148     ///
5149     /// ```
5150     /// fn foo() {
5151     ///     bar_that_returns_u32()
5152     /// }
5153     /// ```
5154     ///
5155     /// This routine checks if the return expression in a block would make sense on its own as a
5156     /// statement and the return type has been left as default or has been specified as `()`. If so,
5157     /// it suggests adding a semicolon.
5158     fn suggest_missing_semicolon(&self,
5159                                  err: &mut DiagnosticBuilder<'tcx>,
5160                                  expression: &'gcx hir::Expr,
5161                                  expected: Ty<'tcx>,
5162                                  cause_span: Span) {
5163         if expected.is_unit() {
5164             // `BlockTailExpression` only relevant if the tail expr would be
5165             // useful on its own.
5166             match expression.node {
5167                 ExprKind::Call(..) |
5168                 ExprKind::MethodCall(..) |
5169                 ExprKind::If(..) |
5170                 ExprKind::While(..) |
5171                 ExprKind::Loop(..) |
5172                 ExprKind::Match(..) |
5173                 ExprKind::Block(..) => {
5174                     let sp = self.tcx.sess.source_map().next_point(cause_span);
5175                     err.span_suggestion(
5176                         sp,
5177                         "try adding a semicolon",
5178                         ";".to_string(),
5179                         Applicability::MachineApplicable);
5180                 }
5181                 _ => (),
5182             }
5183         }
5184     }
5185
5186     /// A possible error is to forget to add a return type that is needed:
5187     ///
5188     /// ```
5189     /// fn foo() {
5190     ///     bar_that_returns_u32()
5191     /// }
5192     /// ```
5193     ///
5194     /// This routine checks if the return type is left as default, the method is not part of an
5195     /// `impl` block and that it isn't the `main` method. If so, it suggests setting the return
5196     /// type.
5197     fn suggest_missing_return_type(
5198         &self,
5199         err: &mut DiagnosticBuilder<'tcx>,
5200         fn_decl: &hir::FnDecl,
5201         expected: Ty<'tcx>,
5202         found: Ty<'tcx>,
5203         can_suggest: bool,
5204     ) -> bool {
5205         // Only suggest changing the return type for methods that
5206         // haven't set a return type at all (and aren't `fn main()` or an impl).
5207         match (&fn_decl.output, found.is_suggestable(), can_suggest, expected.is_unit()) {
5208             (&hir::FunctionRetTy::DefaultReturn(span), true, true, true) => {
5209                 err.span_suggestion(
5210                     span,
5211                     "try adding a return type",
5212                     format!("-> {} ", self.resolve_type_vars_with_obligations(found)),
5213                     Applicability::MachineApplicable);
5214                 true
5215             }
5216             (&hir::FunctionRetTy::DefaultReturn(span), false, true, true) => {
5217                 err.span_label(span, "possibly return type missing here?");
5218                 true
5219             }
5220             (&hir::FunctionRetTy::DefaultReturn(span), _, false, true) => {
5221                 // `fn main()` must return `()`, do not suggest changing return type
5222                 err.span_label(span, "expected `()` because of default return type");
5223                 true
5224             }
5225             // expectation was caused by something else, not the default return
5226             (&hir::FunctionRetTy::DefaultReturn(_), _, _, false) => false,
5227             (&hir::FunctionRetTy::Return(ref ty), _, _, _) => {
5228                 // Only point to return type if the expected type is the return type, as if they
5229                 // are not, the expectation must have been caused by something else.
5230                 debug!("suggest_missing_return_type: return type {:?} node {:?}", ty, ty.node);
5231                 let sp = ty.span;
5232                 let ty = AstConv::ast_ty_to_ty(self, ty);
5233                 debug!("suggest_missing_return_type: return type sty {:?}", ty.sty);
5234                 debug!("suggest_missing_return_type: expected type sty {:?}", ty.sty);
5235                 if ty.sty == expected.sty {
5236                     err.span_label(sp, format!("expected `{}` because of return type",
5237                                                expected));
5238                     return true;
5239                 }
5240                 false
5241             }
5242         }
5243     }
5244
5245     /// A common error is to add an extra semicolon:
5246     ///
5247     /// ```
5248     /// fn foo() -> usize {
5249     ///     22;
5250     /// }
5251     /// ```
5252     ///
5253     /// This routine checks if the final statement in a block is an
5254     /// expression with an explicit semicolon whose type is compatible
5255     /// with `expected_ty`. If so, it suggests removing the semicolon.
5256     fn consider_hint_about_removing_semicolon(
5257         &self,
5258         blk: &'gcx hir::Block,
5259         expected_ty: Ty<'tcx>,
5260         err: &mut DiagnosticBuilder,
5261     ) {
5262         if let Some(span_semi) = self.could_remove_semicolon(blk, expected_ty) {
5263             err.span_suggestion(
5264                 span_semi,
5265                 "consider removing this semicolon",
5266                 String::new(),
5267                 Applicability::MachineApplicable,
5268             );
5269         }
5270     }
5271
5272     fn could_remove_semicolon(
5273         &self,
5274         blk: &'gcx hir::Block,
5275         expected_ty: Ty<'tcx>,
5276     ) -> Option<Span> {
5277         // Be helpful when the user wrote `{... expr;}` and
5278         // taking the `;` off is enough to fix the error.
5279         let last_stmt = match blk.stmts.last() {
5280             Some(s) => s,
5281             None => return None,
5282         };
5283         let last_expr = match last_stmt.node {
5284             hir::StmtKind::Semi(ref e) => e,
5285             _ => return None,
5286         };
5287         let last_expr_ty = self.node_ty(last_expr.hir_id);
5288         if self.can_sub(self.param_env, last_expr_ty, expected_ty).is_err() {
5289             return None;
5290         }
5291         let original_span = original_sp(last_stmt.span, blk.span);
5292         Some(original_span.with_lo(original_span.hi() - BytePos(1)))
5293     }
5294
5295     // Instantiates the given path, which must refer to an item with the given
5296     // number of type parameters and type.
5297     pub fn instantiate_value_path(&self,
5298                                   segments: &[hir::PathSegment],
5299                                   self_ty: Option<Ty<'tcx>>,
5300                                   def: Def,
5301                                   span: Span,
5302                                   node_id: ast::NodeId)
5303                                   -> (Ty<'tcx>, Def) {
5304         debug!(
5305             "instantiate_value_path(segments={:?}, self_ty={:?}, def={:?}, node_id={})",
5306             segments,
5307             self_ty,
5308             def,
5309             node_id,
5310         );
5311
5312         let tcx = self.tcx;
5313
5314         let path_segs = AstConv::def_ids_for_path_segments(self, segments, self_ty, def);
5315
5316         let mut user_self_ty = None;
5317         let mut is_alias_variant_ctor = false;
5318         match def {
5319             Def::VariantCtor(_, _) => {
5320                 if let Some(self_ty) = self_ty {
5321                     let adt_def = self_ty.ty_adt_def().unwrap();
5322                     user_self_ty = Some(UserSelfTy {
5323                         impl_def_id: adt_def.did,
5324                         self_ty,
5325                     });
5326                     is_alias_variant_ctor = true;
5327                 }
5328             }
5329             Def::Method(def_id) |
5330             Def::AssociatedConst(def_id) => {
5331                 let container = tcx.associated_item(def_id).container;
5332                 debug!("instantiate_value_path: def={:?} container={:?}", def, container);
5333                 match container {
5334                     ty::TraitContainer(trait_did) => {
5335                         callee::check_legal_trait_for_method_call(tcx, span, trait_did)
5336                     }
5337                     ty::ImplContainer(impl_def_id) => {
5338                         if segments.len() == 1 {
5339                             // `<T>::assoc` will end up here, and so
5340                             // can `T::assoc`. It this came from an
5341                             // inherent impl, we need to record the
5342                             // `T` for posterity (see `UserSelfTy` for
5343                             // details).
5344                             let self_ty = self_ty.expect("UFCS sugared assoc missing Self");
5345                             user_self_ty = Some(UserSelfTy {
5346                                 impl_def_id,
5347                                 self_ty,
5348                             });
5349                         }
5350                     }
5351                 }
5352             }
5353             _ => {}
5354         }
5355
5356         // Now that we have categorized what space the parameters for each
5357         // segment belong to, let's sort out the parameters that the user
5358         // provided (if any) into their appropriate spaces. We'll also report
5359         // errors if type parameters are provided in an inappropriate place.
5360
5361         let generic_segs: FxHashSet<_> = path_segs.iter().map(|PathSeg(_, index)| index).collect();
5362         let generics_has_err = AstConv::prohibit_generics(
5363                 self, segments.iter().enumerate().filter_map(|(index, seg)| {
5364             if !generic_segs.contains(&index) || is_alias_variant_ctor {
5365                 Some(seg)
5366             } else {
5367                 None
5368             }
5369         }));
5370         if generics_has_err {
5371             // Don't try to infer type parameters when prohibited generic arguments were given.
5372             user_self_ty = None;
5373         }
5374
5375         match def {
5376             Def::Local(nid) | Def::Upvar(nid, ..) => {
5377                 let ty = self.local_ty(span, nid).decl_ty;
5378                 let ty = self.normalize_associated_types_in(span, &ty);
5379                 self.write_ty(tcx.hir().node_to_hir_id(node_id), ty);
5380                 return (ty, def);
5381             }
5382             _ => {}
5383         }
5384
5385         // Now we have to compare the types that the user *actually*
5386         // provided against the types that were *expected*. If the user
5387         // did not provide any types, then we want to substitute inference
5388         // variables. If the user provided some types, we may still need
5389         // to add defaults. If the user provided *too many* types, that's
5390         // a problem.
5391
5392         let mut infer_args_for_err = FxHashSet::default();
5393         for &PathSeg(def_id, index) in &path_segs {
5394             let seg = &segments[index];
5395             let generics = tcx.generics_of(def_id);
5396             // Argument-position `impl Trait` is treated as a normal generic
5397             // parameter internally, but we don't allow users to specify the
5398             // parameter's value explicitly, so we have to do some error-
5399             // checking here.
5400             let suppress_errors = AstConv::check_generic_arg_count_for_call(
5401                 tcx,
5402                 span,
5403                 &generics,
5404                 &seg,
5405                 false, // `is_method_call`
5406             );
5407             if suppress_errors {
5408                 infer_args_for_err.insert(index);
5409                 self.set_tainted_by_errors(); // See issue #53251.
5410             }
5411         }
5412
5413         let has_self = path_segs.last().map(|PathSeg(def_id, _)| {
5414             tcx.generics_of(*def_id).has_self
5415         }).unwrap_or(false);
5416
5417         let mut new_def = def;
5418         let (def_id, ty) = match def {
5419             Def::SelfCtor(impl_def_id) => {
5420                 let ty = self.impl_self_ty(span, impl_def_id).ty;
5421                 let adt_def = ty.ty_adt_def();
5422
5423                 match adt_def {
5424                     Some(adt_def) if adt_def.has_ctor() => {
5425                         let variant = adt_def.non_enum_variant();
5426                         new_def = Def::StructCtor(variant.did, variant.ctor_kind);
5427                         (variant.did, tcx.type_of(variant.did))
5428                     }
5429                     _ => {
5430                         let mut err = tcx.sess.struct_span_err(span,
5431                             "the `Self` constructor can only be used with tuple or unit structs");
5432                         if let Some(adt_def) = adt_def {
5433                             match adt_def.adt_kind() {
5434                                 AdtKind::Enum => {
5435                                     err.help("did you mean to use one of the enum's variants?");
5436                                 },
5437                                 AdtKind::Struct |
5438                                 AdtKind::Union => {
5439                                     err.span_suggestion(
5440                                         span,
5441                                         "use curly brackets",
5442                                         String::from("Self { /* fields */ }"),
5443                                         Applicability::HasPlaceholders,
5444                                     );
5445                                 }
5446                             }
5447                         }
5448                         err.emit();
5449
5450                         (impl_def_id, tcx.types.err)
5451                     }
5452                 }
5453             }
5454             _ => {
5455                 let def_id = def.def_id();
5456
5457                 // The things we are substituting into the type should not contain
5458                 // escaping late-bound regions, and nor should the base type scheme.
5459                 let ty = tcx.type_of(def_id);
5460                 (def_id, ty)
5461             }
5462         };
5463
5464         let substs = AstConv::create_substs_for_generic_args(
5465             tcx,
5466             def_id,
5467             &[][..],
5468             has_self,
5469             self_ty,
5470             // Provide the generic args, and whether types should be inferred.
5471             |def_id| {
5472                 if let Some(&PathSeg(_, index)) = path_segs.iter().find(|&PathSeg(did, _)| {
5473                     *did == def_id
5474                 }) {
5475                     // If we've encountered an `impl Trait`-related error, we're just
5476                     // going to infer the arguments for better error messages.
5477                     if !infer_args_for_err.contains(&index) {
5478                         // Check whether the user has provided generic arguments.
5479                         if let Some(ref data) = segments[index].args {
5480                             return (Some(data), segments[index].infer_types);
5481                         }
5482                     }
5483                     return (None, segments[index].infer_types);
5484                 }
5485
5486                 (None, true)
5487             },
5488             // Provide substitutions for parameters for which (valid) arguments have been provided.
5489             |param, arg| {
5490                 match (&param.kind, arg) {
5491                     (GenericParamDefKind::Lifetime, GenericArg::Lifetime(lt)) => {
5492                         AstConv::ast_region_to_region(self, lt, Some(param)).into()
5493                     }
5494                     (GenericParamDefKind::Type { .. }, GenericArg::Type(ty)) => {
5495                         self.to_ty(ty).into()
5496                     }
5497                     _ => unreachable!(),
5498                 }
5499             },
5500             // Provide substitutions for parameters for which arguments are inferred.
5501             |substs, param, infer_types| {
5502                 match param.kind {
5503                     GenericParamDefKind::Lifetime => {
5504                         self.re_infer(span, Some(param)).unwrap().into()
5505                     }
5506                     GenericParamDefKind::Type { has_default, .. } => {
5507                         if !infer_types && has_default {
5508                             // If we have a default, then we it doesn't matter that we're not
5509                             // inferring the type arguments: we provide the default where any
5510                             // is missing.
5511                             let default = tcx.type_of(param.def_id);
5512                             self.normalize_ty(
5513                                 span,
5514                                 default.subst_spanned(tcx, substs.unwrap(), Some(span))
5515                             ).into()
5516                         } else {
5517                             // If no type arguments were provided, we have to infer them.
5518                             // This case also occurs as a result of some malformed input, e.g.
5519                             // a lifetime argument being given instead of a type parameter.
5520                             // Using inference instead of `Error` gives better error messages.
5521                             self.var_for_def(span, param)
5522                         }
5523                     }
5524                 }
5525             },
5526         );
5527         assert!(!substs.has_escaping_bound_vars());
5528         assert!(!ty.has_escaping_bound_vars());
5529
5530         // First, store the "user substs" for later.
5531         let hir_id = tcx.hir().node_to_hir_id(node_id);
5532         self.write_user_type_annotation_from_substs(hir_id, def_id, substs, user_self_ty);
5533
5534         // Add all the obligations that are required, substituting and
5535         // normalized appropriately.
5536         let bounds = self.instantiate_bounds(span, def_id, &substs);
5537         self.add_obligations_for_parameters(
5538             traits::ObligationCause::new(span, self.body_id, traits::ItemObligation(def_id)),
5539             &bounds);
5540
5541         // Substitute the values for the type parameters into the type of
5542         // the referenced item.
5543         let ty_substituted = self.instantiate_type_scheme(span, &substs, &ty);
5544
5545         if let Some(UserSelfTy { impl_def_id, self_ty }) = user_self_ty {
5546             // In the case of `Foo<T>::method` and `<Foo<T>>::method`, if `method`
5547             // is inherent, there is no `Self` parameter; instead, the impl needs
5548             // type parameters, which we can infer by unifying the provided `Self`
5549             // with the substituted impl type.
5550             // This also occurs for an enum variant on a type alias.
5551             let ty = tcx.type_of(impl_def_id);
5552
5553             let impl_ty = self.instantiate_type_scheme(span, &substs, &ty);
5554             match self.at(&self.misc(span), self.param_env).sup(impl_ty, self_ty) {
5555                 Ok(ok) => self.register_infer_ok_obligations(ok),
5556                 Err(_) => {
5557                     span_bug!(span,
5558                         "instantiate_value_path: (UFCS) {:?} was a subtype of {:?} but now is not?",
5559                         self_ty,
5560                         impl_ty);
5561                 }
5562             }
5563         }
5564
5565         self.check_rustc_args_require_const(def_id, node_id, span);
5566
5567         debug!("instantiate_value_path: type of {:?} is {:?}",
5568                node_id,
5569                ty_substituted);
5570         self.write_substs(hir_id, substs);
5571
5572         (ty_substituted, new_def)
5573     }
5574
5575     fn check_rustc_args_require_const(&self,
5576                                       def_id: DefId,
5577                                       node_id: ast::NodeId,
5578                                       span: Span) {
5579         // We're only interested in functions tagged with
5580         // #[rustc_args_required_const], so ignore anything that's not.
5581         if !self.tcx.has_attr(def_id, "rustc_args_required_const") {
5582             return
5583         }
5584
5585         // If our calling expression is indeed the function itself, we're good!
5586         // If not, generate an error that this can only be called directly.
5587         if let Node::Expr(expr) = self.tcx.hir().get(self.tcx.hir().get_parent_node(node_id)) {
5588             if let ExprKind::Call(ref callee, ..) = expr.node {
5589                 if callee.id == node_id {
5590                     return
5591                 }
5592             }
5593         }
5594
5595         self.tcx.sess.span_err(span, "this function can only be invoked \
5596                                       directly, not through a function pointer");
5597     }
5598
5599     // Resolves `typ` by a single level if `typ` is a type variable.
5600     // If no resolution is possible, then an error is reported.
5601     // Numeric inference variables may be left unresolved.
5602     pub fn structurally_resolved_type(&self, sp: Span, ty: Ty<'tcx>) -> Ty<'tcx> {
5603         let ty = self.resolve_type_vars_with_obligations(ty);
5604         if !ty.is_ty_var() {
5605             ty
5606         } else {
5607             if !self.is_tainted_by_errors() {
5608                 self.need_type_info_err((**self).body_id, sp, ty)
5609                     .note("type must be known at this point")
5610                     .emit();
5611             }
5612             self.demand_suptype(sp, self.tcx.types.err, ty);
5613             self.tcx.types.err
5614         }
5615     }
5616
5617     fn with_breakable_ctxt<F: FnOnce() -> R, R>(&self, id: ast::NodeId,
5618                                                 ctxt: BreakableCtxt<'gcx, 'tcx>, f: F)
5619                                                 -> (BreakableCtxt<'gcx, 'tcx>, R) {
5620         let index;
5621         {
5622             let mut enclosing_breakables = self.enclosing_breakables.borrow_mut();
5623             index = enclosing_breakables.stack.len();
5624             enclosing_breakables.by_id.insert(id, index);
5625             enclosing_breakables.stack.push(ctxt);
5626         }
5627         let result = f();
5628         let ctxt = {
5629             let mut enclosing_breakables = self.enclosing_breakables.borrow_mut();
5630             debug_assert!(enclosing_breakables.stack.len() == index + 1);
5631             enclosing_breakables.by_id.remove(&id).expect("missing breakable context");
5632             enclosing_breakables.stack.pop().expect("missing breakable context")
5633         };
5634         (ctxt, result)
5635     }
5636
5637     /// Instantiate a QueryResponse in a probe context, without a
5638     /// good ObligationCause.
5639     fn probe_instantiate_query_response(
5640         &self,
5641         span: Span,
5642         original_values: &OriginalQueryValues<'tcx>,
5643         query_result: &Canonical<'tcx, QueryResponse<'tcx, Ty<'tcx>>>,
5644     ) -> InferResult<'tcx, Ty<'tcx>>
5645     {
5646         self.instantiate_query_response_and_region_obligations(
5647             &traits::ObligationCause::misc(span, self.body_id),
5648             self.param_env,
5649             original_values,
5650             query_result)
5651     }
5652
5653     /// Returns whether an expression is contained inside the LHS of an assignment expression.
5654     fn expr_in_place(&self, mut expr_id: ast::NodeId) -> bool {
5655         let mut contained_in_place = false;
5656
5657         while let hir::Node::Expr(parent_expr) =
5658             self.tcx.hir().get(self.tcx.hir().get_parent_node(expr_id))
5659         {
5660             match &parent_expr.node {
5661                 hir::ExprKind::Assign(lhs, ..) | hir::ExprKind::AssignOp(_, lhs, ..) => {
5662                     if lhs.id == expr_id {
5663                         contained_in_place = true;
5664                         break;
5665                     }
5666                 }
5667                 _ => (),
5668             }
5669             expr_id = parent_expr.id;
5670         }
5671
5672         contained_in_place
5673     }
5674 }
5675
5676 pub fn check_bounds_are_used<'a, 'tcx>(tcx: TyCtxt<'a, 'tcx, 'tcx>,
5677                                        generics: &ty::Generics,
5678                                        ty: Ty<'tcx>) {
5679     let own_counts = generics.own_counts();
5680     debug!("check_bounds_are_used(n_tps={}, ty={:?})", own_counts.types, ty);
5681
5682     if own_counts.types == 0 {
5683         return;
5684     }
5685     // Make a vector of booleans initially false, set to true when used.
5686     let mut types_used = vec![false; own_counts.types];
5687
5688     for leaf_ty in ty.walk() {
5689         if let ty::Param(ty::ParamTy { idx, .. }) = leaf_ty.sty {
5690             debug!("Found use of ty param num {}", idx);
5691             types_used[idx as usize - own_counts.lifetimes] = true;
5692         } else if let ty::Error = leaf_ty.sty {
5693             // If there is already another error, do not emit
5694             // an error for not using a type Parameter.
5695             assert!(tcx.sess.err_count() > 0);
5696             return;
5697         }
5698     }
5699
5700     let types = generics.params.iter().filter(|param| match param.kind {
5701         ty::GenericParamDefKind::Type { .. } => true,
5702         _ => false,
5703     });
5704     for (&used, param) in types_used.iter().zip(types) {
5705         if !used {
5706             let id = tcx.hir().as_local_node_id(param.def_id).unwrap();
5707             let span = tcx.hir().span(id);
5708             struct_span_err!(tcx.sess, span, E0091, "type parameter `{}` is unused", param.name)
5709                 .span_label(span, "unused type parameter")
5710                 .emit();
5711         }
5712     }
5713 }
5714
5715 fn fatally_break_rust(sess: &Session) {
5716     let handler = sess.diagnostic();
5717     handler.span_bug_no_panic(
5718         MultiSpan::new(),
5719         "It looks like you're trying to break rust; would you like some ICE?",
5720     );
5721     handler.note_without_error("the compiler expectedly panicked. this is a feature.");
5722     handler.note_without_error(
5723         "we would appreciate a joke overview: \
5724         https://github.com/rust-lang/rust/issues/43162#issuecomment-320764675"
5725     );
5726     handler.note_without_error(&format!("rustc {} running on {}",
5727         option_env!("CFG_VERSION").unwrap_or("unknown_version"),
5728         ::session::config::host_triple(),
5729     ));
5730 }
5731
5732 fn potentially_plural_count(count: usize, word: &str) -> String {
5733     format!("{} {}{}", count, word, if count == 1 { "" } else { "s" })
5734 }