01a25ad6e1e703792aade1084291282abc3485c8
[platform/upstream/gcc.git] / gcc / cp / call.c
1 /* Functions related to invoking -*- C++ -*- methods and overloaded functions.
2    Copyright (C) 1987-2019 Free Software Foundation, Inc.
3    Contributed by Michael Tiemann (tiemann@cygnus.com) and
4    modified by Brendan Kehoe (brendan@cygnus.com).
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3, or (at your option)
11 any later version.
12
13 GCC is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3.  If not see
20 <http://www.gnu.org/licenses/>.  */
21
22
23 /* High-level class interface.  */
24
25 #include "config.h"
26 #include "system.h"
27 #include "coretypes.h"
28 #include "target.h"
29 #include "cp-tree.h"
30 #include "timevar.h"
31 #include "stringpool.h"
32 #include "cgraph.h"
33 #include "stor-layout.h"
34 #include "trans-mem.h"
35 #include "flags.h"
36 #include "toplev.h"
37 #include "intl.h"
38 #include "convert.h"
39 #include "langhooks.h"
40 #include "c-family/c-objc.h"
41 #include "internal-fn.h"
42 #include "stringpool.h"
43 #include "attribs.h"
44 #include "gcc-rich-location.h"
45
46 /* The various kinds of conversion.  */
47
48 enum conversion_kind {
49   ck_identity,
50   ck_lvalue,
51   ck_fnptr,
52   ck_qual,
53   ck_std,
54   ck_ptr,
55   ck_pmem,
56   ck_base,
57   ck_ref_bind,
58   ck_user,
59   ck_ambig,
60   ck_list,
61   ck_aggr,
62   ck_rvalue
63 };
64
65 /* The rank of the conversion.  Order of the enumerals matters; better
66    conversions should come earlier in the list.  */
67
68 enum conversion_rank {
69   cr_identity,
70   cr_exact,
71   cr_promotion,
72   cr_std,
73   cr_pbool,
74   cr_user,
75   cr_ellipsis,
76   cr_bad
77 };
78
79 /* An implicit conversion sequence, in the sense of [over.best.ics].
80    The first conversion to be performed is at the end of the chain.
81    That conversion is always a cr_identity conversion.  */
82
83 struct conversion {
84   /* The kind of conversion represented by this step.  */
85   conversion_kind kind;
86   /* The rank of this conversion.  */
87   conversion_rank rank;
88   BOOL_BITFIELD user_conv_p : 1;
89   BOOL_BITFIELD ellipsis_p : 1;
90   BOOL_BITFIELD this_p : 1;
91   /* True if this conversion would be permitted with a bending of
92      language standards, e.g. disregarding pointer qualifiers or
93      converting integers to pointers.  */
94   BOOL_BITFIELD bad_p : 1;
95   /* If KIND is ck_ref_bind ck_base_conv, true to indicate that a
96      temporary should be created to hold the result of the
97      conversion.  If KIND is ck_ambig or ck_user, true means force
98      copy-initialization.  */
99   BOOL_BITFIELD need_temporary_p : 1;
100   /* If KIND is ck_ptr or ck_pmem, true to indicate that a conversion
101      from a pointer-to-derived to pointer-to-base is being performed.  */
102   BOOL_BITFIELD base_p : 1;
103   /* If KIND is ck_ref_bind, true when either an lvalue reference is
104      being bound to an lvalue expression or an rvalue reference is
105      being bound to an rvalue expression.  If KIND is ck_rvalue or ck_base,
106      true when we are treating an lvalue as an rvalue (12.8p33).  If
107      ck_identity, we will be binding a reference directly or decaying to
108      a pointer.  */
109   BOOL_BITFIELD rvaluedness_matches_p: 1;
110   BOOL_BITFIELD check_narrowing: 1;
111   /* Whether check_narrowing should only check TREE_CONSTANTs; used
112      in build_converted_constant_expr.  */
113   BOOL_BITFIELD check_narrowing_const_only: 1;
114   /* The type of the expression resulting from the conversion.  */
115   tree type;
116   union {
117     /* The next conversion in the chain.  Since the conversions are
118        arranged from outermost to innermost, the NEXT conversion will
119        actually be performed before this conversion.  This variant is
120        used only when KIND is neither ck_identity, ck_ambig nor
121        ck_list.  Please use the next_conversion function instead
122        of using this field directly.  */
123     conversion *next;
124     /* The expression at the beginning of the conversion chain.  This
125        variant is used only if KIND is ck_identity or ck_ambig.  */
126     tree expr;
127     /* The array of conversions for an initializer_list, so this
128        variant is used only when KIN D is ck_list.  */
129     conversion **list;
130   } u;
131   /* The function candidate corresponding to this conversion
132      sequence.  This field is only used if KIND is ck_user.  */
133   struct z_candidate *cand;
134 };
135
136 #define CONVERSION_RANK(NODE)                   \
137   ((NODE)->bad_p ? cr_bad                       \
138    : (NODE)->ellipsis_p ? cr_ellipsis           \
139    : (NODE)->user_conv_p ? cr_user              \
140    : (NODE)->rank)
141
142 #define BAD_CONVERSION_RANK(NODE)               \
143   ((NODE)->ellipsis_p ? cr_ellipsis             \
144    : (NODE)->user_conv_p ? cr_user              \
145    : (NODE)->rank)
146
147 static struct obstack conversion_obstack;
148 static bool conversion_obstack_initialized;
149 struct rejection_reason;
150
151 static struct z_candidate * tourney (struct z_candidate *, tsubst_flags_t);
152 static int equal_functions (tree, tree);
153 static int joust (struct z_candidate *, struct z_candidate *, bool,
154                   tsubst_flags_t);
155 static int compare_ics (conversion *, conversion *);
156 static void maybe_warn_class_memaccess (location_t, tree,
157                                         const vec<tree, va_gc> *);
158 static tree build_over_call (struct z_candidate *, int, tsubst_flags_t);
159 #define convert_like(CONV, EXPR, COMPLAIN)                      \
160   convert_like_real ((CONV), (EXPR), NULL_TREE, 0,              \
161                      /*issue_conversion_warnings=*/true,        \
162                      /*c_cast_p=*/false, (COMPLAIN))
163 #define convert_like_with_context(CONV, EXPR, FN, ARGNO, COMPLAIN )     \
164   convert_like_real ((CONV), (EXPR), (FN), (ARGNO),                     \
165                      /*issue_conversion_warnings=*/true,                \
166                      /*c_cast_p=*/false, (COMPLAIN))
167 static tree convert_like_real (conversion *, tree, tree, int, bool,
168                                bool, tsubst_flags_t);
169 static void op_error (const op_location_t &, enum tree_code, enum tree_code,
170                       tree, tree, tree, bool);
171 static struct z_candidate *build_user_type_conversion_1 (tree, tree, int,
172                                                          tsubst_flags_t);
173 static void print_z_candidate (location_t, const char *, struct z_candidate *);
174 static void print_z_candidates (location_t, struct z_candidate *);
175 static tree build_this (tree);
176 static struct z_candidate *splice_viable (struct z_candidate *, bool, bool *);
177 static bool any_strictly_viable (struct z_candidate *);
178 static struct z_candidate *add_template_candidate
179         (struct z_candidate **, tree, tree, tree, tree, const vec<tree, va_gc> *,
180          tree, tree, tree, int, unification_kind_t, tsubst_flags_t);
181 static struct z_candidate *add_template_candidate_real
182         (struct z_candidate **, tree, tree, tree, tree, const vec<tree, va_gc> *,
183          tree, tree, tree, int, tree, unification_kind_t, tsubst_flags_t);
184 static void add_builtin_candidates
185         (struct z_candidate **, enum tree_code, enum tree_code,
186          tree, tree *, int, tsubst_flags_t);
187 static void add_builtin_candidate
188         (struct z_candidate **, enum tree_code, enum tree_code,
189          tree, tree, tree, tree *, tree *, int, tsubst_flags_t);
190 static bool is_complete (tree);
191 static void build_builtin_candidate
192         (struct z_candidate **, tree, tree, tree, tree *, tree *,
193          int, tsubst_flags_t);
194 static struct z_candidate *add_conv_candidate
195         (struct z_candidate **, tree, tree, const vec<tree, va_gc> *, tree,
196          tree, tsubst_flags_t);
197 static struct z_candidate *add_function_candidate
198         (struct z_candidate **, tree, tree, tree, const vec<tree, va_gc> *, tree,
199          tree, int, conversion**, tsubst_flags_t);
200 static conversion *implicit_conversion (tree, tree, tree, bool, int,
201                                         tsubst_flags_t);
202 static conversion *reference_binding (tree, tree, tree, bool, int,
203                                       tsubst_flags_t);
204 static conversion *build_conv (conversion_kind, tree, conversion *);
205 static conversion *build_list_conv (tree, tree, int, tsubst_flags_t);
206 static conversion *next_conversion (conversion *);
207 static bool is_subseq (conversion *, conversion *);
208 static conversion *maybe_handle_ref_bind (conversion **);
209 static void maybe_handle_implicit_object (conversion **);
210 static struct z_candidate *add_candidate
211         (struct z_candidate **, tree, tree, const vec<tree, va_gc> *, size_t,
212          conversion **, tree, tree, int, struct rejection_reason *, int);
213 static tree source_type (conversion *);
214 static void add_warning (struct z_candidate *, struct z_candidate *);
215 static bool reference_compatible_p (tree, tree);
216 static conversion *direct_reference_binding (tree, conversion *);
217 static bool promoted_arithmetic_type_p (tree);
218 static conversion *conditional_conversion (tree, tree, tsubst_flags_t);
219 static char *name_as_c_string (tree, tree, bool *);
220 static tree prep_operand (tree);
221 static void add_candidates (tree, tree, const vec<tree, va_gc> *, tree, tree,
222                             bool, tree, tree, int, struct z_candidate **,
223                             tsubst_flags_t);
224 static conversion *merge_conversion_sequences (conversion *, conversion *);
225 static tree build_temp (tree, tree, int, diagnostic_t *, tsubst_flags_t);
226
227 /* Returns nonzero iff the destructor name specified in NAME matches BASETYPE.
228    NAME can take many forms...  */
229
230 bool
231 check_dtor_name (tree basetype, tree name)
232 {
233   /* Just accept something we've already complained about.  */
234   if (name == error_mark_node)
235     return true;
236
237   if (TREE_CODE (name) == TYPE_DECL)
238     name = TREE_TYPE (name);
239   else if (TYPE_P (name))
240     /* OK */;
241   else if (identifier_p (name))
242     {
243       if ((MAYBE_CLASS_TYPE_P (basetype)
244            || TREE_CODE (basetype) == ENUMERAL_TYPE)
245           && name == constructor_name (basetype))
246         return true;
247       else
248         name = get_type_value (name);
249     }
250   else
251     {
252       /* In the case of:
253
254          template <class T> struct S { ~S(); };
255          int i;
256          i.~S();
257
258          NAME will be a class template.  */
259       gcc_assert (DECL_CLASS_TEMPLATE_P (name));
260       return false;
261     }
262
263   if (!name || name == error_mark_node)
264     return false;
265   return same_type_p (TYPE_MAIN_VARIANT (basetype), TYPE_MAIN_VARIANT (name));
266 }
267
268 /* We want the address of a function or method.  We avoid creating a
269    pointer-to-member function.  */
270
271 tree
272 build_addr_func (tree function, tsubst_flags_t complain)
273 {
274   tree type = TREE_TYPE (function);
275
276   /* We have to do these by hand to avoid real pointer to member
277      functions.  */
278   if (TREE_CODE (type) == METHOD_TYPE)
279     {
280       if (TREE_CODE (function) == OFFSET_REF)
281         {
282           tree object = build_address (TREE_OPERAND (function, 0));
283           return get_member_function_from_ptrfunc (&object,
284                                                    TREE_OPERAND (function, 1),
285                                                    complain);
286         }
287       function = build_address (function);
288     }
289   else
290     function = decay_conversion (function, complain, /*reject_builtin=*/false);
291
292   return function;
293 }
294
295 /* Build a CALL_EXPR, we can handle FUNCTION_TYPEs, METHOD_TYPEs, or
296    POINTER_TYPE to those.  Note, pointer to member function types
297    (TYPE_PTRMEMFUNC_P) must be handled by our callers.  There are
298    two variants.  build_call_a is the primitive taking an array of
299    arguments, while build_call_n is a wrapper that handles varargs.  */
300
301 tree
302 build_call_n (tree function, int n, ...)
303 {
304   if (n == 0)
305     return build_call_a (function, 0, NULL);
306   else
307     {
308       tree *argarray = XALLOCAVEC (tree, n);
309       va_list ap;
310       int i;
311
312       va_start (ap, n);
313       for (i = 0; i < n; i++)
314         argarray[i] = va_arg (ap, tree);
315       va_end (ap);
316       return build_call_a (function, n, argarray);
317     }
318 }
319
320 /* Update various flags in cfun and the call itself based on what is being
321    called.  Split out of build_call_a so that bot_manip can use it too.  */
322
323 void
324 set_flags_from_callee (tree call)
325 {
326   /* Handle both CALL_EXPRs and AGGR_INIT_EXPRs.  */
327   tree decl = cp_get_callee_fndecl_nofold (call);
328
329   /* We check both the decl and the type; a function may be known not to
330      throw without being declared throw().  */
331   bool nothrow = decl && TREE_NOTHROW (decl);
332   tree callee = cp_get_callee (call);
333   if (callee)
334     nothrow |= TYPE_NOTHROW_P (TREE_TYPE (TREE_TYPE (callee)));
335   else if (TREE_CODE (call) == CALL_EXPR
336            && internal_fn_flags (CALL_EXPR_IFN (call)) & ECF_NOTHROW)
337     nothrow = true;
338
339   if (!nothrow && at_function_scope_p () && cfun && cp_function_chain)
340     cp_function_chain->can_throw = 1;
341
342   if (decl && TREE_THIS_VOLATILE (decl) && cfun && cp_function_chain)
343     current_function_returns_abnormally = 1;
344
345   TREE_NOTHROW (call) = nothrow;
346 }
347
348 tree
349 build_call_a (tree function, int n, tree *argarray)
350 {
351   tree decl;
352   tree result_type;
353   tree fntype;
354   int i;
355
356   function = build_addr_func (function, tf_warning_or_error);
357
358   gcc_assert (TYPE_PTR_P (TREE_TYPE (function)));
359   fntype = TREE_TYPE (TREE_TYPE (function));
360   gcc_assert (FUNC_OR_METHOD_TYPE_P (fntype));
361   result_type = TREE_TYPE (fntype);
362   /* An rvalue has no cv-qualifiers.  */
363   if (SCALAR_TYPE_P (result_type) || VOID_TYPE_P (result_type))
364     result_type = cv_unqualified (result_type);
365
366   function = build_call_array_loc (input_location,
367                                    result_type, function, n, argarray);
368   set_flags_from_callee (function);
369
370   decl = get_callee_fndecl (function);
371
372   if (decl && !TREE_USED (decl))
373     {
374       /* We invoke build_call directly for several library
375          functions.  These may have been declared normally if
376          we're building libgcc, so we can't just check
377          DECL_ARTIFICIAL.  */
378       gcc_assert (DECL_ARTIFICIAL (decl)
379                   || !strncmp (IDENTIFIER_POINTER (DECL_NAME (decl)),
380                                "__", 2));
381       mark_used (decl);
382     }
383
384   require_complete_eh_spec_types (fntype, decl);
385
386   TREE_HAS_CONSTRUCTOR (function) = (decl && DECL_CONSTRUCTOR_P (decl));
387
388   /* Don't pass empty class objects by value.  This is useful
389      for tags in STL, which are used to control overload resolution.
390      We don't need to handle other cases of copying empty classes.  */
391   if (!decl || !fndecl_built_in_p (decl))
392     for (i = 0; i < n; i++)
393       {
394         tree arg = CALL_EXPR_ARG (function, i);
395         if (is_empty_class (TREE_TYPE (arg))
396             && simple_empty_class_p (TREE_TYPE (arg), arg, INIT_EXPR))
397           {
398             tree t = build0 (EMPTY_CLASS_EXPR, TREE_TYPE (arg));
399             arg = build2 (COMPOUND_EXPR, TREE_TYPE (t), arg, t);
400             CALL_EXPR_ARG (function, i) = arg;
401           }
402       }
403
404   return function;
405 }
406
407 /* New overloading code.  */
408
409 struct z_candidate;
410
411 struct candidate_warning {
412   z_candidate *loser;
413   candidate_warning *next;
414 };
415
416 /* Information for providing diagnostics about why overloading failed.  */
417
418 enum rejection_reason_code {
419   rr_none,
420   rr_arity,
421   rr_explicit_conversion,
422   rr_template_conversion,
423   rr_arg_conversion,
424   rr_bad_arg_conversion,
425   rr_template_unification,
426   rr_invalid_copy,
427   rr_inherited_ctor,
428   rr_constraint_failure
429 };
430
431 struct conversion_info {
432   /* The index of the argument, 0-based.  */
433   int n_arg;
434   /* The actual argument or its type.  */
435   tree from;
436   /* The type of the parameter.  */
437   tree to_type;
438   /* The location of the argument.  */
439   location_t loc;
440 };
441   
442 struct rejection_reason {
443   enum rejection_reason_code code;
444   union {
445     /* Information about an arity mismatch.  */
446     struct {
447       /* The expected number of arguments.  */
448       int expected;
449       /* The actual number of arguments in the call.  */
450       int actual;
451       /* Whether the call was a varargs call.  */
452       bool call_varargs_p;
453     } arity;
454     /* Information about an argument conversion mismatch.  */
455     struct conversion_info conversion;
456     /* Same, but for bad argument conversions.  */
457     struct conversion_info bad_conversion;
458     /* Information about template unification failures.  These are the
459        parameters passed to fn_type_unification.  */
460     struct {
461       tree tmpl;
462       tree explicit_targs;
463       int num_targs;
464       const tree *args;
465       unsigned int nargs;
466       tree return_type;
467       unification_kind_t strict;
468       int flags;
469     } template_unification;
470     /* Information about template instantiation failures.  These are the
471        parameters passed to instantiate_template.  */
472     struct {
473       tree tmpl;
474       tree targs;
475     } template_instantiation;
476   } u;
477 };
478
479 struct z_candidate {
480   /* The FUNCTION_DECL that will be called if this candidate is
481      selected by overload resolution.  */
482   tree fn;
483   /* If not NULL_TREE, the first argument to use when calling this
484      function.  */
485   tree first_arg;
486   /* The rest of the arguments to use when calling this function.  If
487      there are no further arguments this may be NULL or it may be an
488      empty vector.  */
489   const vec<tree, va_gc> *args;
490   /* The implicit conversion sequences for each of the arguments to
491      FN.  */
492   conversion **convs;
493   /* The number of implicit conversion sequences.  */
494   size_t num_convs;
495   /* If FN is a user-defined conversion, the standard conversion
496      sequence from the type returned by FN to the desired destination
497      type.  */
498   conversion *second_conv;
499   struct rejection_reason *reason;
500   /* If FN is a member function, the binfo indicating the path used to
501      qualify the name of FN at the call site.  This path is used to
502      determine whether or not FN is accessible if it is selected by
503      overload resolution.  The DECL_CONTEXT of FN will always be a
504      (possibly improper) base of this binfo.  */
505   tree access_path;
506   /* If FN is a non-static member function, the binfo indicating the
507      subobject to which the `this' pointer should be converted if FN
508      is selected by overload resolution.  The type pointed to by
509      the `this' pointer must correspond to the most derived class
510      indicated by the CONVERSION_PATH.  */
511   tree conversion_path;
512   tree template_decl;
513   tree explicit_targs;
514   candidate_warning *warnings;
515   z_candidate *next;
516   int viable;
517
518   /* The flags active in add_candidate.  */
519   int flags;
520 };
521
522 /* Returns true iff T is a null pointer constant in the sense of
523    [conv.ptr].  */
524
525 bool
526 null_ptr_cst_p (tree t)
527 {
528   tree type = TREE_TYPE (t);
529
530   /* [conv.ptr]
531
532      A null pointer constant is an integer literal ([lex.icon]) with value
533      zero or a prvalue of type std::nullptr_t.  */
534   if (NULLPTR_TYPE_P (type))
535     return true;
536
537   if (cxx_dialect >= cxx11)
538     {
539       STRIP_ANY_LOCATION_WRAPPER (t);
540
541       /* Core issue 903 says only literal 0 is a null pointer constant.  */
542       if (TREE_CODE (t) == INTEGER_CST
543           && !TREE_OVERFLOW (t)
544           && TREE_CODE (type) == INTEGER_TYPE
545           && integer_zerop (t)
546           && !char_type_p (type))
547         return true;
548     }
549   else if (CP_INTEGRAL_TYPE_P (type))
550     {
551       t = fold_non_dependent_expr (t, tf_none);
552       STRIP_NOPS (t);
553       if (integer_zerop (t) && !TREE_OVERFLOW (t))
554         return true;
555     }
556
557   return false;
558 }
559
560 /* Returns true iff T is a null member pointer value (4.11).  */
561
562 bool
563 null_member_pointer_value_p (tree t)
564 {
565   tree type = TREE_TYPE (t);
566   if (!type)
567     return false;
568   else if (TYPE_PTRMEMFUNC_P (type))
569     return (TREE_CODE (t) == CONSTRUCTOR
570             && CONSTRUCTOR_NELTS (t)
571             && integer_zerop (CONSTRUCTOR_ELT (t, 0)->value));
572   else if (TYPE_PTRDATAMEM_P (type))
573     return integer_all_onesp (t);
574   else
575     return false;
576 }
577
578 /* Returns nonzero if PARMLIST consists of only default parms,
579    ellipsis, and/or undeduced parameter packs.  */
580
581 bool
582 sufficient_parms_p (const_tree parmlist)
583 {
584   for (; parmlist && parmlist != void_list_node;
585        parmlist = TREE_CHAIN (parmlist))
586     if (!TREE_PURPOSE (parmlist)
587         && !PACK_EXPANSION_P (TREE_VALUE (parmlist)))
588       return false;
589   return true;
590 }
591
592 /* Allocate N bytes of memory from the conversion obstack.  The memory
593    is zeroed before being returned.  */
594
595 static void *
596 conversion_obstack_alloc (size_t n)
597 {
598   void *p;
599   if (!conversion_obstack_initialized)
600     {
601       gcc_obstack_init (&conversion_obstack);
602       conversion_obstack_initialized = true;
603     }
604   p = obstack_alloc (&conversion_obstack, n);
605   memset (p, 0, n);
606   return p;
607 }
608
609 /* Allocate rejection reasons.  */
610
611 static struct rejection_reason *
612 alloc_rejection (enum rejection_reason_code code)
613 {
614   struct rejection_reason *p;
615   p = (struct rejection_reason *) conversion_obstack_alloc (sizeof *p);
616   p->code = code;
617   return p;
618 }
619
620 static struct rejection_reason *
621 arity_rejection (tree first_arg, int expected, int actual)
622 {
623   struct rejection_reason *r = alloc_rejection (rr_arity);
624   int adjust = first_arg != NULL_TREE;
625   r->u.arity.expected = expected - adjust;
626   r->u.arity.actual = actual - adjust;
627   return r;
628 }
629
630 static struct rejection_reason *
631 arg_conversion_rejection (tree first_arg, int n_arg, tree from, tree to,
632                           location_t loc)
633 {
634   struct rejection_reason *r = alloc_rejection (rr_arg_conversion);
635   int adjust = first_arg != NULL_TREE;
636   r->u.conversion.n_arg = n_arg - adjust;
637   r->u.conversion.from = from;
638   r->u.conversion.to_type = to;
639   r->u.conversion.loc = loc;
640   return r;
641 }
642
643 static struct rejection_reason *
644 bad_arg_conversion_rejection (tree first_arg, int n_arg, tree from, tree to,
645                               location_t loc)
646 {
647   struct rejection_reason *r = alloc_rejection (rr_bad_arg_conversion);
648   int adjust = first_arg != NULL_TREE;
649   r->u.bad_conversion.n_arg = n_arg - adjust;
650   r->u.bad_conversion.from = from;
651   r->u.bad_conversion.to_type = to;
652   r->u.bad_conversion.loc = loc;
653   return r;
654 }
655
656 static struct rejection_reason *
657 explicit_conversion_rejection (tree from, tree to)
658 {
659   struct rejection_reason *r = alloc_rejection (rr_explicit_conversion);
660   r->u.conversion.n_arg = 0;
661   r->u.conversion.from = from;
662   r->u.conversion.to_type = to;
663   r->u.conversion.loc = UNKNOWN_LOCATION;
664   return r;
665 }
666
667 static struct rejection_reason *
668 template_conversion_rejection (tree from, tree to)
669 {
670   struct rejection_reason *r = alloc_rejection (rr_template_conversion);
671   r->u.conversion.n_arg = 0;
672   r->u.conversion.from = from;
673   r->u.conversion.to_type = to;
674   r->u.conversion.loc = UNKNOWN_LOCATION;
675   return r;
676 }
677
678 static struct rejection_reason *
679 template_unification_rejection (tree tmpl, tree explicit_targs, tree targs,
680                                 const tree *args, unsigned int nargs,
681                                 tree return_type, unification_kind_t strict,
682                                 int flags)
683 {
684   size_t args_n_bytes = sizeof (*args) * nargs;
685   tree *args1 = (tree *) conversion_obstack_alloc (args_n_bytes);
686   struct rejection_reason *r = alloc_rejection (rr_template_unification);
687   r->u.template_unification.tmpl = tmpl;
688   r->u.template_unification.explicit_targs = explicit_targs;
689   r->u.template_unification.num_targs = TREE_VEC_LENGTH (targs);
690   /* Copy args to our own storage.  */
691   memcpy (args1, args, args_n_bytes);
692   r->u.template_unification.args = args1;
693   r->u.template_unification.nargs = nargs;
694   r->u.template_unification.return_type = return_type;
695   r->u.template_unification.strict = strict;
696   r->u.template_unification.flags = flags;
697   return r;
698 }
699
700 static struct rejection_reason *
701 template_unification_error_rejection (void)
702 {
703   return alloc_rejection (rr_template_unification);
704 }
705
706 static struct rejection_reason *
707 invalid_copy_with_fn_template_rejection (void)
708 {
709   struct rejection_reason *r = alloc_rejection (rr_invalid_copy);
710   return r;
711 }
712
713 static struct rejection_reason *
714 inherited_ctor_rejection (void)
715 {
716   struct rejection_reason *r = alloc_rejection (rr_inherited_ctor);
717   return r;
718 }
719
720 // Build a constraint failure record, saving information into the
721 // template_instantiation field of the rejection. If FN is not a template
722 // declaration, the TMPL member is the FN declaration and TARGS is empty.
723
724 static struct rejection_reason *
725 constraint_failure (tree fn)
726 {
727   struct rejection_reason *r = alloc_rejection (rr_constraint_failure);
728   if (tree ti = DECL_TEMPLATE_INFO (fn))
729     {
730       r->u.template_instantiation.tmpl = TI_TEMPLATE (ti);
731       r->u.template_instantiation.targs = TI_ARGS (ti);
732     }
733   else
734     {
735       r->u.template_instantiation.tmpl = fn;
736       r->u.template_instantiation.targs = NULL_TREE;
737     }
738   return r;
739 }
740
741 /* Dynamically allocate a conversion.  */
742
743 static conversion *
744 alloc_conversion (conversion_kind kind)
745 {
746   conversion *c;
747   c = (conversion *) conversion_obstack_alloc (sizeof (conversion));
748   c->kind = kind;
749   return c;
750 }
751
752 /* Make sure that all memory on the conversion obstack has been
753    freed.  */
754
755 void
756 validate_conversion_obstack (void)
757 {
758   if (conversion_obstack_initialized)
759     gcc_assert ((obstack_next_free (&conversion_obstack)
760                  == obstack_base (&conversion_obstack)));
761 }
762
763 /* Dynamically allocate an array of N conversions.  */
764
765 static conversion **
766 alloc_conversions (size_t n)
767 {
768   return (conversion **) conversion_obstack_alloc (n * sizeof (conversion *));
769 }
770
771 static conversion *
772 build_conv (conversion_kind code, tree type, conversion *from)
773 {
774   conversion *t;
775   conversion_rank rank = CONVERSION_RANK (from);
776
777   /* Note that the caller is responsible for filling in t->cand for
778      user-defined conversions.  */
779   t = alloc_conversion (code);
780   t->type = type;
781   t->u.next = from;
782
783   switch (code)
784     {
785     case ck_ptr:
786     case ck_pmem:
787     case ck_base:
788     case ck_std:
789       if (rank < cr_std)
790         rank = cr_std;
791       break;
792
793     case ck_qual:
794     case ck_fnptr:
795       if (rank < cr_exact)
796         rank = cr_exact;
797       break;
798
799     default:
800       break;
801     }
802   t->rank = rank;
803   t->user_conv_p = (code == ck_user || from->user_conv_p);
804   t->bad_p = from->bad_p;
805   t->base_p = false;
806   return t;
807 }
808
809 /* Represent a conversion from CTOR, a braced-init-list, to TYPE, a
810    specialization of std::initializer_list<T>, if such a conversion is
811    possible.  */
812
813 static conversion *
814 build_list_conv (tree type, tree ctor, int flags, tsubst_flags_t complain)
815 {
816   tree elttype = TREE_VEC_ELT (CLASSTYPE_TI_ARGS (type), 0);
817   unsigned len = CONSTRUCTOR_NELTS (ctor);
818   conversion **subconvs = alloc_conversions (len);
819   conversion *t;
820   unsigned i;
821   tree val;
822
823   /* Within a list-initialization we can have more user-defined
824      conversions.  */
825   flags &= ~LOOKUP_NO_CONVERSION;
826   /* But no narrowing conversions.  */
827   flags |= LOOKUP_NO_NARROWING;
828
829   /* Can't make an array of these types.  */
830   if (TYPE_REF_P (elttype)
831       || TREE_CODE (elttype) == FUNCTION_TYPE
832       || VOID_TYPE_P (elttype))
833     return NULL;
834
835   FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (ctor), i, val)
836     {
837       conversion *sub
838         = implicit_conversion (elttype, TREE_TYPE (val), val,
839                                false, flags, complain);
840       if (sub == NULL)
841         return NULL;
842
843       subconvs[i] = sub;
844     }
845
846   t = alloc_conversion (ck_list);
847   t->type = type;
848   t->u.list = subconvs;
849   t->rank = cr_exact;
850
851   for (i = 0; i < len; ++i)
852     {
853       conversion *sub = subconvs[i];
854       if (sub->rank > t->rank)
855         t->rank = sub->rank;
856       if (sub->user_conv_p)
857         t->user_conv_p = true;
858       if (sub->bad_p)
859         t->bad_p = true;
860     }
861
862   return t;
863 }
864
865 /* Return the next conversion of the conversion chain (if applicable),
866    or NULL otherwise.  Please use this function instead of directly
867    accessing fields of struct conversion.  */
868
869 static conversion *
870 next_conversion (conversion *conv)
871 {
872   if (conv == NULL
873       || conv->kind == ck_identity
874       || conv->kind == ck_ambig
875       || conv->kind == ck_list)
876     return NULL;
877   return conv->u.next;
878 }
879
880 /* Subroutine of build_aggr_conv: check whether CTOR, a braced-init-list,
881    is a valid aggregate initializer for array type ATYPE.  */
882
883 static bool
884 can_convert_array (tree atype, tree ctor, int flags, tsubst_flags_t complain)
885 {
886   unsigned i;
887   tree elttype = TREE_TYPE (atype);
888   for (i = 0; i < CONSTRUCTOR_NELTS (ctor); ++i)
889     {
890       tree val = CONSTRUCTOR_ELT (ctor, i)->value;
891       bool ok;
892       if (TREE_CODE (elttype) == ARRAY_TYPE
893           && TREE_CODE (val) == CONSTRUCTOR)
894         ok = can_convert_array (elttype, val, flags, complain);
895       else
896         ok = can_convert_arg (elttype, TREE_TYPE (val), val, flags,
897                               complain);
898       if (!ok)
899         return false;
900     }
901   return true;
902 }
903
904 /* Helper for build_aggr_conv.  Return true if FIELD is in PSET, or if
905    FIELD has ANON_AGGR_TYPE_P and any initializable field in there recursively
906    is in PSET.  */
907
908 static bool
909 field_in_pset (hash_set<tree, true> &pset, tree field)
910 {
911   if (pset.contains (field))
912     return true;
913   if (ANON_AGGR_TYPE_P (TREE_TYPE (field)))
914     for (field = TYPE_FIELDS (TREE_TYPE (field));
915          field; field = DECL_CHAIN (field))
916       {
917         field = next_initializable_field (field);
918         if (field == NULL_TREE)
919           break;
920         if (field_in_pset (pset, field))
921           return true;
922       }
923   return false;
924 }
925
926 /* Represent a conversion from CTOR, a braced-init-list, to TYPE, an
927    aggregate class, if such a conversion is possible.  */
928
929 static conversion *
930 build_aggr_conv (tree type, tree ctor, int flags, tsubst_flags_t complain)
931 {
932   unsigned HOST_WIDE_INT i = 0;
933   conversion *c;
934   tree field = next_initializable_field (TYPE_FIELDS (type));
935   tree empty_ctor = NULL_TREE;
936   hash_set<tree, true> pset;
937
938   /* We already called reshape_init in implicit_conversion.  */
939
940   /* The conversions within the init-list aren't affected by the enclosing
941      context; they're always simple copy-initialization.  */
942   flags = LOOKUP_IMPLICIT|LOOKUP_NO_NARROWING;
943
944   /* For designated initializers, verify that each initializer is convertible
945      to corresponding TREE_TYPE (ce->index) and mark those FIELD_DECLs as
946      visited.  In the following loop then ignore already visited
947      FIELD_DECLs.  */
948   if (CONSTRUCTOR_IS_DESIGNATED_INIT (ctor))
949     {
950       tree idx, val;
951       FOR_EACH_CONSTRUCTOR_ELT (CONSTRUCTOR_ELTS (ctor), i, idx, val)
952         {
953           if (idx && TREE_CODE (idx) == FIELD_DECL)
954             {
955               tree ftype = TREE_TYPE (idx);
956               bool ok;
957
958               if (TREE_CODE (ftype) == ARRAY_TYPE
959                   && TREE_CODE (val) == CONSTRUCTOR)
960                 ok = can_convert_array (ftype, val, flags, complain);
961               else
962                 ok = can_convert_arg (ftype, TREE_TYPE (val), val, flags,
963                                       complain);
964
965               if (!ok)
966                 return NULL;
967               /* For unions, there should be just one initializer.  */
968               if (TREE_CODE (type) == UNION_TYPE)
969                 {
970                   field = NULL_TREE;
971                   i = 1;
972                   break;
973                 }
974               pset.add (idx);
975             }
976           else
977             return NULL;
978         }
979     }
980
981   for (; field; field = next_initializable_field (DECL_CHAIN (field)))
982     {
983       tree ftype = TREE_TYPE (field);
984       tree val;
985       bool ok;
986
987       if (!pset.is_empty () && field_in_pset (pset, field))
988         continue;
989       if (i < CONSTRUCTOR_NELTS (ctor))
990         {
991           val = CONSTRUCTOR_ELT (ctor, i)->value;
992           ++i;
993         }
994       else if (DECL_INITIAL (field))
995         val = get_nsdmi (field, /*ctor*/false, complain);
996       else if (TYPE_REF_P (ftype))
997         /* Value-initialization of reference is ill-formed.  */
998         return NULL;
999       else
1000         {
1001           if (empty_ctor == NULL_TREE)
1002             empty_ctor = build_constructor (init_list_type_node, NULL);
1003           val = empty_ctor;
1004         }
1005
1006       if (TREE_CODE (ftype) == ARRAY_TYPE
1007           && TREE_CODE (val) == CONSTRUCTOR)
1008         ok = can_convert_array (ftype, val, flags, complain);
1009       else
1010         ok = can_convert_arg (ftype, TREE_TYPE (val), val, flags,
1011                               complain);
1012
1013       if (!ok)
1014         return NULL;
1015
1016       if (TREE_CODE (type) == UNION_TYPE)
1017         break;
1018     }
1019
1020   if (i < CONSTRUCTOR_NELTS (ctor))
1021     return NULL;
1022
1023   c = alloc_conversion (ck_aggr);
1024   c->type = type;
1025   c->rank = cr_exact;
1026   c->user_conv_p = true;
1027   c->check_narrowing = true;
1028   c->u.next = NULL;
1029   return c;
1030 }
1031
1032 /* Represent a conversion from CTOR, a braced-init-list, to TYPE, an
1033    array type, if such a conversion is possible.  */
1034
1035 static conversion *
1036 build_array_conv (tree type, tree ctor, int flags, tsubst_flags_t complain)
1037 {
1038   conversion *c;
1039   unsigned HOST_WIDE_INT len = CONSTRUCTOR_NELTS (ctor);
1040   tree elttype = TREE_TYPE (type);
1041   unsigned i;
1042   tree val;
1043   bool bad = false;
1044   bool user = false;
1045   enum conversion_rank rank = cr_exact;
1046
1047   /* We might need to propagate the size from the element to the array.  */
1048   complete_type (type);
1049
1050   if (TYPE_DOMAIN (type)
1051       && !variably_modified_type_p (TYPE_DOMAIN (type), NULL_TREE))
1052     {
1053       unsigned HOST_WIDE_INT alen = tree_to_uhwi (array_type_nelts_top (type));
1054       if (alen < len)
1055         return NULL;
1056     }
1057
1058   flags = LOOKUP_IMPLICIT|LOOKUP_NO_NARROWING;
1059
1060   FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (ctor), i, val)
1061     {
1062       conversion *sub
1063         = implicit_conversion (elttype, TREE_TYPE (val), val,
1064                                false, flags, complain);
1065       if (sub == NULL)
1066         return NULL;
1067
1068       if (sub->rank > rank)
1069         rank = sub->rank;
1070       if (sub->user_conv_p)
1071         user = true;
1072       if (sub->bad_p)
1073         bad = true;
1074     }
1075
1076   c = alloc_conversion (ck_aggr);
1077   c->type = type;
1078   c->rank = rank;
1079   c->user_conv_p = user;
1080   c->bad_p = bad;
1081   c->u.next = NULL;
1082   return c;
1083 }
1084
1085 /* Represent a conversion from CTOR, a braced-init-list, to TYPE, a
1086    complex type, if such a conversion is possible.  */
1087
1088 static conversion *
1089 build_complex_conv (tree type, tree ctor, int flags,
1090                     tsubst_flags_t complain)
1091 {
1092   conversion *c;
1093   unsigned HOST_WIDE_INT len = CONSTRUCTOR_NELTS (ctor);
1094   tree elttype = TREE_TYPE (type);
1095   unsigned i;
1096   tree val;
1097   bool bad = false;
1098   bool user = false;
1099   enum conversion_rank rank = cr_exact;
1100
1101   if (len != 2)
1102     return NULL;
1103
1104   flags = LOOKUP_IMPLICIT|LOOKUP_NO_NARROWING;
1105
1106   FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (ctor), i, val)
1107     {
1108       conversion *sub
1109         = implicit_conversion (elttype, TREE_TYPE (val), val,
1110                                false, flags, complain);
1111       if (sub == NULL)
1112         return NULL;
1113
1114       if (sub->rank > rank)
1115         rank = sub->rank;
1116       if (sub->user_conv_p)
1117         user = true;
1118       if (sub->bad_p)
1119         bad = true;
1120     }
1121
1122   c = alloc_conversion (ck_aggr);
1123   c->type = type;
1124   c->rank = rank;
1125   c->user_conv_p = user;
1126   c->bad_p = bad;
1127   c->u.next = NULL;
1128   return c;
1129 }
1130
1131 /* Build a representation of the identity conversion from EXPR to
1132    itself.  The TYPE should match the type of EXPR, if EXPR is non-NULL.  */
1133
1134 static conversion *
1135 build_identity_conv (tree type, tree expr)
1136 {
1137   conversion *c;
1138
1139   c = alloc_conversion (ck_identity);
1140   c->type = type;
1141   c->u.expr = expr;
1142
1143   return c;
1144 }
1145
1146 /* Converting from EXPR to TYPE was ambiguous in the sense that there
1147    were multiple user-defined conversions to accomplish the job.
1148    Build a conversion that indicates that ambiguity.  */
1149
1150 static conversion *
1151 build_ambiguous_conv (tree type, tree expr)
1152 {
1153   conversion *c;
1154
1155   c = alloc_conversion (ck_ambig);
1156   c->type = type;
1157   c->u.expr = expr;
1158
1159   return c;
1160 }
1161
1162 tree
1163 strip_top_quals (tree t)
1164 {
1165   if (TREE_CODE (t) == ARRAY_TYPE)
1166     return t;
1167   return cp_build_qualified_type (t, 0);
1168 }
1169
1170 /* Returns the standard conversion path (see [conv]) from type FROM to type
1171    TO, if any.  For proper handling of null pointer constants, you must
1172    also pass the expression EXPR to convert from.  If C_CAST_P is true,
1173    this conversion is coming from a C-style cast.  */
1174
1175 static conversion *
1176 standard_conversion (tree to, tree from, tree expr, bool c_cast_p,
1177                      int flags, tsubst_flags_t complain)
1178 {
1179   enum tree_code fcode, tcode;
1180   conversion *conv;
1181   bool fromref = false;
1182   tree qualified_to;
1183
1184   to = non_reference (to);
1185   if (TYPE_REF_P (from))
1186     {
1187       fromref = true;
1188       from = TREE_TYPE (from);
1189     }
1190   qualified_to = to;
1191   to = strip_top_quals (to);
1192   from = strip_top_quals (from);
1193
1194   if (expr && type_unknown_p (expr))
1195     {
1196       if (TYPE_PTRFN_P (to) || TYPE_PTRMEMFUNC_P (to))
1197         {
1198           tsubst_flags_t tflags = tf_conv;
1199           expr = instantiate_type (to, expr, tflags);
1200           if (expr == error_mark_node)
1201             return NULL;
1202           from = TREE_TYPE (expr);
1203         }
1204       else if (TREE_CODE (to) == BOOLEAN_TYPE)
1205         {
1206           /* Necessary for eg, TEMPLATE_ID_EXPRs (c++/50961).  */
1207           expr = resolve_nondeduced_context (expr, complain);
1208           from = TREE_TYPE (expr);
1209         }
1210     }
1211
1212   fcode = TREE_CODE (from);
1213   tcode = TREE_CODE (to);
1214
1215   conv = build_identity_conv (from, expr);
1216   if (fcode == FUNCTION_TYPE || fcode == ARRAY_TYPE)
1217     {
1218       from = type_decays_to (from);
1219       fcode = TREE_CODE (from);
1220       /* Tell convert_like_real that we're using the address.  */
1221       conv->rvaluedness_matches_p = true;
1222       conv = build_conv (ck_lvalue, from, conv);
1223     }
1224   /* Wrapping a ck_rvalue around a class prvalue (as a result of using
1225      obvalue_p) seems odd, since it's already a prvalue, but that's how we
1226      express the copy constructor call required by copy-initialization.  */
1227   else if (fromref || (expr && obvalue_p (expr)))
1228     {
1229       if (expr)
1230         {
1231           tree bitfield_type;
1232           bitfield_type = is_bitfield_expr_with_lowered_type (expr);
1233           if (bitfield_type)
1234             {
1235               from = strip_top_quals (bitfield_type);
1236               fcode = TREE_CODE (from);
1237             }
1238         }
1239       conv = build_conv (ck_rvalue, from, conv);
1240       if (flags & LOOKUP_PREFER_RVALUE)
1241         /* Tell convert_like_real to set LOOKUP_PREFER_RVALUE.  */
1242         conv->rvaluedness_matches_p = true;
1243     }
1244
1245    /* Allow conversion between `__complex__' data types.  */
1246   if (tcode == COMPLEX_TYPE && fcode == COMPLEX_TYPE)
1247     {
1248       /* The standard conversion sequence to convert FROM to TO is
1249          the standard conversion sequence to perform componentwise
1250          conversion.  */
1251       conversion *part_conv = standard_conversion
1252         (TREE_TYPE (to), TREE_TYPE (from), NULL_TREE, c_cast_p, flags,
1253          complain);
1254
1255       if (part_conv)
1256         {
1257           conv = build_conv (part_conv->kind, to, conv);
1258           conv->rank = part_conv->rank;
1259         }
1260       else
1261         conv = NULL;
1262
1263       return conv;
1264     }
1265
1266   if (same_type_p (from, to))
1267     {
1268       if (CLASS_TYPE_P (to) && conv->kind == ck_rvalue)
1269         conv->type = qualified_to;
1270       return conv;
1271     }
1272
1273   /* [conv.ptr]
1274      A null pointer constant can be converted to a pointer type; ... A
1275      null pointer constant of integral type can be converted to an
1276      rvalue of type std::nullptr_t. */
1277   if ((tcode == POINTER_TYPE || TYPE_PTRMEM_P (to)
1278        || NULLPTR_TYPE_P (to))
1279       && ((expr && null_ptr_cst_p (expr))
1280           || NULLPTR_TYPE_P (from)))
1281     conv = build_conv (ck_std, to, conv);
1282   else if ((tcode == INTEGER_TYPE && fcode == POINTER_TYPE)
1283            || (tcode == POINTER_TYPE && fcode == INTEGER_TYPE))
1284     {
1285       /* For backwards brain damage compatibility, allow interconversion of
1286          pointers and integers with a pedwarn.  */
1287       conv = build_conv (ck_std, to, conv);
1288       conv->bad_p = true;
1289     }
1290   else if (UNSCOPED_ENUM_P (to) && fcode == INTEGER_TYPE)
1291     {
1292       /* For backwards brain damage compatibility, allow interconversion of
1293          enums and integers with a pedwarn.  */
1294       conv = build_conv (ck_std, to, conv);
1295       conv->bad_p = true;
1296     }
1297   else if ((tcode == POINTER_TYPE && fcode == POINTER_TYPE)
1298            || (TYPE_PTRDATAMEM_P (to) && TYPE_PTRDATAMEM_P (from)))
1299     {
1300       tree to_pointee;
1301       tree from_pointee;
1302
1303       if (tcode == POINTER_TYPE)
1304         {
1305           to_pointee = TREE_TYPE (to);
1306           from_pointee = TREE_TYPE (from);
1307
1308           /* Since this is the target of a pointer, it can't have function
1309              qualifiers, so any TYPE_QUALS must be for attributes const or
1310              noreturn.  Strip them.  */
1311           if (TREE_CODE (to_pointee) == FUNCTION_TYPE
1312               && TYPE_QUALS (to_pointee))
1313             to_pointee = build_qualified_type (to_pointee, TYPE_UNQUALIFIED);
1314           if (TREE_CODE (from_pointee) == FUNCTION_TYPE
1315               && TYPE_QUALS (from_pointee))
1316             from_pointee = build_qualified_type (from_pointee, TYPE_UNQUALIFIED);
1317         }
1318       else
1319         {
1320           to_pointee = TYPE_PTRMEM_POINTED_TO_TYPE (to);
1321           from_pointee = TYPE_PTRMEM_POINTED_TO_TYPE (from);
1322         }
1323
1324       if (tcode == POINTER_TYPE
1325           && same_type_ignoring_top_level_qualifiers_p (from_pointee,
1326                                                         to_pointee))
1327         ;
1328       else if (VOID_TYPE_P (to_pointee)
1329                && !TYPE_PTRDATAMEM_P (from)
1330                && TREE_CODE (from_pointee) != FUNCTION_TYPE)
1331         {
1332           tree nfrom = TREE_TYPE (from);
1333           /* Don't try to apply restrict to void.  */
1334           int quals = cp_type_quals (nfrom) & ~TYPE_QUAL_RESTRICT;
1335           from_pointee = cp_build_qualified_type (void_type_node, quals);
1336           from = build_pointer_type (from_pointee);
1337           conv = build_conv (ck_ptr, from, conv);
1338         }
1339       else if (TYPE_PTRDATAMEM_P (from))
1340         {
1341           tree fbase = TYPE_PTRMEM_CLASS_TYPE (from);
1342           tree tbase = TYPE_PTRMEM_CLASS_TYPE (to);
1343
1344           if (same_type_p (fbase, tbase))
1345             /* No base conversion needed.  */;
1346           else if (DERIVED_FROM_P (fbase, tbase)
1347                    && (same_type_ignoring_top_level_qualifiers_p
1348                        (from_pointee, to_pointee)))
1349             {
1350               from = build_ptrmem_type (tbase, from_pointee);
1351               conv = build_conv (ck_pmem, from, conv);
1352             }
1353           else
1354             return NULL;
1355         }
1356       else if (CLASS_TYPE_P (from_pointee)
1357                && CLASS_TYPE_P (to_pointee)
1358                /* [conv.ptr]
1359
1360                   An rvalue of type "pointer to cv D," where D is a
1361                   class type, can be converted to an rvalue of type
1362                   "pointer to cv B," where B is a base class (clause
1363                   _class.derived_) of D.  If B is an inaccessible
1364                   (clause _class.access_) or ambiguous
1365                   (_class.member.lookup_) base class of D, a program
1366                   that necessitates this conversion is ill-formed.
1367                   Therefore, we use DERIVED_FROM_P, and do not check
1368                   access or uniqueness.  */
1369                && DERIVED_FROM_P (to_pointee, from_pointee))
1370         {
1371           from_pointee
1372             = cp_build_qualified_type (to_pointee,
1373                                        cp_type_quals (from_pointee));
1374           from = build_pointer_type (from_pointee);
1375           conv = build_conv (ck_ptr, from, conv);
1376           conv->base_p = true;
1377         }
1378
1379       if (same_type_p (from, to))
1380         /* OK */;
1381       else if (c_cast_p && comp_ptr_ttypes_const (to, from))
1382         /* In a C-style cast, we ignore CV-qualification because we
1383            are allowed to perform a static_cast followed by a
1384            const_cast.  */
1385         conv = build_conv (ck_qual, to, conv);
1386       else if (!c_cast_p && comp_ptr_ttypes (to_pointee, from_pointee))
1387         conv = build_conv (ck_qual, to, conv);
1388       else if (expr && string_conv_p (to, expr, 0))
1389         /* converting from string constant to char *.  */
1390         conv = build_conv (ck_qual, to, conv);
1391       else if (fnptr_conv_p (to, from))
1392         conv = build_conv (ck_fnptr, to, conv);
1393       /* Allow conversions among compatible ObjC pointer types (base
1394          conversions have been already handled above).  */
1395       else if (c_dialect_objc ()
1396                && objc_compare_types (to, from, -4, NULL_TREE))
1397         conv = build_conv (ck_ptr, to, conv);
1398       else if (ptr_reasonably_similar (to_pointee, from_pointee))
1399         {
1400           conv = build_conv (ck_ptr, to, conv);
1401           conv->bad_p = true;
1402         }
1403       else
1404         return NULL;
1405
1406       from = to;
1407     }
1408   else if (TYPE_PTRMEMFUNC_P (to) && TYPE_PTRMEMFUNC_P (from))
1409     {
1410       tree fromfn = TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (from));
1411       tree tofn = TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (to));
1412       tree fbase = class_of_this_parm (fromfn);
1413       tree tbase = class_of_this_parm (tofn);
1414
1415       if (!DERIVED_FROM_P (fbase, tbase))
1416         return NULL;
1417
1418       tree fstat = static_fn_type (fromfn);
1419       tree tstat = static_fn_type (tofn);
1420       if (same_type_p (tstat, fstat)
1421           || fnptr_conv_p (tstat, fstat))
1422         /* OK */;
1423       else
1424         return NULL;
1425
1426       if (!same_type_p (fbase, tbase))
1427         {
1428           from = build_memfn_type (fstat,
1429                                    tbase,
1430                                    cp_type_quals (tbase),
1431                                    type_memfn_rqual (tofn));
1432           from = build_ptrmemfunc_type (build_pointer_type (from));
1433           conv = build_conv (ck_pmem, from, conv);
1434           conv->base_p = true;
1435         }
1436       if (fnptr_conv_p (tstat, fstat))
1437         conv = build_conv (ck_fnptr, to, conv);
1438     }
1439   else if (tcode == BOOLEAN_TYPE)
1440     {
1441       /* [conv.bool]
1442
1443           A prvalue of arithmetic, unscoped enumeration, pointer, or pointer
1444           to member type can be converted to a prvalue of type bool. ...
1445           For direct-initialization (8.5 [dcl.init]), a prvalue of type
1446           std::nullptr_t can be converted to a prvalue of type bool;  */
1447       if (ARITHMETIC_TYPE_P (from)
1448           || UNSCOPED_ENUM_P (from)
1449           || fcode == POINTER_TYPE
1450           || TYPE_PTRMEM_P (from)
1451           || NULLPTR_TYPE_P (from))
1452         {
1453           conv = build_conv (ck_std, to, conv);
1454           if (fcode == POINTER_TYPE
1455               || TYPE_PTRDATAMEM_P (from)
1456               || (TYPE_PTRMEMFUNC_P (from)
1457                   && conv->rank < cr_pbool)
1458               || NULLPTR_TYPE_P (from))
1459             conv->rank = cr_pbool;
1460           if (NULLPTR_TYPE_P (from) && (flags & LOOKUP_ONLYCONVERTING))
1461             conv->bad_p = true;
1462           if (flags & LOOKUP_NO_NARROWING)
1463             conv->check_narrowing = true;
1464           return conv;
1465         }
1466
1467       return NULL;
1468     }
1469   /* We don't check for ENUMERAL_TYPE here because there are no standard
1470      conversions to enum type.  */
1471   /* As an extension, allow conversion to complex type.  */
1472   else if (ARITHMETIC_TYPE_P (to))
1473     {
1474       if (! (INTEGRAL_CODE_P (fcode)
1475              || (fcode == REAL_TYPE && !(flags & LOOKUP_NO_NON_INTEGRAL)))
1476           || SCOPED_ENUM_P (from))
1477         return NULL;
1478
1479       /* If we're parsing an enum with no fixed underlying type, we're
1480          dealing with an incomplete type, which renders the conversion
1481          ill-formed.  */
1482       if (!COMPLETE_TYPE_P (from))
1483         return NULL;
1484
1485       conv = build_conv (ck_std, to, conv);
1486
1487       /* Give this a better rank if it's a promotion.  */
1488       if (same_type_p (to, type_promotes_to (from))
1489           && next_conversion (conv)->rank <= cr_promotion)
1490         conv->rank = cr_promotion;
1491     }
1492   else if (fcode == VECTOR_TYPE && tcode == VECTOR_TYPE
1493            && vector_types_convertible_p (from, to, false))
1494     return build_conv (ck_std, to, conv);
1495   else if (MAYBE_CLASS_TYPE_P (to) && MAYBE_CLASS_TYPE_P (from)
1496            && is_properly_derived_from (from, to))
1497     {
1498       if (conv->kind == ck_rvalue)
1499         conv = next_conversion (conv);
1500       conv = build_conv (ck_base, to, conv);
1501       /* The derived-to-base conversion indicates the initialization
1502          of a parameter with base type from an object of a derived
1503          type.  A temporary object is created to hold the result of
1504          the conversion unless we're binding directly to a reference.  */
1505       conv->need_temporary_p = !(flags & LOOKUP_NO_TEMP_BIND);
1506       if (flags & LOOKUP_PREFER_RVALUE)
1507         /* Tell convert_like_real to set LOOKUP_PREFER_RVALUE.  */
1508         conv->rvaluedness_matches_p = true;
1509     }
1510   else
1511     return NULL;
1512
1513   if (flags & LOOKUP_NO_NARROWING)
1514     conv->check_narrowing = true;
1515
1516   return conv;
1517 }
1518
1519 /* Returns nonzero if T1 is reference-related to T2.  */
1520
1521 bool
1522 reference_related_p (tree t1, tree t2)
1523 {
1524   if (t1 == error_mark_node || t2 == error_mark_node)
1525     return false;
1526
1527   t1 = TYPE_MAIN_VARIANT (t1);
1528   t2 = TYPE_MAIN_VARIANT (t2);
1529
1530   /* [dcl.init.ref]
1531
1532      Given types "cv1 T1" and "cv2 T2," "cv1 T1" is reference-related
1533      to "cv2 T2" if T1 is the same type as T2, or T1 is a base class
1534      of T2.  */
1535   return (same_type_p (t1, t2)
1536           || (CLASS_TYPE_P (t1) && CLASS_TYPE_P (t2)
1537               && DERIVED_FROM_P (t1, t2)));
1538 }
1539
1540 /* Returns nonzero if T1 is reference-compatible with T2.  */
1541
1542 static bool
1543 reference_compatible_p (tree t1, tree t2)
1544 {
1545   /* [dcl.init.ref]
1546
1547      "cv1 T1" is reference compatible with "cv2 T2" if
1548        * T1 is reference-related to T2 or
1549        * T2 is "noexcept function" and T1 is "function", where the
1550          function types are otherwise the same,
1551      and cv1 is the same cv-qualification as, or greater cv-qualification
1552      than, cv2.  */
1553   return ((reference_related_p (t1, t2)
1554            || fnptr_conv_p (t1, t2))
1555           && at_least_as_qualified_p (t1, t2));
1556 }
1557
1558 /* A reference of the indicated TYPE is being bound directly to the
1559    expression represented by the implicit conversion sequence CONV.
1560    Return a conversion sequence for this binding.  */
1561
1562 static conversion *
1563 direct_reference_binding (tree type, conversion *conv)
1564 {
1565   tree t;
1566
1567   gcc_assert (TYPE_REF_P (type));
1568   gcc_assert (!TYPE_REF_P (conv->type));
1569
1570   t = TREE_TYPE (type);
1571
1572   if (conv->kind == ck_identity)
1573     /* Mark the identity conv as to not decay to rvalue.  */
1574     conv->rvaluedness_matches_p = true;
1575
1576   /* [over.ics.rank]
1577
1578      When a parameter of reference type binds directly
1579      (_dcl.init.ref_) to an argument expression, the implicit
1580      conversion sequence is the identity conversion, unless the
1581      argument expression has a type that is a derived class of the
1582      parameter type, in which case the implicit conversion sequence is
1583      a derived-to-base Conversion.
1584
1585      If the parameter binds directly to the result of applying a
1586      conversion function to the argument expression, the implicit
1587      conversion sequence is a user-defined conversion sequence
1588      (_over.ics.user_), with the second standard conversion sequence
1589      either an identity conversion or, if the conversion function
1590      returns an entity of a type that is a derived class of the
1591      parameter type, a derived-to-base conversion.  */
1592   if (is_properly_derived_from (conv->type, t))
1593     {
1594       /* Represent the derived-to-base conversion.  */
1595       conv = build_conv (ck_base, t, conv);
1596       /* We will actually be binding to the base-class subobject in
1597          the derived class, so we mark this conversion appropriately.
1598          That way, convert_like knows not to generate a temporary.  */
1599       conv->need_temporary_p = false;
1600     }
1601
1602   return build_conv (ck_ref_bind, type, conv);
1603 }
1604
1605 /* Returns the conversion path from type FROM to reference type TO for
1606    purposes of reference binding.  For lvalue binding, either pass a
1607    reference type to FROM or an lvalue expression to EXPR.  If the
1608    reference will be bound to a temporary, NEED_TEMPORARY_P is set for
1609    the conversion returned.  If C_CAST_P is true, this
1610    conversion is coming from a C-style cast.  */
1611
1612 static conversion *
1613 reference_binding (tree rto, tree rfrom, tree expr, bool c_cast_p, int flags,
1614                    tsubst_flags_t complain)
1615 {
1616   conversion *conv = NULL;
1617   tree to = TREE_TYPE (rto);
1618   tree from = rfrom;
1619   tree tfrom;
1620   bool related_p;
1621   bool compatible_p;
1622   cp_lvalue_kind gl_kind;
1623   bool is_lvalue;
1624
1625   if (TREE_CODE (to) == FUNCTION_TYPE && expr && type_unknown_p (expr))
1626     {
1627       expr = instantiate_type (to, expr, tf_none);
1628       if (expr == error_mark_node)
1629         return NULL;
1630       from = TREE_TYPE (expr);
1631     }
1632
1633   bool copy_list_init = false;
1634   if (expr && BRACE_ENCLOSED_INITIALIZER_P (expr))
1635     {
1636       maybe_warn_cpp0x (CPP0X_INITIALIZER_LISTS);
1637       /* DR 1288: Otherwise, if the initializer list has a single element
1638          of type E and ... [T's] referenced type is reference-related to E,
1639          the object or reference is initialized from that element... */
1640       if (CONSTRUCTOR_NELTS (expr) == 1)
1641         {
1642           tree elt = CONSTRUCTOR_ELT (expr, 0)->value;
1643           if (error_operand_p (elt))
1644             return NULL;
1645           tree etype = TREE_TYPE (elt);
1646           if (reference_related_p (to, etype))
1647             {
1648               expr = elt;
1649               from = etype;
1650               goto skip;
1651             }
1652         }
1653       /* Otherwise, if T is a reference type, a prvalue temporary of the type
1654          referenced by T is copy-list-initialized, and the reference is bound
1655          to that temporary. */
1656       copy_list_init = true;
1657     skip:;
1658     }
1659
1660   if (TYPE_REF_P (from))
1661     {
1662       from = TREE_TYPE (from);
1663       if (!TYPE_REF_IS_RVALUE (rfrom)
1664           || TREE_CODE (from) == FUNCTION_TYPE)
1665         gl_kind = clk_ordinary;
1666       else
1667         gl_kind = clk_rvalueref;
1668     }
1669   else if (expr)
1670     gl_kind = lvalue_kind (expr);
1671   else if (CLASS_TYPE_P (from)
1672            || TREE_CODE (from) == ARRAY_TYPE)
1673     gl_kind = clk_class;
1674   else
1675     gl_kind = clk_none;
1676
1677   /* Don't allow a class prvalue when LOOKUP_NO_TEMP_BIND.  */
1678   if ((flags & LOOKUP_NO_TEMP_BIND)
1679       && (gl_kind & clk_class))
1680     gl_kind = clk_none;
1681
1682   /* Same mask as real_lvalue_p.  */
1683   is_lvalue = gl_kind && !(gl_kind & (clk_rvalueref|clk_class));
1684
1685   tfrom = from;
1686   if ((gl_kind & clk_bitfield) != 0)
1687     tfrom = unlowered_expr_type (expr);
1688
1689   /* Figure out whether or not the types are reference-related and
1690      reference compatible.  We have to do this after stripping
1691      references from FROM.  */
1692   related_p = reference_related_p (to, tfrom);
1693   /* If this is a C cast, first convert to an appropriately qualified
1694      type, so that we can later do a const_cast to the desired type.  */
1695   if (related_p && c_cast_p
1696       && !at_least_as_qualified_p (to, tfrom))
1697     to = cp_build_qualified_type (to, cp_type_quals (tfrom));
1698   compatible_p = reference_compatible_p (to, tfrom);
1699
1700   /* Directly bind reference when target expression's type is compatible with
1701      the reference and expression is an lvalue. In DR391, the wording in
1702      [8.5.3/5 dcl.init.ref] is changed to also require direct bindings for
1703      const and rvalue references to rvalues of compatible class type.
1704      We should also do direct bindings for non-class xvalues.  */
1705   if ((related_p || compatible_p) && gl_kind)
1706     {
1707       /* [dcl.init.ref]
1708
1709          If the initializer expression
1710
1711          -- is an lvalue (but not an lvalue for a bit-field), and "cv1 T1"
1712             is reference-compatible with "cv2 T2,"
1713
1714          the reference is bound directly to the initializer expression
1715          lvalue.
1716
1717          [...]
1718          If the initializer expression is an rvalue, with T2 a class type,
1719          and "cv1 T1" is reference-compatible with "cv2 T2", the reference
1720          is bound to the object represented by the rvalue or to a sub-object
1721          within that object.  */
1722
1723       conv = build_identity_conv (tfrom, expr);
1724       conv = direct_reference_binding (rto, conv);
1725
1726       if (TYPE_REF_P (rfrom))
1727         /* Handle rvalue reference to function properly.  */
1728         conv->rvaluedness_matches_p
1729           = (TYPE_REF_IS_RVALUE (rto) == TYPE_REF_IS_RVALUE (rfrom));
1730       else
1731         conv->rvaluedness_matches_p 
1732           = (TYPE_REF_IS_RVALUE (rto) == !is_lvalue);
1733
1734       if ((gl_kind & clk_bitfield) != 0
1735           || ((gl_kind & clk_packed) != 0 && !TYPE_PACKED (to)))
1736         /* For the purposes of overload resolution, we ignore the fact
1737            this expression is a bitfield or packed field. (In particular,
1738            [over.ics.ref] says specifically that a function with a
1739            non-const reference parameter is viable even if the
1740            argument is a bitfield.)
1741
1742            However, when we actually call the function we must create
1743            a temporary to which to bind the reference.  If the
1744            reference is volatile, or isn't const, then we cannot make
1745            a temporary, so we just issue an error when the conversion
1746            actually occurs.  */
1747         conv->need_temporary_p = true;
1748
1749       /* Don't allow binding of lvalues (other than function lvalues) to
1750          rvalue references.  */
1751       if (is_lvalue && TYPE_REF_IS_RVALUE (rto)
1752           && TREE_CODE (to) != FUNCTION_TYPE)
1753         conv->bad_p = true;
1754
1755       /* Nor the reverse.  */
1756       if (!is_lvalue && !TYPE_REF_IS_RVALUE (rto)
1757           && (!CP_TYPE_CONST_NON_VOLATILE_P (to)
1758               || (flags & LOOKUP_NO_RVAL_BIND))
1759           && TREE_CODE (to) != FUNCTION_TYPE)
1760         conv->bad_p = true;
1761
1762       if (!compatible_p)
1763         conv->bad_p = true;
1764
1765       return conv;
1766     }
1767   /* [class.conv.fct] A conversion function is never used to convert a
1768      (possibly cv-qualified) object to the (possibly cv-qualified) same
1769      object type (or a reference to it), to a (possibly cv-qualified) base
1770      class of that type (or a reference to it).... */
1771   else if (CLASS_TYPE_P (from) && !related_p
1772            && !(flags & LOOKUP_NO_CONVERSION))
1773     {
1774       /* [dcl.init.ref]
1775
1776          If the initializer expression
1777
1778          -- has a class type (i.e., T2 is a class type) can be
1779             implicitly converted to an lvalue of type "cv3 T3," where
1780             "cv1 T1" is reference-compatible with "cv3 T3".  (this
1781             conversion is selected by enumerating the applicable
1782             conversion functions (_over.match.ref_) and choosing the
1783             best one through overload resolution.  (_over.match_).
1784
1785         the reference is bound to the lvalue result of the conversion
1786         in the second case.  */
1787       z_candidate *cand = build_user_type_conversion_1 (rto, expr, flags,
1788                                                         complain);
1789       if (cand)
1790         return cand->second_conv;
1791     }
1792
1793   /* From this point on, we conceptually need temporaries, even if we
1794      elide them.  Only the cases above are "direct bindings".  */
1795   if (flags & LOOKUP_NO_TEMP_BIND)
1796     return NULL;
1797
1798   /* [over.ics.rank]
1799
1800      When a parameter of reference type is not bound directly to an
1801      argument expression, the conversion sequence is the one required
1802      to convert the argument expression to the underlying type of the
1803      reference according to _over.best.ics_.  Conceptually, this
1804      conversion sequence corresponds to copy-initializing a temporary
1805      of the underlying type with the argument expression.  Any
1806      difference in top-level cv-qualification is subsumed by the
1807      initialization itself and does not constitute a conversion.  */
1808
1809   /* [dcl.init.ref]
1810
1811      Otherwise, the reference shall be an lvalue reference to a
1812      non-volatile const type, or the reference shall be an rvalue
1813      reference.
1814
1815      We try below to treat this as a bad conversion to improve diagnostics,
1816      but if TO is an incomplete class, we need to reject this conversion
1817      now to avoid unnecessary instantiation.  */
1818   if (!CP_TYPE_CONST_NON_VOLATILE_P (to) && !TYPE_REF_IS_RVALUE (rto)
1819       && !COMPLETE_TYPE_P (to))
1820     return NULL;
1821
1822   /* We're generating a temporary now, but don't bind any more in the
1823      conversion (specifically, don't slice the temporary returned by a
1824      conversion operator).  */
1825   flags |= LOOKUP_NO_TEMP_BIND;
1826
1827   /* Core issue 899: When [copy-]initializing a temporary to be bound
1828      to the first parameter of a copy constructor (12.8) called with
1829      a single argument in the context of direct-initialization,
1830      explicit conversion functions are also considered.
1831
1832      So don't set LOOKUP_ONLYCONVERTING in that case.  */
1833   if (!(flags & LOOKUP_COPY_PARM))
1834     flags |= LOOKUP_ONLYCONVERTING;
1835
1836   if (!conv)
1837     conv = implicit_conversion (to, from, expr, c_cast_p,
1838                                 flags, complain);
1839   if (!conv)
1840     return NULL;
1841
1842   if (conv->user_conv_p)
1843     {
1844       if (copy_list_init)
1845         /* Remember this was copy-list-initialization.  */
1846         conv->need_temporary_p = true;
1847
1848       /* If initializing the temporary used a conversion function,
1849          recalculate the second conversion sequence.  */
1850       for (conversion *t = conv; t; t = next_conversion (t))
1851         if (t->kind == ck_user
1852             && DECL_CONV_FN_P (t->cand->fn))
1853           {
1854             tree ftype = TREE_TYPE (TREE_TYPE (t->cand->fn));
1855             /* A prvalue of non-class type is cv-unqualified.  */
1856             if (!TYPE_REF_P (ftype) && !CLASS_TYPE_P (ftype))
1857               ftype = cv_unqualified (ftype);
1858             int sflags = (flags|LOOKUP_NO_CONVERSION)&~LOOKUP_NO_TEMP_BIND;
1859             conversion *new_second
1860               = reference_binding (rto, ftype, NULL_TREE, c_cast_p,
1861                                    sflags, complain);
1862             if (!new_second)
1863               return NULL;
1864             return merge_conversion_sequences (t, new_second);
1865           }
1866     }
1867
1868   conv = build_conv (ck_ref_bind, rto, conv);
1869   /* This reference binding, unlike those above, requires the
1870      creation of a temporary.  */
1871   conv->need_temporary_p = true;
1872   conv->rvaluedness_matches_p = TYPE_REF_IS_RVALUE (rto);
1873
1874   /* [dcl.init.ref]
1875
1876      Otherwise, the reference shall be an lvalue reference to a
1877      non-volatile const type, or the reference shall be an rvalue
1878      reference.  */
1879   if (!CP_TYPE_CONST_NON_VOLATILE_P (to) && !TYPE_REF_IS_RVALUE (rto))
1880     conv->bad_p = true;
1881
1882   /* [dcl.init.ref]
1883
1884      Otherwise, a temporary of type "cv1 T1" is created and
1885      initialized from the initializer expression using the rules for a
1886      non-reference copy initialization.  If T1 is reference-related to
1887      T2, cv1 must be the same cv-qualification as, or greater
1888      cv-qualification than, cv2; otherwise, the program is ill-formed.  */
1889   if (related_p && !at_least_as_qualified_p (to, from))
1890     conv->bad_p = true;
1891
1892   return conv;
1893 }
1894
1895 /* Returns the implicit conversion sequence (see [over.ics]) from type
1896    FROM to type TO.  The optional expression EXPR may affect the
1897    conversion.  FLAGS are the usual overloading flags.  If C_CAST_P is
1898    true, this conversion is coming from a C-style cast.  */
1899
1900 static conversion *
1901 implicit_conversion (tree to, tree from, tree expr, bool c_cast_p,
1902                      int flags, tsubst_flags_t complain)
1903 {
1904   conversion *conv;
1905
1906   if (from == error_mark_node || to == error_mark_node
1907       || expr == error_mark_node)
1908     return NULL;
1909
1910   /* Other flags only apply to the primary function in overload
1911      resolution, or after we've chosen one.  */
1912   flags &= (LOOKUP_ONLYCONVERTING|LOOKUP_NO_CONVERSION|LOOKUP_COPY_PARM
1913             |LOOKUP_NO_TEMP_BIND|LOOKUP_NO_RVAL_BIND|LOOKUP_PREFER_RVALUE
1914             |LOOKUP_NO_NARROWING|LOOKUP_PROTECT|LOOKUP_NO_NON_INTEGRAL);
1915
1916   /* FIXME: actually we don't want warnings either, but we can't just
1917      have 'complain &= ~(tf_warning|tf_error)' because it would cause
1918      the regression of, eg, g++.old-deja/g++.benjamin/16077.C.
1919      We really ought not to issue that warning until we've committed
1920      to that conversion.  */
1921   complain &= ~tf_error;
1922
1923   /* Call reshape_init early to remove redundant braces.  */
1924   if (expr && BRACE_ENCLOSED_INITIALIZER_P (expr)
1925       && CLASS_TYPE_P (to)
1926       && COMPLETE_TYPE_P (complete_type (to))
1927       && !CLASSTYPE_NON_AGGREGATE (to))
1928     {
1929       expr = reshape_init (to, expr, complain);
1930       if (expr == error_mark_node)
1931         return NULL;
1932       from = TREE_TYPE (expr);
1933     }
1934
1935   if (TYPE_REF_P (to))
1936     conv = reference_binding (to, from, expr, c_cast_p, flags, complain);
1937   else
1938     conv = standard_conversion (to, from, expr, c_cast_p, flags, complain);
1939
1940   if (conv)
1941     return conv;
1942
1943   if (expr && BRACE_ENCLOSED_INITIALIZER_P (expr))
1944     {
1945       if (is_std_init_list (to) && !CONSTRUCTOR_IS_DESIGNATED_INIT (expr))
1946         return build_list_conv (to, expr, flags, complain);
1947
1948       /* As an extension, allow list-initialization of _Complex.  */
1949       if (TREE_CODE (to) == COMPLEX_TYPE
1950           && !CONSTRUCTOR_IS_DESIGNATED_INIT (expr))
1951         {
1952           conv = build_complex_conv (to, expr, flags, complain);
1953           if (conv)
1954             return conv;
1955         }
1956
1957       /* Allow conversion from an initializer-list with one element to a
1958          scalar type.  */
1959       if (SCALAR_TYPE_P (to))
1960         {
1961           int nelts = CONSTRUCTOR_NELTS (expr);
1962           tree elt;
1963
1964           if (nelts == 0)
1965             elt = build_value_init (to, tf_none);
1966           else if (nelts == 1 && !CONSTRUCTOR_IS_DESIGNATED_INIT (expr))
1967             elt = CONSTRUCTOR_ELT (expr, 0)->value;
1968           else
1969             elt = error_mark_node;
1970
1971           conv = implicit_conversion (to, TREE_TYPE (elt), elt,
1972                                       c_cast_p, flags, complain);
1973           if (conv)
1974             {
1975               conv->check_narrowing = true;
1976               if (BRACE_ENCLOSED_INITIALIZER_P (elt))
1977                 /* Too many levels of braces, i.e. '{{1}}'.  */
1978                 conv->bad_p = true;
1979               return conv;
1980             }
1981         }
1982       else if (TREE_CODE (to) == ARRAY_TYPE)
1983         return build_array_conv (to, expr, flags, complain);
1984     }
1985
1986   if (expr != NULL_TREE
1987       && (MAYBE_CLASS_TYPE_P (from)
1988           || MAYBE_CLASS_TYPE_P (to))
1989       && (flags & LOOKUP_NO_CONVERSION) == 0)
1990     {
1991       struct z_candidate *cand;
1992
1993       if (CLASS_TYPE_P (to)
1994           && BRACE_ENCLOSED_INITIALIZER_P (expr)
1995           && !CLASSTYPE_NON_AGGREGATE (complete_type (to)))
1996         return build_aggr_conv (to, expr, flags, complain);
1997
1998       cand = build_user_type_conversion_1 (to, expr, flags, complain);
1999       if (cand)
2000         {
2001           if (BRACE_ENCLOSED_INITIALIZER_P (expr)
2002               && CONSTRUCTOR_NELTS (expr) == 1
2003               && !is_list_ctor (cand->fn))
2004             {
2005               /* "If C is not an initializer-list constructor and the
2006                  initializer list has a single element of type cv U, where U is
2007                  X or a class derived from X, the implicit conversion sequence
2008                  has Exact Match rank if U is X, or Conversion rank if U is
2009                  derived from X."  */
2010               tree elt = CONSTRUCTOR_ELT (expr, 0)->value;
2011               tree elttype = TREE_TYPE (elt);
2012               if (reference_related_p (to, elttype))
2013                 return implicit_conversion (to, elttype, elt,
2014                                             c_cast_p, flags, complain);
2015             }
2016           conv = cand->second_conv;
2017         }
2018
2019       /* We used to try to bind a reference to a temporary here, but that
2020          is now handled after the recursive call to this function at the end
2021          of reference_binding.  */
2022       return conv;
2023     }
2024
2025   return NULL;
2026 }
2027
2028 /* Like implicit_conversion, but return NULL if the conversion is bad.
2029
2030    This is not static so that check_non_deducible_conversion can call it within
2031    add_template_candidate_real as part of overload resolution; it should not be
2032    called outside of overload resolution.  */
2033
2034 conversion *
2035 good_conversion (tree to, tree from, tree expr,
2036                  int flags, tsubst_flags_t complain)
2037 {
2038   conversion *c = implicit_conversion (to, from, expr, /*cast*/false,
2039                                        flags, complain);
2040   if (c && c->bad_p)
2041     c = NULL;
2042   return c;
2043 }
2044
2045 /* Add a new entry to the list of candidates.  Used by the add_*_candidate
2046    functions.  ARGS will not be changed until a single candidate is
2047    selected.  */
2048
2049 static struct z_candidate *
2050 add_candidate (struct z_candidate **candidates,
2051                tree fn, tree first_arg, const vec<tree, va_gc> *args,
2052                size_t num_convs, conversion **convs,
2053                tree access_path, tree conversion_path,
2054                int viable, struct rejection_reason *reason,
2055                int flags)
2056 {
2057   struct z_candidate *cand = (struct z_candidate *)
2058     conversion_obstack_alloc (sizeof (struct z_candidate));
2059
2060   cand->fn = fn;
2061   cand->first_arg = first_arg;
2062   cand->args = args;
2063   cand->convs = convs;
2064   cand->num_convs = num_convs;
2065   cand->access_path = access_path;
2066   cand->conversion_path = conversion_path;
2067   cand->viable = viable;
2068   cand->reason = reason;
2069   cand->next = *candidates;
2070   cand->flags = flags;
2071   *candidates = cand;
2072
2073   return cand;
2074 }
2075
2076 /* Return the number of remaining arguments in the parameter list
2077    beginning with ARG.  */
2078
2079 int
2080 remaining_arguments (tree arg)
2081 {
2082   int n;
2083
2084   for (n = 0; arg != NULL_TREE && arg != void_list_node;
2085        arg = TREE_CHAIN (arg))
2086     n++;
2087
2088   return n;
2089 }
2090
2091 /* [over.match.copy]: When initializing a temporary object (12.2) to be bound
2092    to the first parameter of a constructor where the parameter is of type
2093    "reference to possibly cv-qualified T" and the constructor is called with a
2094    single argument in the context of direct-initialization of an object of type
2095    "cv2 T", explicit conversion functions are also considered.
2096
2097    So set LOOKUP_COPY_PARM to let reference_binding know that
2098    it's being called in that context.  */
2099
2100 int
2101 conv_flags (int i, int nargs, tree fn, tree arg, int flags)
2102 {
2103   int lflags = flags;
2104   tree t;
2105   if (i == 0 && nargs == 1 && DECL_CONSTRUCTOR_P (fn)
2106       && (t = FUNCTION_FIRST_USER_PARMTYPE (fn))
2107       && (same_type_ignoring_top_level_qualifiers_p
2108           (non_reference (TREE_VALUE (t)), DECL_CONTEXT (fn))))
2109     {
2110       if (!(flags & LOOKUP_ONLYCONVERTING))
2111         lflags |= LOOKUP_COPY_PARM;
2112       if ((flags & LOOKUP_LIST_INIT_CTOR)
2113           && BRACE_ENCLOSED_INITIALIZER_P (arg))
2114         lflags |= LOOKUP_NO_CONVERSION;
2115     }
2116   else
2117     lflags |= LOOKUP_ONLYCONVERTING;
2118
2119   return lflags;
2120 }
2121
2122 /* Create an overload candidate for the function or method FN called
2123    with the argument list FIRST_ARG/ARGS and add it to CANDIDATES.
2124    FLAGS is passed on to implicit_conversion.
2125
2126    This does not change ARGS.
2127
2128    CTYPE, if non-NULL, is the type we want to pretend this function
2129    comes from for purposes of overload resolution.  */
2130
2131 static struct z_candidate *
2132 add_function_candidate (struct z_candidate **candidates,
2133                         tree fn, tree ctype, tree first_arg,
2134                         const vec<tree, va_gc> *args, tree access_path,
2135                         tree conversion_path, int flags,
2136                         conversion **convs,
2137                         tsubst_flags_t complain)
2138 {
2139   tree parmlist = TYPE_ARG_TYPES (TREE_TYPE (fn));
2140   int i, len;
2141   tree parmnode;
2142   tree orig_first_arg = first_arg;
2143   int skip;
2144   int viable = 1;
2145   struct rejection_reason *reason = NULL;
2146
2147   /* At this point we should not see any functions which haven't been
2148      explicitly declared, except for friend functions which will have
2149      been found using argument dependent lookup.  */
2150   gcc_assert (!DECL_ANTICIPATED (fn) || DECL_HIDDEN_FRIEND_P (fn));
2151
2152   /* The `this', `in_chrg' and VTT arguments to constructors are not
2153      considered in overload resolution.  */
2154   if (DECL_CONSTRUCTOR_P (fn))
2155     {
2156       if (ctor_omit_inherited_parms (fn))
2157         /* Bring back parameters omitted from an inherited ctor.  */
2158         parmlist = FUNCTION_FIRST_USER_PARMTYPE (DECL_ORIGIN (fn));
2159       else
2160         parmlist = skip_artificial_parms_for (fn, parmlist);
2161       skip = num_artificial_parms_for (fn);
2162       if (skip > 0 && first_arg != NULL_TREE)
2163         {
2164           --skip;
2165           first_arg = NULL_TREE;
2166         }
2167     }
2168   else
2169     skip = 0;
2170
2171   len = vec_safe_length (args) - skip + (first_arg != NULL_TREE ? 1 : 0);
2172   if (!convs)
2173     convs = alloc_conversions (len);
2174
2175   /* 13.3.2 - Viable functions [over.match.viable]
2176      First, to be a viable function, a candidate function shall have enough
2177      parameters to agree in number with the arguments in the list.
2178
2179      We need to check this first; otherwise, checking the ICSes might cause
2180      us to produce an ill-formed template instantiation.  */
2181
2182   parmnode = parmlist;
2183   for (i = 0; i < len; ++i)
2184     {
2185       if (parmnode == NULL_TREE || parmnode == void_list_node)
2186         break;
2187       parmnode = TREE_CHAIN (parmnode);
2188     }
2189
2190   if ((i < len && parmnode)
2191       || !sufficient_parms_p (parmnode))
2192     {
2193       int remaining = remaining_arguments (parmnode);
2194       viable = 0;
2195       reason = arity_rejection (first_arg, i + remaining, len);
2196     }
2197
2198   /* An inherited constructor (12.6.3 [class.inhctor.init]) that has a first
2199      parameter of type "reference to cv C" (including such a constructor
2200      instantiated from a template) is excluded from the set of candidate
2201      functions when used to construct an object of type D with an argument list
2202      containing a single argument if C is reference-related to D.  */
2203   if (viable && len == 1 && parmlist && DECL_CONSTRUCTOR_P (fn)
2204       && flag_new_inheriting_ctors
2205       && DECL_INHERITED_CTOR (fn))
2206     {
2207       tree ptype = non_reference (TREE_VALUE (parmlist));
2208       tree dtype = DECL_CONTEXT (fn);
2209       tree btype = DECL_INHERITED_CTOR_BASE (fn);
2210       if (reference_related_p (ptype, dtype)
2211           && reference_related_p (btype, ptype))
2212         {
2213           viable = false;
2214           reason = inherited_ctor_rejection ();
2215         }
2216     }
2217
2218   /* Second, for a function to be viable, its constraints must be
2219      satisfied. */
2220   if (flag_concepts && viable
2221       && !constraints_satisfied_p (fn))
2222     {
2223       reason = constraint_failure (fn);
2224       viable = false;
2225     }
2226
2227   /* When looking for a function from a subobject from an implicit
2228      copy/move constructor/operator=, don't consider anything that takes (a
2229      reference to) an unrelated type.  See c++/44909 and core 1092.  */
2230   if (viable && parmlist && (flags & LOOKUP_DEFAULTED))
2231     {
2232       if (DECL_CONSTRUCTOR_P (fn))
2233         i = 1;
2234       else if (DECL_ASSIGNMENT_OPERATOR_P (fn)
2235                && DECL_OVERLOADED_OPERATOR_IS (fn, NOP_EXPR))
2236         i = 2;
2237       else
2238         i = 0;
2239       if (i && len == i)
2240         {
2241           parmnode = chain_index (i-1, parmlist);
2242           if (!reference_related_p (non_reference (TREE_VALUE (parmnode)),
2243                                     ctype))
2244             viable = 0;
2245         }
2246
2247       /* This only applies at the top level.  */
2248       flags &= ~LOOKUP_DEFAULTED;
2249     }
2250
2251   if (! viable)
2252     goto out;
2253
2254   /* Third, for F to be a viable function, there shall exist for each
2255      argument an implicit conversion sequence that converts that argument
2256      to the corresponding parameter of F.  */
2257
2258   parmnode = parmlist;
2259
2260   for (i = 0; i < len; ++i)
2261     {
2262       tree argtype, to_type;
2263       tree arg;
2264       conversion *t;
2265       int is_this;
2266
2267       if (parmnode == void_list_node)
2268         break;
2269
2270       if (convs[i])
2271         {
2272           /* Already set during deduction.  */
2273           parmnode = TREE_CHAIN (parmnode);
2274           continue;
2275         }
2276
2277       if (i == 0 && first_arg != NULL_TREE)
2278         arg = first_arg;
2279       else
2280         arg = CONST_CAST_TREE (
2281                 (*args)[i + skip - (first_arg != NULL_TREE ? 1 : 0)]);
2282       argtype = lvalue_type (arg);
2283
2284       is_this = (i == 0 && DECL_NONSTATIC_MEMBER_FUNCTION_P (fn)
2285                  && ! DECL_CONSTRUCTOR_P (fn));
2286
2287       if (parmnode)
2288         {
2289           tree parmtype = TREE_VALUE (parmnode);
2290
2291           parmnode = TREE_CHAIN (parmnode);
2292
2293           /* The type of the implicit object parameter ('this') for
2294              overload resolution is not always the same as for the
2295              function itself; conversion functions are considered to
2296              be members of the class being converted, and functions
2297              introduced by a using-declaration are considered to be
2298              members of the class that uses them.
2299
2300              Since build_over_call ignores the ICS for the `this'
2301              parameter, we can just change the parm type.  */
2302           if (ctype && is_this)
2303             {
2304               parmtype = cp_build_qualified_type
2305                 (ctype, cp_type_quals (TREE_TYPE (parmtype)));
2306               if (FUNCTION_REF_QUALIFIED (TREE_TYPE (fn)))
2307                 {
2308                   /* If the function has a ref-qualifier, the implicit
2309                      object parameter has reference type.  */
2310                   bool rv = FUNCTION_RVALUE_QUALIFIED (TREE_TYPE (fn));
2311                   parmtype = cp_build_reference_type (parmtype, rv);
2312                   /* The special handling of 'this' conversions in compare_ics
2313                      does not apply if there is a ref-qualifier.  */
2314                   is_this = false;
2315                 }
2316               else
2317                 {
2318                   parmtype = build_pointer_type (parmtype);
2319                   /* We don't use build_this here because we don't want to
2320                      capture the object argument until we've chosen a
2321                      non-static member function.  */
2322                   arg = build_address (arg);
2323                   argtype = lvalue_type (arg);
2324                 }
2325             }
2326
2327           int lflags = conv_flags (i, len-skip, fn, arg, flags);
2328
2329           t = implicit_conversion (parmtype, argtype, arg,
2330                                    /*c_cast_p=*/false, lflags, complain);
2331           to_type = parmtype;
2332         }
2333       else
2334         {
2335           t = build_identity_conv (argtype, arg);
2336           t->ellipsis_p = true;
2337           to_type = argtype;
2338         }
2339
2340       if (t && is_this)
2341         t->this_p = true;
2342
2343       convs[i] = t;
2344       if (! t)
2345         {
2346           viable = 0;
2347           reason = arg_conversion_rejection (first_arg, i, argtype, to_type,
2348                                              EXPR_LOCATION (arg));
2349           break;
2350         }
2351
2352       if (t->bad_p)
2353         {
2354           viable = -1;
2355           reason = bad_arg_conversion_rejection (first_arg, i, arg, to_type,
2356                                                  EXPR_LOCATION (arg));
2357
2358         }
2359     }
2360
2361  out:
2362   return add_candidate (candidates, fn, orig_first_arg, args, len, convs,
2363                         access_path, conversion_path, viable, reason, flags);
2364 }
2365
2366 /* Create an overload candidate for the conversion function FN which will
2367    be invoked for expression OBJ, producing a pointer-to-function which
2368    will in turn be called with the argument list FIRST_ARG/ARGLIST,
2369    and add it to CANDIDATES.  This does not change ARGLIST.  FLAGS is
2370    passed on to implicit_conversion.
2371
2372    Actually, we don't really care about FN; we care about the type it
2373    converts to.  There may be multiple conversion functions that will
2374    convert to that type, and we rely on build_user_type_conversion_1 to
2375    choose the best one; so when we create our candidate, we record the type
2376    instead of the function.  */
2377
2378 static struct z_candidate *
2379 add_conv_candidate (struct z_candidate **candidates, tree fn, tree obj,
2380                     const vec<tree, va_gc> *arglist,
2381                     tree access_path, tree conversion_path,
2382                     tsubst_flags_t complain)
2383 {
2384   tree totype = TREE_TYPE (TREE_TYPE (fn));
2385   int i, len, viable, flags;
2386   tree parmlist, parmnode;
2387   conversion **convs;
2388   struct rejection_reason *reason;
2389
2390   for (parmlist = totype; TREE_CODE (parmlist) != FUNCTION_TYPE; )
2391     parmlist = TREE_TYPE (parmlist);
2392   parmlist = TYPE_ARG_TYPES (parmlist);
2393
2394   len = vec_safe_length (arglist) + 1;
2395   convs = alloc_conversions (len);
2396   parmnode = parmlist;
2397   viable = 1;
2398   flags = LOOKUP_IMPLICIT;
2399   reason = NULL;
2400
2401   /* Don't bother looking up the same type twice.  */
2402   if (*candidates && (*candidates)->fn == totype)
2403     return NULL;
2404
2405   for (i = 0; i < len; ++i)
2406     {
2407       tree arg, argtype, convert_type = NULL_TREE;
2408       conversion *t;
2409
2410       if (i == 0)
2411         arg = obj;
2412       else
2413         arg = (*arglist)[i - 1];
2414       argtype = lvalue_type (arg);
2415
2416       if (i == 0)
2417         {
2418           t = build_identity_conv (argtype, NULL_TREE);
2419           t = build_conv (ck_user, totype, t);
2420           /* Leave the 'cand' field null; we'll figure out the conversion in
2421              convert_like_real if this candidate is chosen.  */
2422           convert_type = totype;
2423         }
2424       else if (parmnode == void_list_node)
2425         break;
2426       else if (parmnode)
2427         {
2428           t = implicit_conversion (TREE_VALUE (parmnode), argtype, arg,
2429                                    /*c_cast_p=*/false, flags, complain);
2430           convert_type = TREE_VALUE (parmnode);
2431         }
2432       else
2433         {
2434           t = build_identity_conv (argtype, arg);
2435           t->ellipsis_p = true;
2436           convert_type = argtype;
2437         }
2438
2439       convs[i] = t;
2440       if (! t)
2441         break;
2442
2443       if (t->bad_p)
2444         {
2445           viable = -1;
2446           reason = bad_arg_conversion_rejection (NULL_TREE, i, arg, convert_type,
2447                                                  EXPR_LOCATION (arg));
2448         }
2449
2450       if (i == 0)
2451         continue;
2452
2453       if (parmnode)
2454         parmnode = TREE_CHAIN (parmnode);
2455     }
2456
2457   if (i < len
2458       || ! sufficient_parms_p (parmnode))
2459     {
2460       int remaining = remaining_arguments (parmnode);
2461       viable = 0;
2462       reason = arity_rejection (NULL_TREE, i + remaining, len);
2463     }
2464
2465   return add_candidate (candidates, totype, obj, arglist, len, convs,
2466                         access_path, conversion_path, viable, reason, flags);
2467 }
2468
2469 static void
2470 build_builtin_candidate (struct z_candidate **candidates, tree fnname,
2471                          tree type1, tree type2, tree *args, tree *argtypes,
2472                          int flags, tsubst_flags_t complain)
2473 {
2474   conversion *t;
2475   conversion **convs;
2476   size_t num_convs;
2477   int viable = 1, i;
2478   tree types[2];
2479   struct rejection_reason *reason = NULL;
2480
2481   types[0] = type1;
2482   types[1] = type2;
2483
2484   num_convs =  args[2] ? 3 : (args[1] ? 2 : 1);
2485   convs = alloc_conversions (num_convs);
2486
2487   /* TRUTH_*_EXPR do "contextual conversion to bool", which means explicit
2488      conversion ops are allowed.  We handle that here by just checking for
2489      boolean_type_node because other operators don't ask for it.  COND_EXPR
2490      also does contextual conversion to bool for the first operand, but we
2491      handle that in build_conditional_expr, and type1 here is operand 2.  */
2492   if (type1 != boolean_type_node)
2493     flags |= LOOKUP_ONLYCONVERTING;
2494
2495   for (i = 0; i < 2; ++i)
2496     {
2497       if (! args[i])
2498         break;
2499
2500       t = implicit_conversion (types[i], argtypes[i], args[i],
2501                                /*c_cast_p=*/false, flags, complain);
2502       if (! t)
2503         {
2504           viable = 0;
2505           /* We need something for printing the candidate.  */
2506           t = build_identity_conv (types[i], NULL_TREE);
2507           reason = arg_conversion_rejection (NULL_TREE, i, argtypes[i],
2508                                              types[i], EXPR_LOCATION (args[i]));
2509         }
2510       else if (t->bad_p)
2511         {
2512           viable = 0;
2513           reason = bad_arg_conversion_rejection (NULL_TREE, i, args[i],
2514                                                  types[i],
2515                                                  EXPR_LOCATION (args[i]));
2516         }
2517       convs[i] = t;
2518     }
2519
2520   /* For COND_EXPR we rearranged the arguments; undo that now.  */
2521   if (args[2])
2522     {
2523       convs[2] = convs[1];
2524       convs[1] = convs[0];
2525       t = implicit_conversion (boolean_type_node, argtypes[2], args[2],
2526                                /*c_cast_p=*/false, flags,
2527                                complain);
2528       if (t)
2529         convs[0] = t;
2530       else
2531         {
2532           viable = 0;
2533           reason = arg_conversion_rejection (NULL_TREE, 0, argtypes[2],
2534                                              boolean_type_node,
2535                                              EXPR_LOCATION (args[2]));
2536         }
2537     }
2538
2539   add_candidate (candidates, fnname, /*first_arg=*/NULL_TREE, /*args=*/NULL,
2540                  num_convs, convs,
2541                  /*access_path=*/NULL_TREE,
2542                  /*conversion_path=*/NULL_TREE,
2543                  viable, reason, flags);
2544 }
2545
2546 static bool
2547 is_complete (tree t)
2548 {
2549   return COMPLETE_TYPE_P (complete_type (t));
2550 }
2551
2552 /* Returns nonzero if TYPE is a promoted arithmetic type.  */
2553
2554 static bool
2555 promoted_arithmetic_type_p (tree type)
2556 {
2557   /* [over.built]
2558
2559      In this section, the term promoted integral type is used to refer
2560      to those integral types which are preserved by integral promotion
2561      (including e.g.  int and long but excluding e.g.  char).
2562      Similarly, the term promoted arithmetic type refers to promoted
2563      integral types plus floating types.  */
2564   return ((CP_INTEGRAL_TYPE_P (type)
2565            && same_type_p (type_promotes_to (type), type))
2566           || TREE_CODE (type) == REAL_TYPE);
2567 }
2568
2569 /* Create any builtin operator overload candidates for the operator in
2570    question given the converted operand types TYPE1 and TYPE2.  The other
2571    args are passed through from add_builtin_candidates to
2572    build_builtin_candidate.
2573
2574    TYPE1 and TYPE2 may not be permissible, and we must filter them.
2575    If CODE is requires candidates operands of the same type of the kind
2576    of which TYPE1 and TYPE2 are, we add both candidates
2577    CODE (TYPE1, TYPE1) and CODE (TYPE2, TYPE2).  */
2578
2579 static void
2580 add_builtin_candidate (struct z_candidate **candidates, enum tree_code code,
2581                        enum tree_code code2, tree fnname, tree type1,
2582                        tree type2, tree *args, tree *argtypes, int flags,
2583                        tsubst_flags_t complain)
2584 {
2585   switch (code)
2586     {
2587     case POSTINCREMENT_EXPR:
2588     case POSTDECREMENT_EXPR:
2589       args[1] = integer_zero_node;
2590       type2 = integer_type_node;
2591       break;
2592     default:
2593       break;
2594     }
2595
2596   switch (code)
2597     {
2598
2599 /* 4 For every pair T, VQ), where T is an arithmetic or  enumeration  type,
2600      and  VQ  is  either  volatile or empty, there exist candidate operator
2601      functions of the form
2602              VQ T&   operator++(VQ T&);
2603              T       operator++(VQ T&, int);
2604    5 For every pair T, VQ), where T is an enumeration type or an arithmetic
2605      type  other than bool, and VQ is either volatile or empty, there exist
2606      candidate operator functions of the form
2607              VQ T&   operator--(VQ T&);
2608              T       operator--(VQ T&, int);
2609    6 For every pair T, VQ), where T is  a  cv-qualified  or  cv-unqualified
2610      complete  object type, and VQ is either volatile or empty, there exist
2611      candidate operator functions of the form
2612              T*VQ&   operator++(T*VQ&);
2613              T*VQ&   operator--(T*VQ&);
2614              T*      operator++(T*VQ&, int);
2615              T*      operator--(T*VQ&, int);  */
2616
2617     case POSTDECREMENT_EXPR:
2618     case PREDECREMENT_EXPR:
2619       if (TREE_CODE (type1) == BOOLEAN_TYPE)
2620         return;
2621       /* FALLTHRU */
2622     case POSTINCREMENT_EXPR:
2623     case PREINCREMENT_EXPR:
2624       if (ARITHMETIC_TYPE_P (type1) || TYPE_PTROB_P (type1))
2625         {
2626           type1 = build_reference_type (type1);
2627           break;
2628         }
2629       return;
2630
2631 /* 7 For every cv-qualified or cv-unqualified object type T, there
2632      exist candidate operator functions of the form
2633
2634              T&      operator*(T*);
2635
2636    8 For every function type T, there exist candidate operator functions of
2637      the form
2638              T&      operator*(T*);  */
2639
2640     case INDIRECT_REF:
2641       if (TYPE_PTR_P (type1)
2642           && (TYPE_PTROB_P (type1)
2643               || TREE_CODE (TREE_TYPE (type1)) == FUNCTION_TYPE))
2644         break;
2645       return;
2646
2647 /* 9 For every type T, there exist candidate operator functions of the form
2648              T*      operator+(T*);
2649
2650    10For  every  promoted arithmetic type T, there exist candidate operator
2651      functions of the form
2652              T       operator+(T);
2653              T       operator-(T);  */
2654
2655     case UNARY_PLUS_EXPR: /* unary + */
2656       if (TYPE_PTR_P (type1))
2657         break;
2658       /* FALLTHRU */
2659     case NEGATE_EXPR:
2660       if (ARITHMETIC_TYPE_P (type1))
2661         break;
2662       return;
2663
2664 /* 11For every promoted integral type T,  there  exist  candidate  operator
2665      functions of the form
2666              T       operator~(T);  */
2667
2668     case BIT_NOT_EXPR:
2669       if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type1))
2670         break;
2671       return;
2672
2673 /* 12For every quintuple C1, C2, T, CV1, CV2), where C2 is a class type, C1
2674      is the same type as C2 or is a derived class of C2, T  is  a  complete
2675      object type or a function type, and CV1 and CV2 are cv-qualifier-seqs,
2676      there exist candidate operator functions of the form
2677              CV12 T& operator->*(CV1 C1*, CV2 T C2::*);
2678      where CV12 is the union of CV1 and CV2.  */
2679
2680     case MEMBER_REF:
2681       if (TYPE_PTR_P (type1) && TYPE_PTRMEM_P (type2))
2682         {
2683           tree c1 = TREE_TYPE (type1);
2684           tree c2 = TYPE_PTRMEM_CLASS_TYPE (type2);
2685
2686           if (MAYBE_CLASS_TYPE_P (c1) && DERIVED_FROM_P (c2, c1)
2687               && (TYPE_PTRMEMFUNC_P (type2)
2688                   || is_complete (TYPE_PTRMEM_POINTED_TO_TYPE (type2))))
2689             break;
2690         }
2691       return;
2692
2693 /* 13For every pair of promoted arithmetic types L and R, there exist  can-
2694      didate operator functions of the form
2695              LR      operator*(L, R);
2696              LR      operator/(L, R);
2697              LR      operator+(L, R);
2698              LR      operator-(L, R);
2699              bool    operator<(L, R);
2700              bool    operator>(L, R);
2701              bool    operator<=(L, R);
2702              bool    operator>=(L, R);
2703              bool    operator==(L, R);
2704              bool    operator!=(L, R);
2705      where  LR  is  the  result of the usual arithmetic conversions between
2706      types L and R.
2707
2708    14For every pair of types T and I, where T  is  a  cv-qualified  or  cv-
2709      unqualified  complete  object  type and I is a promoted integral type,
2710      there exist candidate operator functions of the form
2711              T*      operator+(T*, I);
2712              T&      operator[](T*, I);
2713              T*      operator-(T*, I);
2714              T*      operator+(I, T*);
2715              T&      operator[](I, T*);
2716
2717    15For every T, where T is a pointer to complete object type, there exist
2718      candidate operator functions of the form112)
2719              ptrdiff_t operator-(T, T);
2720
2721    16For every pointer or enumeration type T, there exist candidate operator
2722      functions of the form
2723              bool    operator<(T, T);
2724              bool    operator>(T, T);
2725              bool    operator<=(T, T);
2726              bool    operator>=(T, T);
2727              bool    operator==(T, T);
2728              bool    operator!=(T, T);
2729
2730    17For every pointer to member type T,  there  exist  candidate  operator
2731      functions of the form
2732              bool    operator==(T, T);
2733              bool    operator!=(T, T);  */
2734
2735     case MINUS_EXPR:
2736       if (TYPE_PTROB_P (type1) && TYPE_PTROB_P (type2))
2737         break;
2738       if (TYPE_PTROB_P (type1)
2739           && INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type2))
2740         {
2741           type2 = ptrdiff_type_node;
2742           break;
2743         }
2744       /* FALLTHRU */
2745     case MULT_EXPR:
2746     case TRUNC_DIV_EXPR:
2747       if (ARITHMETIC_TYPE_P (type1) && ARITHMETIC_TYPE_P (type2))
2748         break;
2749       return;
2750
2751     case EQ_EXPR:
2752     case NE_EXPR:
2753       if ((TYPE_PTRMEMFUNC_P (type1) && TYPE_PTRMEMFUNC_P (type2))
2754           || (TYPE_PTRDATAMEM_P (type1) && TYPE_PTRDATAMEM_P (type2)))
2755         break;
2756       if (TYPE_PTRMEM_P (type1) && null_ptr_cst_p (args[1]))
2757         {
2758           type2 = type1;
2759           break;
2760         }
2761       if (TYPE_PTRMEM_P (type2) && null_ptr_cst_p (args[0]))
2762         {
2763           type1 = type2;
2764           break;
2765         }
2766       /* Fall through.  */
2767     case LT_EXPR:
2768     case GT_EXPR:
2769     case LE_EXPR:
2770     case GE_EXPR:
2771     case MAX_EXPR:
2772     case MIN_EXPR:
2773       if (ARITHMETIC_TYPE_P (type1) && ARITHMETIC_TYPE_P (type2))
2774         break;
2775       if (TYPE_PTR_P (type1) && TYPE_PTR_P (type2))
2776         break;
2777       if (TREE_CODE (type1) == ENUMERAL_TYPE 
2778           && TREE_CODE (type2) == ENUMERAL_TYPE)
2779         break;
2780       if (TYPE_PTR_P (type1) 
2781           && null_ptr_cst_p (args[1]))
2782         {
2783           type2 = type1;
2784           break;
2785         }
2786       if (null_ptr_cst_p (args[0]) 
2787           && TYPE_PTR_P (type2))
2788         {
2789           type1 = type2;
2790           break;
2791         }
2792       return;
2793
2794     case PLUS_EXPR:
2795       if (ARITHMETIC_TYPE_P (type1) && ARITHMETIC_TYPE_P (type2))
2796         break;
2797       /* FALLTHRU */
2798     case ARRAY_REF:
2799       if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type1) && TYPE_PTROB_P (type2))
2800         {
2801           type1 = ptrdiff_type_node;
2802           break;
2803         }
2804       if (TYPE_PTROB_P (type1) && INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type2))
2805         {
2806           type2 = ptrdiff_type_node;
2807           break;
2808         }
2809       return;
2810
2811 /* 18For  every pair of promoted integral types L and R, there exist candi-
2812      date operator functions of the form
2813              LR      operator%(L, R);
2814              LR      operator&(L, R);
2815              LR      operator^(L, R);
2816              LR      operator|(L, R);
2817              L       operator<<(L, R);
2818              L       operator>>(L, R);
2819      where LR is the result of the  usual  arithmetic  conversions  between
2820      types L and R.  */
2821
2822     case TRUNC_MOD_EXPR:
2823     case BIT_AND_EXPR:
2824     case BIT_IOR_EXPR:
2825     case BIT_XOR_EXPR:
2826     case LSHIFT_EXPR:
2827     case RSHIFT_EXPR:
2828       if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type1) && INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type2))
2829         break;
2830       return;
2831
2832 /* 19For  every  triple  L, VQ, R), where L is an arithmetic or enumeration
2833      type, VQ is either volatile or empty, and R is a  promoted  arithmetic
2834      type, there exist candidate operator functions of the form
2835              VQ L&   operator=(VQ L&, R);
2836              VQ L&   operator*=(VQ L&, R);
2837              VQ L&   operator/=(VQ L&, R);
2838              VQ L&   operator+=(VQ L&, R);
2839              VQ L&   operator-=(VQ L&, R);
2840
2841    20For  every  pair T, VQ), where T is any type and VQ is either volatile
2842      or empty, there exist candidate operator functions of the form
2843              T*VQ&   operator=(T*VQ&, T*);
2844
2845    21For every pair T, VQ), where T is a pointer to member type and  VQ  is
2846      either  volatile or empty, there exist candidate operator functions of
2847      the form
2848              VQ T&   operator=(VQ T&, T);
2849
2850    22For every triple  T,  VQ,  I),  where  T  is  a  cv-qualified  or  cv-
2851      unqualified  complete object type, VQ is either volatile or empty, and
2852      I is a promoted integral type, there exist  candidate  operator  func-
2853      tions of the form
2854              T*VQ&   operator+=(T*VQ&, I);
2855              T*VQ&   operator-=(T*VQ&, I);
2856
2857    23For  every  triple  L,  VQ,  R), where L is an integral or enumeration
2858      type, VQ is either volatile or empty, and R  is  a  promoted  integral
2859      type, there exist candidate operator functions of the form
2860
2861              VQ L&   operator%=(VQ L&, R);
2862              VQ L&   operator<<=(VQ L&, R);
2863              VQ L&   operator>>=(VQ L&, R);
2864              VQ L&   operator&=(VQ L&, R);
2865              VQ L&   operator^=(VQ L&, R);
2866              VQ L&   operator|=(VQ L&, R);  */
2867
2868     case MODIFY_EXPR:
2869       switch (code2)
2870         {
2871         case PLUS_EXPR:
2872         case MINUS_EXPR:
2873           if (TYPE_PTROB_P (type1) && INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type2))
2874             {
2875               type2 = ptrdiff_type_node;
2876               break;
2877             }
2878           /* FALLTHRU */
2879         case MULT_EXPR:
2880         case TRUNC_DIV_EXPR:
2881           if (ARITHMETIC_TYPE_P (type1) && ARITHMETIC_TYPE_P (type2))
2882             break;
2883           return;
2884
2885         case TRUNC_MOD_EXPR:
2886         case BIT_AND_EXPR:
2887         case BIT_IOR_EXPR:
2888         case BIT_XOR_EXPR:
2889         case LSHIFT_EXPR:
2890         case RSHIFT_EXPR:
2891           if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type1) && INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type2))
2892             break;
2893           return;
2894
2895         case NOP_EXPR:
2896           if (ARITHMETIC_TYPE_P (type1) && ARITHMETIC_TYPE_P (type2))
2897             break;
2898           if ((TYPE_PTRMEMFUNC_P (type1) && TYPE_PTRMEMFUNC_P (type2))
2899               || (TYPE_PTR_P (type1) && TYPE_PTR_P (type2))
2900               || (TYPE_PTRDATAMEM_P (type1) && TYPE_PTRDATAMEM_P (type2))
2901               || ((TYPE_PTRMEMFUNC_P (type1)
2902                    || TYPE_PTR_P (type1))
2903                   && null_ptr_cst_p (args[1])))
2904             {
2905               type2 = type1;
2906               break;
2907             }
2908           return;
2909
2910         default:
2911           gcc_unreachable ();
2912         }
2913       type1 = build_reference_type (type1);
2914       break;
2915
2916     case COND_EXPR:
2917       /* [over.built]
2918
2919          For every pair of promoted arithmetic types L and R, there
2920          exist candidate operator functions of the form
2921
2922          LR operator?(bool, L, R);
2923
2924          where LR is the result of the usual arithmetic conversions
2925          between types L and R.
2926
2927          For every type T, where T is a pointer or pointer-to-member
2928          type, there exist candidate operator functions of the form T
2929          operator?(bool, T, T);  */
2930
2931       if (promoted_arithmetic_type_p (type1)
2932           && promoted_arithmetic_type_p (type2))
2933         /* That's OK.  */
2934         break;
2935
2936       /* Otherwise, the types should be pointers.  */
2937       if (!TYPE_PTR_OR_PTRMEM_P (type1) || !TYPE_PTR_OR_PTRMEM_P (type2))
2938         return;
2939
2940       /* We don't check that the two types are the same; the logic
2941          below will actually create two candidates; one in which both
2942          parameter types are TYPE1, and one in which both parameter
2943          types are TYPE2.  */
2944       break;
2945
2946     case REALPART_EXPR:
2947     case IMAGPART_EXPR:
2948       if (ARITHMETIC_TYPE_P (type1))
2949         break;
2950       return;
2951  
2952     default:
2953       gcc_unreachable ();
2954     }
2955
2956   /* Make sure we don't create builtin candidates with dependent types.  */
2957   bool u1 = uses_template_parms (type1);
2958   bool u2 = type2 ? uses_template_parms (type2) : false;
2959   if (u1 || u2)
2960     {
2961       /* Try to recover if one of the types is non-dependent.  But if
2962          there's only one type, there's nothing we can do.  */
2963       if (!type2)
2964         return;
2965       /* And we lose if both are dependent.  */
2966       if (u1 && u2)
2967         return;
2968       /* Or if they have different forms.  */
2969       if (TREE_CODE (type1) != TREE_CODE (type2))
2970         return;
2971
2972       if (u1 && !u2)
2973         type1 = type2;
2974       else if (u2 && !u1)
2975         type2 = type1;
2976     }
2977
2978   /* If we're dealing with two pointer types or two enumeral types,
2979      we need candidates for both of them.  */
2980   if (type2 && !same_type_p (type1, type2)
2981       && TREE_CODE (type1) == TREE_CODE (type2)
2982       && (TYPE_REF_P (type1)
2983           || (TYPE_PTR_P (type1) && TYPE_PTR_P (type2))
2984           || (TYPE_PTRDATAMEM_P (type1) && TYPE_PTRDATAMEM_P (type2))
2985           || TYPE_PTRMEMFUNC_P (type1)
2986           || MAYBE_CLASS_TYPE_P (type1)
2987           || TREE_CODE (type1) == ENUMERAL_TYPE))
2988     {
2989       if (TYPE_PTR_OR_PTRMEM_P (type1))
2990         {
2991           tree cptype = composite_pointer_type (type1, type2,
2992                                                 error_mark_node,
2993                                                 error_mark_node,
2994                                                 CPO_CONVERSION,
2995                                                 tf_none);
2996           if (cptype != error_mark_node)
2997             {
2998               build_builtin_candidate
2999                 (candidates, fnname, cptype, cptype, args, argtypes,
3000                  flags, complain);
3001               return;
3002             }
3003         }
3004
3005       build_builtin_candidate
3006         (candidates, fnname, type1, type1, args, argtypes, flags, complain);
3007       build_builtin_candidate
3008         (candidates, fnname, type2, type2, args, argtypes, flags, complain);
3009       return;
3010     }
3011
3012   build_builtin_candidate
3013     (candidates, fnname, type1, type2, args, argtypes, flags, complain);
3014 }
3015
3016 tree
3017 type_decays_to (tree type)
3018 {
3019   if (TREE_CODE (type) == ARRAY_TYPE)
3020     return build_pointer_type (TREE_TYPE (type));
3021   if (TREE_CODE (type) == FUNCTION_TYPE)
3022     return build_pointer_type (type);
3023   return type;
3024 }
3025
3026 /* There are three conditions of builtin candidates:
3027
3028    1) bool-taking candidates.  These are the same regardless of the input.
3029    2) pointer-pair taking candidates.  These are generated for each type
3030       one of the input types converts to.
3031    3) arithmetic candidates.  According to the standard, we should generate
3032       all of these, but I'm trying not to...
3033
3034    Here we generate a superset of the possible candidates for this particular
3035    case.  That is a subset of the full set the standard defines, plus some
3036    other cases which the standard disallows. add_builtin_candidate will
3037    filter out the invalid set.  */
3038
3039 static void
3040 add_builtin_candidates (struct z_candidate **candidates, enum tree_code code,
3041                         enum tree_code code2, tree fnname, tree *args,
3042                         int flags, tsubst_flags_t complain)
3043 {
3044   int ref1, i;
3045   int enum_p = 0;
3046   tree type, argtypes[3], t;
3047   /* TYPES[i] is the set of possible builtin-operator parameter types
3048      we will consider for the Ith argument.  */
3049   vec<tree, va_gc> *types[2];
3050   unsigned ix;
3051
3052   for (i = 0; i < 3; ++i)
3053     {
3054       if (args[i])
3055         argtypes[i] = unlowered_expr_type (args[i]);
3056       else
3057         argtypes[i] = NULL_TREE;
3058     }
3059
3060   switch (code)
3061     {
3062 /* 4 For every pair T, VQ), where T is an arithmetic or  enumeration  type,
3063      and  VQ  is  either  volatile or empty, there exist candidate operator
3064      functions of the form
3065                  VQ T&   operator++(VQ T&);  */
3066
3067     case POSTINCREMENT_EXPR:
3068     case PREINCREMENT_EXPR:
3069     case POSTDECREMENT_EXPR:
3070     case PREDECREMENT_EXPR:
3071     case MODIFY_EXPR:
3072       ref1 = 1;
3073       break;
3074
3075 /* 24There also exist candidate operator functions of the form
3076              bool    operator!(bool);
3077              bool    operator&&(bool, bool);
3078              bool    operator||(bool, bool);  */
3079
3080     case TRUTH_NOT_EXPR:
3081       build_builtin_candidate
3082         (candidates, fnname, boolean_type_node,
3083          NULL_TREE, args, argtypes, flags, complain);
3084       return;
3085
3086     case TRUTH_ORIF_EXPR:
3087     case TRUTH_ANDIF_EXPR:
3088       build_builtin_candidate
3089         (candidates, fnname, boolean_type_node,
3090          boolean_type_node, args, argtypes, flags, complain);
3091       return;
3092
3093     case ADDR_EXPR:
3094     case COMPOUND_EXPR:
3095     case COMPONENT_REF:
3096       return;
3097
3098     case COND_EXPR:
3099     case EQ_EXPR:
3100     case NE_EXPR:
3101     case LT_EXPR:
3102     case LE_EXPR:
3103     case GT_EXPR:
3104     case GE_EXPR:
3105       enum_p = 1;
3106       /* Fall through.  */
3107
3108     default:
3109       ref1 = 0;
3110     }
3111
3112   types[0] = make_tree_vector ();
3113   types[1] = make_tree_vector ();
3114
3115   for (i = 0; i < 2; ++i)
3116     {
3117       if (! args[i])
3118         ;
3119       else if (MAYBE_CLASS_TYPE_P (argtypes[i]))
3120         {
3121           tree convs;
3122
3123           if (i == 0 && code == MODIFY_EXPR && code2 == NOP_EXPR)
3124             return;
3125
3126           convs = lookup_conversions (argtypes[i]);
3127
3128           if (code == COND_EXPR)
3129             {
3130               if (lvalue_p (args[i]))
3131                 vec_safe_push (types[i], build_reference_type (argtypes[i]));
3132
3133               vec_safe_push (types[i], TYPE_MAIN_VARIANT (argtypes[i]));
3134             }
3135
3136           else if (! convs)
3137             return;
3138
3139           for (; convs; convs = TREE_CHAIN (convs))
3140             {
3141               type = TREE_TYPE (convs);
3142
3143               if (i == 0 && ref1
3144                   && (!TYPE_REF_P (type)
3145                       || CP_TYPE_CONST_P (TREE_TYPE (type))))
3146                 continue;
3147
3148               if (code == COND_EXPR && TYPE_REF_P (type))
3149                 vec_safe_push (types[i], type);
3150
3151               type = non_reference (type);
3152               if (i != 0 || ! ref1)
3153                 {
3154                   type = cv_unqualified (type_decays_to (type));
3155                   if (enum_p && TREE_CODE (type) == ENUMERAL_TYPE)
3156                     vec_safe_push (types[i], type);
3157                   if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type))
3158                     type = type_promotes_to (type);
3159                 }
3160
3161               if (! vec_member (type, types[i]))
3162                 vec_safe_push (types[i], type);
3163             }
3164         }
3165       else
3166         {
3167           if (code == COND_EXPR && lvalue_p (args[i]))
3168             vec_safe_push (types[i], build_reference_type (argtypes[i]));
3169           type = non_reference (argtypes[i]);
3170           if (i != 0 || ! ref1)
3171             {
3172               type = cv_unqualified (type_decays_to (type));
3173               if (enum_p && UNSCOPED_ENUM_P (type))
3174                 vec_safe_push (types[i], type);
3175               if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type))
3176                 type = type_promotes_to (type);
3177             }
3178           vec_safe_push (types[i], type);
3179         }
3180     }
3181
3182   /* Run through the possible parameter types of both arguments,
3183      creating candidates with those parameter types.  */
3184   FOR_EACH_VEC_ELT_REVERSE (*(types[0]), ix, t)
3185     {
3186       unsigned jx;
3187       tree u;
3188
3189       if (!types[1]->is_empty ())
3190         FOR_EACH_VEC_ELT_REVERSE (*(types[1]), jx, u)
3191           add_builtin_candidate
3192             (candidates, code, code2, fnname, t,
3193              u, args, argtypes, flags, complain);
3194       else
3195         add_builtin_candidate
3196           (candidates, code, code2, fnname, t,
3197            NULL_TREE, args, argtypes, flags, complain);
3198     }
3199
3200   release_tree_vector (types[0]);
3201   release_tree_vector (types[1]);
3202 }
3203
3204
3205 /* If TMPL can be successfully instantiated as indicated by
3206    EXPLICIT_TARGS and ARGLIST, adds the instantiation to CANDIDATES.
3207
3208    TMPL is the template.  EXPLICIT_TARGS are any explicit template
3209    arguments.  ARGLIST is the arguments provided at the call-site.
3210    This does not change ARGLIST.  The RETURN_TYPE is the desired type
3211    for conversion operators.  If OBJ is NULL_TREE, FLAGS and CTYPE are
3212    as for add_function_candidate.  If an OBJ is supplied, FLAGS and
3213    CTYPE are ignored, and OBJ is as for add_conv_candidate.  */
3214
3215 static struct z_candidate*
3216 add_template_candidate_real (struct z_candidate **candidates, tree tmpl,
3217                              tree ctype, tree explicit_targs, tree first_arg,
3218                              const vec<tree, va_gc> *arglist, tree return_type,
3219                              tree access_path, tree conversion_path,
3220                              int flags, tree obj, unification_kind_t strict,
3221                              tsubst_flags_t complain)
3222 {
3223   int ntparms = DECL_NTPARMS (tmpl);
3224   tree targs = make_tree_vec (ntparms);
3225   unsigned int len = vec_safe_length (arglist);
3226   unsigned int nargs = (first_arg == NULL_TREE ? 0 : 1) + len;
3227   unsigned int skip_without_in_chrg = 0;
3228   tree first_arg_without_in_chrg = first_arg;
3229   tree *args_without_in_chrg;
3230   unsigned int nargs_without_in_chrg;
3231   unsigned int ia, ix;
3232   tree arg;
3233   struct z_candidate *cand;
3234   tree fn;
3235   struct rejection_reason *reason = NULL;
3236   int errs;
3237   conversion **convs = NULL;
3238
3239   /* We don't do deduction on the in-charge parameter, the VTT
3240      parameter or 'this'.  */
3241   if (DECL_NONSTATIC_MEMBER_FUNCTION_P (tmpl))
3242     {
3243       if (first_arg_without_in_chrg != NULL_TREE)
3244         first_arg_without_in_chrg = NULL_TREE;
3245       else if (return_type && strict == DEDUCE_CALL)
3246         /* We're deducing for a call to the result of a template conversion
3247            function, so the args don't contain 'this'; leave them alone.  */;
3248       else
3249         ++skip_without_in_chrg;
3250     }
3251
3252   if ((DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (tmpl)
3253        || DECL_BASE_CONSTRUCTOR_P (tmpl))
3254       && CLASSTYPE_VBASECLASSES (DECL_CONTEXT (tmpl)))
3255     {
3256       if (first_arg_without_in_chrg != NULL_TREE)
3257         first_arg_without_in_chrg = NULL_TREE;
3258       else
3259         ++skip_without_in_chrg;
3260     }
3261
3262   if (len < skip_without_in_chrg)
3263     return NULL;
3264
3265   if (DECL_CONSTRUCTOR_P (tmpl) && nargs == 2
3266       && same_type_ignoring_top_level_qualifiers_p (TREE_TYPE (first_arg),
3267                                                     TREE_TYPE ((*arglist)[0])))
3268     {
3269       /* 12.8/6 says, "A declaration of a constructor for a class X is
3270          ill-formed if its first parameter is of type (optionally cv-qualified)
3271          X and either there are no other parameters or else all other
3272          parameters have default arguments. A member function template is never
3273          instantiated to produce such a constructor signature."
3274
3275          So if we're trying to copy an object of the containing class, don't
3276          consider a template constructor that has a first parameter type that
3277          is just a template parameter, as we would deduce a signature that we
3278          would then reject in the code below.  */
3279       if (tree firstparm = FUNCTION_FIRST_USER_PARMTYPE (tmpl))
3280         {
3281           firstparm = TREE_VALUE (firstparm);
3282           if (PACK_EXPANSION_P (firstparm))
3283             firstparm = PACK_EXPANSION_PATTERN (firstparm);
3284           if (TREE_CODE (firstparm) == TEMPLATE_TYPE_PARM)
3285             {
3286               gcc_assert (!explicit_targs);
3287               reason = invalid_copy_with_fn_template_rejection ();
3288               goto fail;
3289             }
3290         }
3291     }
3292
3293   nargs_without_in_chrg = ((first_arg_without_in_chrg != NULL_TREE ? 1 : 0)
3294                            + (len - skip_without_in_chrg));
3295   args_without_in_chrg = XALLOCAVEC (tree, nargs_without_in_chrg);
3296   ia = 0;
3297   if (first_arg_without_in_chrg != NULL_TREE)
3298     {
3299       args_without_in_chrg[ia] = first_arg_without_in_chrg;
3300       ++ia;
3301     }
3302   for (ix = skip_without_in_chrg;
3303        vec_safe_iterate (arglist, ix, &arg);
3304        ++ix)
3305     {
3306       args_without_in_chrg[ia] = arg;
3307       ++ia;
3308     }
3309   gcc_assert (ia == nargs_without_in_chrg);
3310
3311   errs = errorcount+sorrycount;
3312   if (!obj)
3313     convs = alloc_conversions (nargs);
3314   fn = fn_type_unification (tmpl, explicit_targs, targs,
3315                             args_without_in_chrg,
3316                             nargs_without_in_chrg,
3317                             return_type, strict, flags, convs,
3318                             false, complain & tf_decltype);
3319
3320   if (fn == error_mark_node)
3321     {
3322       /* Don't repeat unification later if it already resulted in errors.  */
3323       if (errorcount+sorrycount == errs)
3324         reason = template_unification_rejection (tmpl, explicit_targs,
3325                                                  targs, args_without_in_chrg,
3326                                                  nargs_without_in_chrg,
3327                                                  return_type, strict, flags);
3328       else
3329         reason = template_unification_error_rejection ();
3330       goto fail;
3331     }
3332
3333   /* Now the explicit specifier might have been deduced; check if this
3334      declaration is explicit.  If it is and we're ignoring non-converting
3335      constructors, don't add this function to the set of candidates.  */
3336   if ((flags & LOOKUP_ONLYCONVERTING) && DECL_NONCONVERTING_P (fn))
3337     return NULL;
3338
3339   if (DECL_CONSTRUCTOR_P (fn) && nargs == 2)
3340     {
3341       tree arg_types = FUNCTION_FIRST_USER_PARMTYPE (fn);
3342       if (arg_types && same_type_p (TYPE_MAIN_VARIANT (TREE_VALUE (arg_types)),
3343                                     ctype))
3344         {
3345           /* We're trying to produce a constructor with a prohibited signature,
3346              as discussed above; handle here any cases we didn't catch then,
3347              such as X(X<T>).  */
3348           reason = invalid_copy_with_fn_template_rejection ();
3349           goto fail;
3350         }
3351     }
3352
3353   if (obj != NULL_TREE)
3354     /* Aha, this is a conversion function.  */
3355     cand = add_conv_candidate (candidates, fn, obj, arglist,
3356                                access_path, conversion_path, complain);
3357   else
3358     cand = add_function_candidate (candidates, fn, ctype,
3359                                    first_arg, arglist, access_path,
3360                                    conversion_path, flags, convs, complain);
3361   if (DECL_TI_TEMPLATE (fn) != tmpl)
3362     /* This situation can occur if a member template of a template
3363        class is specialized.  Then, instantiate_template might return
3364        an instantiation of the specialization, in which case the
3365        DECL_TI_TEMPLATE field will point at the original
3366        specialization.  For example:
3367
3368          template <class T> struct S { template <class U> void f(U);
3369                                        template <> void f(int) {}; };
3370          S<double> sd;
3371          sd.f(3);
3372
3373        Here, TMPL will be template <class U> S<double>::f(U).
3374        And, instantiate template will give us the specialization
3375        template <> S<double>::f(int).  But, the DECL_TI_TEMPLATE field
3376        for this will point at template <class T> template <> S<T>::f(int),
3377        so that we can find the definition.  For the purposes of
3378        overload resolution, however, we want the original TMPL.  */
3379     cand->template_decl = build_template_info (tmpl, targs);
3380   else
3381     cand->template_decl = DECL_TEMPLATE_INFO (fn);
3382   cand->explicit_targs = explicit_targs;
3383
3384   return cand;
3385  fail:
3386   return add_candidate (candidates, tmpl, first_arg, arglist, nargs, NULL,
3387                         access_path, conversion_path, 0, reason, flags);
3388 }
3389
3390
3391 static struct z_candidate *
3392 add_template_candidate (struct z_candidate **candidates, tree tmpl, tree ctype,
3393                         tree explicit_targs, tree first_arg,
3394                         const vec<tree, va_gc> *arglist, tree return_type,
3395                         tree access_path, tree conversion_path, int flags,
3396                         unification_kind_t strict, tsubst_flags_t complain)
3397 {
3398   return
3399     add_template_candidate_real (candidates, tmpl, ctype,
3400                                  explicit_targs, first_arg, arglist,
3401                                  return_type, access_path, conversion_path,
3402                                  flags, NULL_TREE, strict, complain);
3403 }
3404
3405 /* Create an overload candidate for the conversion function template TMPL,
3406    returning RETURN_TYPE, which will be invoked for expression OBJ to produce a
3407    pointer-to-function which will in turn be called with the argument list
3408    ARGLIST, and add it to CANDIDATES.  This does not change ARGLIST.  FLAGS is
3409    passed on to implicit_conversion.  */
3410
3411 static struct z_candidate *
3412 add_template_conv_candidate (struct z_candidate **candidates, tree tmpl,
3413                              tree obj,
3414                              const vec<tree, va_gc> *arglist,
3415                              tree return_type, tree access_path,
3416                              tree conversion_path, tsubst_flags_t complain)
3417 {
3418   /* Making this work broke PR 71117 and 85118, so until the committee resolves
3419      core issue 2189, let's disable this candidate if there are any call
3420      operators.  */
3421   if (*candidates)
3422     return NULL;
3423
3424   return
3425     add_template_candidate_real (candidates, tmpl, NULL_TREE, NULL_TREE,
3426                                  NULL_TREE, arglist, return_type, access_path,
3427                                  conversion_path, 0, obj, DEDUCE_CALL,
3428                                  complain);
3429 }
3430
3431 /* The CANDS are the set of candidates that were considered for
3432    overload resolution.  Return the set of viable candidates, or CANDS
3433    if none are viable.  If any of the candidates were viable, set
3434    *ANY_VIABLE_P to true.  STRICT_P is true if a candidate should be
3435    considered viable only if it is strictly viable.  */
3436
3437 static struct z_candidate*
3438 splice_viable (struct z_candidate *cands,
3439                bool strict_p,
3440                bool *any_viable_p)
3441 {
3442   struct z_candidate *viable;
3443   struct z_candidate **last_viable;
3444   struct z_candidate **cand;
3445   bool found_strictly_viable = false;
3446
3447   /* Be strict inside templates, since build_over_call won't actually
3448      do the conversions to get pedwarns.  */
3449   if (processing_template_decl)
3450     strict_p = true;
3451
3452   viable = NULL;
3453   last_viable = &viable;
3454   *any_viable_p = false;
3455
3456   cand = &cands;
3457   while (*cand)
3458     {
3459       struct z_candidate *c = *cand;
3460       if (!strict_p
3461           && (c->viable == 1 || TREE_CODE (c->fn) == TEMPLATE_DECL))
3462         {
3463           /* Be strict in the presence of a viable candidate.  Also if
3464              there are template candidates, so that we get deduction errors
3465              for them instead of silently preferring a bad conversion.  */
3466           strict_p = true;
3467           if (viable && !found_strictly_viable)
3468             {
3469               /* Put any spliced near matches back onto the main list so
3470                  that we see them if there is no strict match.  */
3471               *any_viable_p = false;
3472               *last_viable = cands;
3473               cands = viable;
3474               viable = NULL;
3475               last_viable = &viable;
3476             }
3477         }
3478
3479       if (strict_p ? c->viable == 1 : c->viable)
3480         {
3481           *last_viable = c;
3482           *cand = c->next;
3483           c->next = NULL;
3484           last_viable = &c->next;
3485           *any_viable_p = true;
3486           if (c->viable == 1)
3487             found_strictly_viable = true;
3488         }
3489       else
3490         cand = &c->next;
3491     }
3492
3493   return viable ? viable : cands;
3494 }
3495
3496 static bool
3497 any_strictly_viable (struct z_candidate *cands)
3498 {
3499   for (; cands; cands = cands->next)
3500     if (cands->viable == 1)
3501       return true;
3502   return false;
3503 }
3504
3505 /* OBJ is being used in an expression like "OBJ.f (...)".  In other
3506    words, it is about to become the "this" pointer for a member
3507    function call.  Take the address of the object.  */
3508
3509 static tree
3510 build_this (tree obj)
3511 {
3512   /* In a template, we are only concerned about the type of the
3513      expression, so we can take a shortcut.  */
3514   if (processing_template_decl)
3515     return build_address (obj);
3516
3517   return cp_build_addr_expr (obj, tf_warning_or_error);
3518 }
3519
3520 /* Returns true iff functions are equivalent. Equivalent functions are
3521    not '==' only if one is a function-local extern function or if
3522    both are extern "C".  */
3523
3524 static inline int
3525 equal_functions (tree fn1, tree fn2)
3526 {
3527   if (TREE_CODE (fn1) != TREE_CODE (fn2))
3528     return 0;
3529   if (TREE_CODE (fn1) == TEMPLATE_DECL)
3530     return fn1 == fn2;
3531   if (DECL_LOCAL_FUNCTION_P (fn1) || DECL_LOCAL_FUNCTION_P (fn2)
3532       || DECL_EXTERN_C_FUNCTION_P (fn1))
3533     return decls_match (fn1, fn2);
3534   return fn1 == fn2;
3535 }
3536
3537 /* Print information about a candidate FN being rejected due to INFO.  */
3538
3539 static void
3540 print_conversion_rejection (location_t loc, struct conversion_info *info,
3541                             tree fn)
3542 {
3543   tree from = info->from;
3544   if (!TYPE_P (from))
3545     from = lvalue_type (from);
3546   if (info->n_arg == -1)
3547     {
3548       /* Conversion of implicit `this' argument failed.  */
3549       if (!TYPE_P (info->from))
3550         /* A bad conversion for 'this' must be discarding cv-quals.  */
3551         inform (loc, "  passing %qT as %<this%> "
3552                 "argument discards qualifiers",
3553                 from);
3554       else
3555         inform (loc, "  no known conversion for implicit "
3556                 "%<this%> parameter from %qH to %qI",
3557                 from, info->to_type);
3558     }
3559   else if (!TYPE_P (info->from))
3560     {
3561       if (info->n_arg >= 0)
3562         inform (loc, "  conversion of argument %d would be ill-formed:",
3563                 info->n_arg + 1);
3564       perform_implicit_conversion (info->to_type, info->from,
3565                                    tf_warning_or_error);
3566     }
3567   else if (info->n_arg == -2)
3568     /* Conversion of conversion function return value failed.  */
3569     inform (loc, "  no known conversion from %qH to %qI",
3570             from, info->to_type);
3571   else
3572     {
3573       if (TREE_CODE (fn) == FUNCTION_DECL)
3574         loc = get_fndecl_argument_location (fn, info->n_arg);
3575       inform (loc, "  no known conversion for argument %d from %qH to %qI",
3576               info->n_arg + 1, from, info->to_type);
3577     }
3578 }
3579
3580 /* Print information about a candidate with WANT parameters and we found
3581    HAVE.  */
3582
3583 static void
3584 print_arity_information (location_t loc, unsigned int have, unsigned int want)
3585 {
3586   inform_n (loc, want,
3587             "  candidate expects %d argument, %d provided",
3588             "  candidate expects %d arguments, %d provided",
3589             want, have);
3590 }
3591
3592 /* Print information about one overload candidate CANDIDATE.  MSGSTR
3593    is the text to print before the candidate itself.
3594
3595    NOTE: Unlike most diagnostic functions in GCC, MSGSTR is expected
3596    to have been run through gettext by the caller.  This wart makes
3597    life simpler in print_z_candidates and for the translators.  */
3598
3599 static void
3600 print_z_candidate (location_t loc, const char *msgstr,
3601                    struct z_candidate *candidate)
3602 {
3603   const char *msg = (msgstr == NULL
3604                      ? ""
3605                      : ACONCAT ((_(msgstr), " ", NULL)));
3606   tree fn = candidate->fn;
3607   if (flag_new_inheriting_ctors)
3608     fn = strip_inheriting_ctors (fn);
3609   location_t cloc = location_of (fn);
3610
3611   if (identifier_p (fn))
3612     {
3613       cloc = loc;
3614       if (candidate->num_convs == 3)
3615         inform (cloc, "%s%<%D(%T, %T, %T)%> (built-in)", msg, fn,
3616                 candidate->convs[0]->type,
3617                 candidate->convs[1]->type,
3618                 candidate->convs[2]->type);
3619       else if (candidate->num_convs == 2)
3620         inform (cloc, "%s%<%D(%T, %T)%> (built-in)", msg, fn,
3621                 candidate->convs[0]->type,
3622                 candidate->convs[1]->type);
3623       else
3624         inform (cloc, "%s%<%D(%T)%> (built-in)", msg, fn,
3625                 candidate->convs[0]->type);
3626     }
3627   else if (TYPE_P (fn))
3628     inform (cloc, "%s%qT (conversion)", msg, fn);
3629   else if (candidate->viable == -1)
3630     inform (cloc, "%s%#qD (near match)", msg, fn);
3631   else if (DECL_DELETED_FN (fn))
3632     inform (cloc, "%s%#qD (deleted)", msg, fn);
3633   else
3634     inform (cloc, "%s%#qD", msg, fn);
3635   if (fn != candidate->fn)
3636     {
3637       cloc = location_of (candidate->fn);
3638       inform (cloc, "  inherited here");
3639     }
3640   /* Give the user some information about why this candidate failed.  */
3641   if (candidate->reason != NULL)
3642     {
3643       struct rejection_reason *r = candidate->reason;
3644
3645       switch (r->code)
3646         {
3647         case rr_arity:
3648           print_arity_information (cloc, r->u.arity.actual,
3649                                    r->u.arity.expected);
3650           break;
3651         case rr_arg_conversion:
3652           print_conversion_rejection (cloc, &r->u.conversion, fn);
3653           break;
3654         case rr_bad_arg_conversion:
3655           print_conversion_rejection (cloc, &r->u.bad_conversion, fn);
3656           break;
3657         case rr_explicit_conversion:
3658           inform (cloc, "  return type %qT of explicit conversion function "
3659                   "cannot be converted to %qT with a qualification "
3660                   "conversion", r->u.conversion.from,
3661                   r->u.conversion.to_type);
3662           break;
3663         case rr_template_conversion:
3664           inform (cloc, "  conversion from return type %qT of template "
3665                   "conversion function specialization to %qT is not an "
3666                   "exact match", r->u.conversion.from,
3667                   r->u.conversion.to_type);
3668           break;
3669         case rr_template_unification:
3670           /* We use template_unification_error_rejection if unification caused
3671              actual non-SFINAE errors, in which case we don't need to repeat
3672              them here.  */
3673           if (r->u.template_unification.tmpl == NULL_TREE)
3674             {
3675               inform (cloc, "  substitution of deduced template arguments "
3676                       "resulted in errors seen above");
3677               break;
3678             }
3679           /* Re-run template unification with diagnostics.  */
3680           inform (cloc, "  template argument deduction/substitution failed:");
3681           fn_type_unification (r->u.template_unification.tmpl,
3682                                r->u.template_unification.explicit_targs,
3683                                (make_tree_vec
3684                                 (r->u.template_unification.num_targs)),
3685                                r->u.template_unification.args,
3686                                r->u.template_unification.nargs,
3687                                r->u.template_unification.return_type,
3688                                r->u.template_unification.strict,
3689                                r->u.template_unification.flags,
3690                                NULL, true, false);
3691           break;
3692         case rr_invalid_copy:
3693           inform (cloc,
3694                   "  a constructor taking a single argument of its own "
3695                   "class type is invalid");
3696           break;
3697         case rr_constraint_failure:
3698           {
3699             tree tmpl = r->u.template_instantiation.tmpl;
3700             tree args = r->u.template_instantiation.targs;
3701             diagnose_constraints (cloc, tmpl, args);
3702           }
3703           break;
3704         case rr_inherited_ctor:
3705           inform (cloc, "  an inherited constructor is not a candidate for "
3706                   "initialization from an expression of the same or derived "
3707                   "type");
3708           break;
3709         case rr_none:
3710         default:
3711           /* This candidate didn't have any issues or we failed to
3712              handle a particular code.  Either way...  */
3713           gcc_unreachable ();
3714         }
3715     }
3716 }
3717
3718 static void
3719 print_z_candidates (location_t loc, struct z_candidate *candidates)
3720 {
3721   struct z_candidate *cand1;
3722   struct z_candidate **cand2;
3723
3724   if (!candidates)
3725     return;
3726
3727   /* Remove non-viable deleted candidates.  */
3728   cand1 = candidates;
3729   for (cand2 = &cand1; *cand2; )
3730     {
3731       if (TREE_CODE ((*cand2)->fn) == FUNCTION_DECL
3732           && !(*cand2)->viable
3733           && DECL_DELETED_FN ((*cand2)->fn))
3734         *cand2 = (*cand2)->next;
3735       else
3736         cand2 = &(*cand2)->next;
3737     }
3738   /* ...if there are any non-deleted ones.  */
3739   if (cand1)
3740     candidates = cand1;
3741
3742   /* There may be duplicates in the set of candidates.  We put off
3743      checking this condition as long as possible, since we have no way
3744      to eliminate duplicates from a set of functions in less than n^2
3745      time.  Now we are about to emit an error message, so it is more
3746      permissible to go slowly.  */
3747   for (cand1 = candidates; cand1; cand1 = cand1->next)
3748     {
3749       tree fn = cand1->fn;
3750       /* Skip builtin candidates and conversion functions.  */
3751       if (!DECL_P (fn))
3752         continue;
3753       cand2 = &cand1->next;
3754       while (*cand2)
3755         {
3756           if (DECL_P ((*cand2)->fn)
3757               && equal_functions (fn, (*cand2)->fn))
3758             *cand2 = (*cand2)->next;
3759           else
3760             cand2 = &(*cand2)->next;
3761         }
3762     }
3763
3764   for (; candidates; candidates = candidates->next)
3765     print_z_candidate (loc, N_("candidate:"), candidates);
3766 }
3767
3768 /* USER_SEQ is a user-defined conversion sequence, beginning with a
3769    USER_CONV.  STD_SEQ is the standard conversion sequence applied to
3770    the result of the conversion function to convert it to the final
3771    desired type.  Merge the two sequences into a single sequence,
3772    and return the merged sequence.  */
3773
3774 static conversion *
3775 merge_conversion_sequences (conversion *user_seq, conversion *std_seq)
3776 {
3777   conversion **t;
3778   bool bad = user_seq->bad_p;
3779
3780   gcc_assert (user_seq->kind == ck_user);
3781
3782   /* Find the end of the second conversion sequence.  */
3783   for (t = &std_seq; (*t)->kind != ck_identity; t = &((*t)->u.next))
3784     {
3785       /* The entire sequence is a user-conversion sequence.  */
3786       (*t)->user_conv_p = true;
3787       if (bad)
3788         (*t)->bad_p = true;
3789     }
3790
3791   if ((*t)->rvaluedness_matches_p)
3792     /* We're binding a reference directly to the result of the conversion.
3793        build_user_type_conversion_1 stripped the REFERENCE_TYPE from the return
3794        type, but we want it back.  */
3795     user_seq->type = TREE_TYPE (TREE_TYPE (user_seq->cand->fn));
3796
3797   /* Replace the identity conversion with the user conversion
3798      sequence.  */
3799   *t = user_seq;
3800
3801   return std_seq;
3802 }
3803
3804 /* Handle overload resolution for initializing an object of class type from
3805    an initializer list.  First we look for a suitable constructor that
3806    takes a std::initializer_list; if we don't find one, we then look for a
3807    non-list constructor.
3808
3809    Parameters are as for add_candidates, except that the arguments are in
3810    the form of a CONSTRUCTOR (the initializer list) rather than a vector, and
3811    the RETURN_TYPE parameter is replaced by TOTYPE, the desired type.  */
3812
3813 static void
3814 add_list_candidates (tree fns, tree first_arg,
3815                      const vec<tree, va_gc> *args, tree totype,
3816                      tree explicit_targs, bool template_only,
3817                      tree conversion_path, tree access_path,
3818                      int flags,
3819                      struct z_candidate **candidates,
3820                      tsubst_flags_t complain)
3821 {
3822   gcc_assert (*candidates == NULL);
3823
3824   /* We're looking for a ctor for list-initialization.  */
3825   flags |= LOOKUP_LIST_INIT_CTOR;
3826   /* And we don't allow narrowing conversions.  We also use this flag to
3827      avoid the copy constructor call for copy-list-initialization.  */
3828   flags |= LOOKUP_NO_NARROWING;
3829
3830   unsigned nart = num_artificial_parms_for (OVL_FIRST (fns)) - 1;
3831   tree init_list = (*args)[nart];
3832
3833   /* Always use the default constructor if the list is empty (DR 990).  */
3834   if (CONSTRUCTOR_NELTS (init_list) == 0
3835       && TYPE_HAS_DEFAULT_CONSTRUCTOR (totype))
3836     ;
3837   /* If the class has a list ctor, try passing the list as a single
3838      argument first, but only consider list ctors.  */
3839   else if (TYPE_HAS_LIST_CTOR (totype))
3840     {
3841       flags |= LOOKUP_LIST_ONLY;
3842       add_candidates (fns, first_arg, args, NULL_TREE,
3843                       explicit_targs, template_only, conversion_path,
3844                       access_path, flags, candidates, complain);
3845       if (any_strictly_viable (*candidates))
3846         return;
3847     }
3848
3849   /* Expand the CONSTRUCTOR into a new argument vec.  */
3850   vec<tree, va_gc> *new_args;
3851   vec_alloc (new_args, nart + CONSTRUCTOR_NELTS (init_list));
3852   for (unsigned i = 0; i < nart; ++i)
3853     new_args->quick_push ((*args)[i]);
3854   for (unsigned i = 0; i < CONSTRUCTOR_NELTS (init_list); ++i)
3855     new_args->quick_push (CONSTRUCTOR_ELT (init_list, i)->value);
3856
3857   /* We aren't looking for list-ctors anymore.  */
3858   flags &= ~LOOKUP_LIST_ONLY;
3859   /* We allow more user-defined conversions within an init-list.  */
3860   flags &= ~LOOKUP_NO_CONVERSION;
3861
3862   add_candidates (fns, first_arg, new_args, NULL_TREE,
3863                   explicit_targs, template_only, conversion_path,
3864                   access_path, flags, candidates, complain);
3865 }
3866
3867 /* Returns the best overload candidate to perform the requested
3868    conversion.  This function is used for three the overloading situations
3869    described in [over.match.copy], [over.match.conv], and [over.match.ref].
3870    If TOTYPE is a REFERENCE_TYPE, we're trying to find a direct binding as
3871    per [dcl.init.ref], so we ignore temporary bindings.  */
3872
3873 static struct z_candidate *
3874 build_user_type_conversion_1 (tree totype, tree expr, int flags,
3875                               tsubst_flags_t complain)
3876 {
3877   struct z_candidate *candidates, *cand;
3878   tree fromtype;
3879   tree ctors = NULL_TREE;
3880   tree conv_fns = NULL_TREE;
3881   conversion *conv = NULL;
3882   tree first_arg = NULL_TREE;
3883   vec<tree, va_gc> *args = NULL;
3884   bool any_viable_p;
3885   int convflags;
3886
3887   if (!expr)
3888     return NULL;
3889
3890   fromtype = TREE_TYPE (expr);
3891
3892   /* We represent conversion within a hierarchy using RVALUE_CONV and
3893      BASE_CONV, as specified by [over.best.ics]; these become plain
3894      constructor calls, as specified in [dcl.init].  */
3895   gcc_assert (!MAYBE_CLASS_TYPE_P (fromtype) || !MAYBE_CLASS_TYPE_P (totype)
3896               || !DERIVED_FROM_P (totype, fromtype));
3897
3898   if (CLASS_TYPE_P (totype))
3899     /* Use lookup_fnfields_slot instead of lookup_fnfields to avoid
3900        creating a garbage BASELINK; constructors can't be inherited.  */
3901     ctors = get_class_binding (totype, complete_ctor_identifier);
3902
3903   if (MAYBE_CLASS_TYPE_P (fromtype))
3904     {
3905       tree to_nonref = non_reference (totype);
3906       if (same_type_ignoring_top_level_qualifiers_p (to_nonref, fromtype) ||
3907           (CLASS_TYPE_P (to_nonref) && CLASS_TYPE_P (fromtype)
3908            && DERIVED_FROM_P (to_nonref, fromtype)))
3909         {
3910           /* [class.conv.fct] A conversion function is never used to
3911              convert a (possibly cv-qualified) object to the (possibly
3912              cv-qualified) same object type (or a reference to it), to a
3913              (possibly cv-qualified) base class of that type (or a
3914              reference to it)...  */
3915         }
3916       else
3917         conv_fns = lookup_conversions (fromtype);
3918     }
3919
3920   candidates = 0;
3921   flags |= LOOKUP_NO_CONVERSION;
3922   if (BRACE_ENCLOSED_INITIALIZER_P (expr))
3923     flags |= LOOKUP_NO_NARROWING;
3924
3925   /* It's OK to bind a temporary for converting constructor arguments, but
3926      not in converting the return value of a conversion operator.  */
3927   convflags = ((flags & LOOKUP_NO_TEMP_BIND) | LOOKUP_NO_CONVERSION
3928                | (flags & LOOKUP_NO_NARROWING));
3929   flags &= ~LOOKUP_NO_TEMP_BIND;
3930
3931   if (ctors)
3932     {
3933       int ctorflags = flags;
3934
3935       first_arg = build_dummy_object (totype);
3936
3937       /* We should never try to call the abstract or base constructor
3938          from here.  */
3939       gcc_assert (!DECL_HAS_IN_CHARGE_PARM_P (OVL_FIRST (ctors))
3940                   && !DECL_HAS_VTT_PARM_P (OVL_FIRST (ctors)));
3941
3942       args = make_tree_vector_single (expr);
3943       if (BRACE_ENCLOSED_INITIALIZER_P (expr))
3944         {
3945           /* List-initialization.  */
3946           add_list_candidates (ctors, first_arg, args, totype, NULL_TREE,
3947                                false, TYPE_BINFO (totype), TYPE_BINFO (totype),
3948                                ctorflags, &candidates, complain);
3949         }
3950       else
3951         {
3952           add_candidates (ctors, first_arg, args, NULL_TREE, NULL_TREE, false,
3953                           TYPE_BINFO (totype), TYPE_BINFO (totype),
3954                           ctorflags, &candidates, complain);
3955         }
3956
3957       for (cand = candidates; cand; cand = cand->next)
3958         {
3959           cand->second_conv = build_identity_conv (totype, NULL_TREE);
3960
3961           /* If totype isn't a reference, and LOOKUP_NO_TEMP_BIND isn't
3962              set, then this is copy-initialization.  In that case, "The
3963              result of the call is then used to direct-initialize the
3964              object that is the destination of the copy-initialization."
3965              [dcl.init]
3966
3967              We represent this in the conversion sequence with an
3968              rvalue conversion, which means a constructor call.  */
3969           if (!TYPE_REF_P (totype)
3970               && !(convflags & LOOKUP_NO_TEMP_BIND))
3971             cand->second_conv
3972               = build_conv (ck_rvalue, totype, cand->second_conv);
3973         }
3974     }
3975
3976   if (conv_fns)
3977     {
3978       if (BRACE_ENCLOSED_INITIALIZER_P (expr))
3979         first_arg = CONSTRUCTOR_ELT (expr, 0)->value;
3980       else
3981         first_arg = expr;
3982     }
3983
3984   for (; conv_fns; conv_fns = TREE_CHAIN (conv_fns))
3985     {
3986       tree conversion_path = TREE_PURPOSE (conv_fns);
3987       struct z_candidate *old_candidates;
3988
3989       /* If we are called to convert to a reference type, we are trying to
3990          find a direct binding, so don't even consider temporaries.  If
3991          we don't find a direct binding, the caller will try again to
3992          look for a temporary binding.  */
3993       if (TYPE_REF_P (totype))
3994         convflags |= LOOKUP_NO_TEMP_BIND;
3995
3996       old_candidates = candidates;
3997       add_candidates (TREE_VALUE (conv_fns), first_arg, NULL, totype,
3998                       NULL_TREE, false,
3999                       conversion_path, TYPE_BINFO (fromtype),
4000                       flags, &candidates, complain);
4001
4002       for (cand = candidates; cand != old_candidates; cand = cand->next)
4003         {
4004           tree rettype = TREE_TYPE (TREE_TYPE (cand->fn));
4005           conversion *ics
4006             = implicit_conversion (totype,
4007                                    rettype,
4008                                    0,
4009                                    /*c_cast_p=*/false, convflags,
4010                                    complain);
4011
4012           /* If LOOKUP_NO_TEMP_BIND isn't set, then this is
4013              copy-initialization.  In that case, "The result of the
4014              call is then used to direct-initialize the object that is
4015              the destination of the copy-initialization."  [dcl.init]
4016
4017              We represent this in the conversion sequence with an
4018              rvalue conversion, which means a constructor call.  But
4019              don't add a second rvalue conversion if there's already
4020              one there.  Which there really shouldn't be, but it's
4021              harmless since we'd add it here anyway. */
4022           if (ics && MAYBE_CLASS_TYPE_P (totype) && ics->kind != ck_rvalue
4023               && !(convflags & LOOKUP_NO_TEMP_BIND))
4024             ics = build_conv (ck_rvalue, totype, ics);
4025
4026           cand->second_conv = ics;
4027
4028           if (!ics)
4029             {
4030               cand->viable = 0;
4031               cand->reason = arg_conversion_rejection (NULL_TREE, -2,
4032                                                        rettype, totype,
4033                                                        EXPR_LOCATION (expr));
4034             }
4035           else if (TYPE_REF_P (totype) && !ics->rvaluedness_matches_p
4036                    && TREE_CODE (TREE_TYPE (totype)) != FUNCTION_TYPE)
4037             {
4038               /* If we are called to convert to a reference type, we are trying
4039                  to find a direct binding per [over.match.ref], so rvaluedness
4040                  must match for non-functions.  */
4041               cand->viable = 0;
4042             }
4043           else if (DECL_NONCONVERTING_P (cand->fn)
4044                    && ics->rank > cr_exact)
4045             {
4046               /* 13.3.1.5: For direct-initialization, those explicit
4047                  conversion functions that are not hidden within S and
4048                  yield type T or a type that can be converted to type T
4049                  with a qualification conversion (4.4) are also candidate
4050                  functions.  */
4051               /* 13.3.1.6 doesn't have a parallel restriction, but it should;
4052                  I've raised this issue with the committee. --jason 9/2011 */
4053               cand->viable = -1;
4054               cand->reason = explicit_conversion_rejection (rettype, totype);
4055             }
4056           else if (cand->viable == 1 && ics->bad_p)
4057             {
4058               cand->viable = -1;
4059               cand->reason
4060                 = bad_arg_conversion_rejection (NULL_TREE, -2,
4061                                                 rettype, totype,
4062                                                 EXPR_LOCATION (expr));
4063             }
4064           else if (primary_template_specialization_p (cand->fn)
4065                    && ics->rank > cr_exact)
4066             {
4067               /* 13.3.3.1.2: If the user-defined conversion is specified by
4068                  a specialization of a conversion function template, the
4069                  second standard conversion sequence shall have exact match
4070                  rank.  */
4071               cand->viable = -1;
4072               cand->reason = template_conversion_rejection (rettype, totype);
4073             }
4074         }
4075     }
4076
4077   candidates = splice_viable (candidates, false, &any_viable_p);
4078   if (!any_viable_p)
4079     {
4080       if (args)
4081         release_tree_vector (args);
4082       return NULL;
4083     }
4084
4085   cand = tourney (candidates, complain);
4086   if (cand == NULL)
4087     {
4088       if (complain & tf_error)
4089         {
4090           auto_diagnostic_group d;
4091           error ("conversion from %qH to %qI is ambiguous",
4092                  fromtype, totype);
4093           print_z_candidates (location_of (expr), candidates);
4094         }
4095
4096       cand = candidates;        /* any one will do */
4097       cand->second_conv = build_ambiguous_conv (totype, expr);
4098       cand->second_conv->user_conv_p = true;
4099       if (!any_strictly_viable (candidates))
4100         cand->second_conv->bad_p = true;
4101       if (flags & LOOKUP_ONLYCONVERTING)
4102         cand->second_conv->need_temporary_p = true;
4103       /* If there are viable candidates, don't set ICS_BAD_FLAG; an
4104          ambiguous conversion is no worse than another user-defined
4105          conversion.  */
4106
4107       return cand;
4108     }
4109
4110   tree convtype;
4111   if (!DECL_CONSTRUCTOR_P (cand->fn))
4112     convtype = non_reference (TREE_TYPE (TREE_TYPE (cand->fn)));
4113   else if (cand->second_conv->kind == ck_rvalue)
4114     /* DR 5: [in the first step of copy-initialization]...if the function
4115        is a constructor, the call initializes a temporary of the
4116        cv-unqualified version of the destination type. */
4117     convtype = cv_unqualified (totype);
4118   else
4119     convtype = totype;
4120   /* Build the user conversion sequence.  */
4121   conv = build_conv
4122     (ck_user,
4123      convtype,
4124      build_identity_conv (TREE_TYPE (expr), expr));
4125   conv->cand = cand;
4126   if (cand->viable == -1)
4127     conv->bad_p = true;
4128
4129   /* We're performing the maybe-rvalue overload resolution and
4130      a conversion function is in play.  Reject converting the return
4131      value of the conversion function to a base class.  */
4132   if ((flags & LOOKUP_PREFER_RVALUE) && !DECL_CONSTRUCTOR_P (cand->fn))
4133     for (conversion *t = cand->second_conv; t; t = next_conversion (t))
4134       if (t->kind == ck_base)
4135         return NULL;
4136
4137   /* Remember that this was a list-initialization.  */
4138   if (flags & LOOKUP_NO_NARROWING)
4139     conv->check_narrowing = true;
4140
4141   /* Combine it with the second conversion sequence.  */
4142   cand->second_conv = merge_conversion_sequences (conv,
4143                                                   cand->second_conv);
4144
4145   return cand;
4146 }
4147
4148 /* Wrapper for above. */
4149
4150 tree
4151 build_user_type_conversion (tree totype, tree expr, int flags,
4152                             tsubst_flags_t complain)
4153 {
4154   struct z_candidate *cand;
4155   tree ret;
4156
4157   bool subtime = timevar_cond_start (TV_OVERLOAD);
4158   cand = build_user_type_conversion_1 (totype, expr, flags, complain);
4159
4160   if (cand)
4161     {
4162       if (cand->second_conv->kind == ck_ambig)
4163         ret = error_mark_node;
4164       else
4165         {
4166           expr = convert_like (cand->second_conv, expr, complain);
4167           ret = convert_from_reference (expr);
4168         }
4169     }
4170   else
4171     ret = NULL_TREE;
4172
4173   timevar_cond_stop (TV_OVERLOAD, subtime);
4174   return ret;
4175 }
4176
4177 /* Worker for build_converted_constant_expr.  */
4178
4179 static tree
4180 build_converted_constant_expr_internal (tree type, tree expr,
4181                                         int flags, tsubst_flags_t complain)
4182 {
4183   conversion *conv;
4184   void *p;
4185   tree t;
4186   location_t loc = cp_expr_loc_or_input_loc (expr);
4187
4188   if (error_operand_p (expr))
4189     return error_mark_node;
4190
4191   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
4192   p = conversion_obstack_alloc (0);
4193
4194   conv = implicit_conversion (type, TREE_TYPE (expr), expr,
4195                               /*c_cast_p=*/false, flags, complain);
4196
4197   /* A converted constant expression of type T is an expression, implicitly
4198      converted to type T, where the converted expression is a constant
4199      expression and the implicit conversion sequence contains only
4200
4201        * user-defined conversions,
4202        * lvalue-to-rvalue conversions (7.1),
4203        * array-to-pointer conversions (7.2),
4204        * function-to-pointer conversions (7.3),
4205        * qualification conversions (7.5),
4206        * integral promotions (7.6),
4207        * integral conversions (7.8) other than narrowing conversions (11.6.4),
4208        * null pointer conversions (7.11) from std::nullptr_t,
4209        * null member pointer conversions (7.12) from std::nullptr_t, and
4210        * function pointer conversions (7.13),
4211
4212      and where the reference binding (if any) binds directly.  */
4213
4214   for (conversion *c = conv;
4215        conv && c->kind != ck_identity;
4216        c = next_conversion (c))
4217     {
4218       switch (c->kind)
4219         {
4220           /* A conversion function is OK.  If it isn't constexpr, we'll
4221              complain later that the argument isn't constant.  */
4222         case ck_user:
4223           /* The lvalue-to-rvalue conversion is OK.  */
4224         case ck_rvalue:
4225           /* Array-to-pointer and function-to-pointer.  */
4226         case ck_lvalue:
4227           /* Function pointer conversions.  */
4228         case ck_fnptr:
4229           /* Qualification conversions.  */
4230         case ck_qual:
4231           break;
4232
4233         case ck_ref_bind:
4234           if (c->need_temporary_p)
4235             {
4236               if (complain & tf_error)
4237                 error_at (loc, "initializing %qH with %qI in converted "
4238                           "constant expression does not bind directly",
4239                           type, next_conversion (c)->type);
4240               conv = NULL;
4241             }
4242           break;
4243
4244         case ck_base:
4245         case ck_pmem:
4246         case ck_ptr:
4247         case ck_std:
4248           t = next_conversion (c)->type;
4249           if (INTEGRAL_OR_ENUMERATION_TYPE_P (t)
4250               && INTEGRAL_OR_ENUMERATION_TYPE_P (type))
4251             /* Integral promotion or conversion.  */
4252             break;
4253           if (NULLPTR_TYPE_P (t))
4254             /* Conversion from nullptr to pointer or pointer-to-member.  */
4255             break;
4256
4257           if (complain & tf_error)
4258             error_at (loc, "conversion from %qH to %qI in a "
4259                       "converted constant expression", t, type);
4260           /* fall through.  */
4261
4262         default:
4263           conv = NULL;
4264           break;
4265         }
4266     }
4267
4268   /* Avoid confusing convert_nontype_argument by introducing
4269      a redundant conversion to the same reference type.  */
4270   if (conv && conv->kind == ck_ref_bind
4271       && REFERENCE_REF_P (expr))
4272     {
4273       tree ref = TREE_OPERAND (expr, 0);
4274       if (same_type_p (type, TREE_TYPE (ref)))
4275         return ref;
4276     }
4277
4278   if (conv)
4279     {
4280       /* Don't copy a class in a template.  */
4281       if (CLASS_TYPE_P (type) && conv->kind == ck_rvalue
4282           && processing_template_decl)
4283         conv = next_conversion (conv);
4284
4285       conv->check_narrowing = true;
4286       conv->check_narrowing_const_only = true;
4287       expr = convert_like (conv, expr, complain);
4288     }
4289   else
4290     {
4291       if (complain & tf_error)
4292         error_at (loc, "could not convert %qE from %qH to %qI", expr,
4293                   TREE_TYPE (expr), type);
4294       expr = error_mark_node;
4295     }
4296
4297   /* Free all the conversions we allocated.  */
4298   obstack_free (&conversion_obstack, p);
4299
4300   return expr;
4301 }
4302
4303 /* Subroutine of convert_nontype_argument.
4304
4305    EXPR is an expression used in a context that requires a converted
4306    constant-expression, such as a template non-type parameter.  Do any
4307    necessary conversions (that are permitted for converted
4308    constant-expressions) to convert it to the desired type.
4309
4310    This function doesn't consider explicit conversion functions.  If
4311    you mean to use "a contextually converted constant expression of type
4312    bool", use build_converted_constant_bool_expr.
4313
4314    If conversion is successful, returns the converted expression;
4315    otherwise, returns error_mark_node.  */
4316
4317 tree
4318 build_converted_constant_expr (tree type, tree expr, tsubst_flags_t complain)
4319 {
4320   return build_converted_constant_expr_internal (type, expr, LOOKUP_IMPLICIT,
4321                                                  complain);
4322 }
4323
4324 /* Used to create "a contextually converted constant expression of type
4325    bool".  This differs from build_converted_constant_expr in that it
4326    also considers explicit conversion functions.  */
4327
4328 tree
4329 build_converted_constant_bool_expr (tree expr, tsubst_flags_t complain)
4330 {
4331   return build_converted_constant_expr_internal (boolean_type_node, expr,
4332                                                  LOOKUP_NORMAL, complain);
4333 }
4334
4335 /* Do any initial processing on the arguments to a function call.  */
4336
4337 static vec<tree, va_gc> *
4338 resolve_args (vec<tree, va_gc> *args, tsubst_flags_t complain)
4339 {
4340   unsigned int ix;
4341   tree arg;
4342
4343   FOR_EACH_VEC_SAFE_ELT (args, ix, arg)
4344     {
4345       if (error_operand_p (arg))
4346         return NULL;
4347       else if (VOID_TYPE_P (TREE_TYPE (arg)))
4348         {
4349           if (complain & tf_error)
4350             error ("invalid use of void expression");
4351           return NULL;
4352         }
4353       else if (invalid_nonstatic_memfn_p (EXPR_LOCATION (arg), arg, complain))
4354         return NULL;
4355     }
4356   return args;
4357 }
4358
4359 /* Perform overload resolution on FN, which is called with the ARGS.
4360
4361    Return the candidate function selected by overload resolution, or
4362    NULL if the event that overload resolution failed.  In the case
4363    that overload resolution fails, *CANDIDATES will be the set of
4364    candidates considered, and ANY_VIABLE_P will be set to true or
4365    false to indicate whether or not any of the candidates were
4366    viable.
4367
4368    The ARGS should already have gone through RESOLVE_ARGS before this
4369    function is called.  */
4370
4371 static struct z_candidate *
4372 perform_overload_resolution (tree fn,
4373                              const vec<tree, va_gc> *args,
4374                              struct z_candidate **candidates,
4375                              bool *any_viable_p, tsubst_flags_t complain)
4376 {
4377   struct z_candidate *cand;
4378   tree explicit_targs;
4379   int template_only;
4380
4381   bool subtime = timevar_cond_start (TV_OVERLOAD);
4382
4383   explicit_targs = NULL_TREE;
4384   template_only = 0;
4385
4386   *candidates = NULL;
4387   *any_viable_p = true;
4388
4389   /* Check FN.  */
4390   gcc_assert (OVL_P (fn) || TREE_CODE (fn) == TEMPLATE_ID_EXPR);
4391
4392   if (TREE_CODE (fn) == TEMPLATE_ID_EXPR)
4393     {
4394       explicit_targs = TREE_OPERAND (fn, 1);
4395       fn = TREE_OPERAND (fn, 0);
4396       template_only = 1;
4397     }
4398
4399   /* Add the various candidate functions.  */
4400   add_candidates (fn, NULL_TREE, args, NULL_TREE,
4401                   explicit_targs, template_only,
4402                   /*conversion_path=*/NULL_TREE,
4403                   /*access_path=*/NULL_TREE,
4404                   LOOKUP_NORMAL,
4405                   candidates, complain);
4406
4407   *candidates = splice_viable (*candidates, false, any_viable_p);
4408   if (*any_viable_p)
4409     cand = tourney (*candidates, complain);
4410   else
4411     cand = NULL;
4412
4413   timevar_cond_stop (TV_OVERLOAD, subtime);
4414   return cand;
4415 }
4416
4417 /* Print an error message about being unable to build a call to FN with
4418    ARGS.  ANY_VIABLE_P indicates whether any candidate functions could
4419    be located; CANDIDATES is a possibly empty list of such
4420    functions.  */
4421
4422 static void
4423 print_error_for_call_failure (tree fn, vec<tree, va_gc> *args,
4424                               struct z_candidate *candidates)
4425 {
4426   tree targs = NULL_TREE;
4427   if (TREE_CODE (fn) == TEMPLATE_ID_EXPR)
4428     {
4429       targs = TREE_OPERAND (fn, 1);
4430       fn = TREE_OPERAND (fn, 0);
4431     }
4432   tree name = OVL_NAME (fn);
4433   location_t loc = location_of (name);
4434   if (targs)
4435     name = lookup_template_function (name, targs);
4436
4437   auto_diagnostic_group d;
4438   if (!any_strictly_viable (candidates))
4439     error_at (loc, "no matching function for call to %<%D(%A)%>",
4440               name, build_tree_list_vec (args));
4441   else
4442     error_at (loc, "call of overloaded %<%D(%A)%> is ambiguous",
4443               name, build_tree_list_vec (args));
4444   if (candidates)
4445     print_z_candidates (loc, candidates);
4446 }
4447
4448 /* Return an expression for a call to FN (a namespace-scope function,
4449    or a static member function) with the ARGS.  This may change
4450    ARGS.  */
4451
4452 tree
4453 build_new_function_call (tree fn, vec<tree, va_gc> **args,
4454                          tsubst_flags_t complain)
4455 {
4456   struct z_candidate *candidates, *cand;
4457   bool any_viable_p;
4458   void *p;
4459   tree result;
4460
4461   if (args != NULL && *args != NULL)
4462     {
4463       *args = resolve_args (*args, complain);
4464       if (*args == NULL)
4465         return error_mark_node;
4466     }
4467
4468   if (flag_tm)
4469     tm_malloc_replacement (fn);
4470
4471   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
4472   p = conversion_obstack_alloc (0);
4473
4474   cand = perform_overload_resolution (fn, *args, &candidates, &any_viable_p,
4475                                       complain);
4476
4477   if (!cand)
4478     {
4479       if (complain & tf_error)
4480         {
4481           // If there is a single (non-viable) function candidate,
4482           // let the error be diagnosed by cp_build_function_call_vec.
4483           if (!any_viable_p && candidates && ! candidates->next
4484               && (TREE_CODE (candidates->fn) == FUNCTION_DECL))
4485             return cp_build_function_call_vec (candidates->fn, args, complain);
4486
4487           // Otherwise, emit notes for non-viable candidates.
4488           print_error_for_call_failure (fn, *args, candidates);
4489         }
4490       result = error_mark_node;
4491     }
4492   else
4493     {
4494       int flags = LOOKUP_NORMAL;
4495       /* If fn is template_id_expr, the call has explicit template arguments
4496          (e.g. func<int>(5)), communicate this info to build_over_call
4497          through flags so that later we can use it to decide whether to warn
4498          about peculiar null pointer conversion.  */
4499       if (TREE_CODE (fn) == TEMPLATE_ID_EXPR)
4500         {
4501           /* If overload resolution selects a specialization of a
4502              function concept for non-dependent template arguments,
4503              the expression is true if the constraints are satisfied
4504              and false otherwise.
4505
4506              NOTE: This is an extension of Concepts Lite TS that
4507              allows constraints to be used in expressions. */
4508           if (flag_concepts && !processing_template_decl)
4509             {
4510               tree tmpl = DECL_TI_TEMPLATE (cand->fn);
4511               tree targs = DECL_TI_ARGS (cand->fn);
4512               tree decl = DECL_TEMPLATE_RESULT (tmpl);
4513               if (DECL_DECLARED_CONCEPT_P (decl))
4514                 return evaluate_function_concept (decl, targs);
4515             }
4516
4517           flags |= LOOKUP_EXPLICIT_TMPL_ARGS;
4518         }
4519
4520       result = build_over_call (cand, flags, complain);
4521     }
4522
4523   /* Free all the conversions we allocated.  */
4524   obstack_free (&conversion_obstack, p);
4525
4526   return result;
4527 }
4528
4529 /* Build a call to a global operator new.  FNNAME is the name of the
4530    operator (either "operator new" or "operator new[]") and ARGS are
4531    the arguments provided.  This may change ARGS.  *SIZE points to the
4532    total number of bytes required by the allocation, and is updated if
4533    that is changed here.  *COOKIE_SIZE is non-NULL if a cookie should
4534    be used.  If this function determines that no cookie should be
4535    used, after all, *COOKIE_SIZE is set to NULL_TREE.  If SIZE_CHECK
4536    is not NULL_TREE, it is evaluated before calculating the final
4537    array size, and if it fails, the array size is replaced with
4538    (size_t)-1 (usually triggering a std::bad_alloc exception).  If FN
4539    is non-NULL, it will be set, upon return, to the allocation
4540    function called.  */
4541
4542 tree
4543 build_operator_new_call (tree fnname, vec<tree, va_gc> **args,
4544                          tree *size, tree *cookie_size,
4545                          tree align_arg, tree size_check,
4546                          tree *fn, tsubst_flags_t complain)
4547 {
4548   tree original_size = *size;
4549   tree fns;
4550   struct z_candidate *candidates;
4551   struct z_candidate *cand = NULL;
4552   bool any_viable_p;
4553
4554   if (fn)
4555     *fn = NULL_TREE;
4556   /* Set to (size_t)-1 if the size check fails.  */
4557   if (size_check != NULL_TREE)
4558     {
4559       tree errval = TYPE_MAX_VALUE (sizetype);
4560       if (cxx_dialect >= cxx11 && flag_exceptions)
4561         errval = throw_bad_array_new_length ();
4562       *size = fold_build3 (COND_EXPR, sizetype, size_check,
4563                            original_size, errval);
4564     }
4565   vec_safe_insert (*args, 0, *size);
4566   *args = resolve_args (*args, complain);
4567   if (*args == NULL)
4568     return error_mark_node;
4569
4570   /* Based on:
4571
4572        [expr.new]
4573
4574        If this lookup fails to find the name, or if the allocated type
4575        is not a class type, the allocation function's name is looked
4576        up in the global scope.
4577
4578      we disregard block-scope declarations of "operator new".  */
4579   fns = lookup_name_real (fnname, 0, 1, /*block_p=*/false, 0, 0);
4580   fns = lookup_arg_dependent (fnname, fns, *args);
4581
4582   if (align_arg)
4583     {
4584       vec<tree, va_gc>* align_args
4585         = vec_copy_and_insert (*args, align_arg, 1);
4586       cand = perform_overload_resolution (fns, align_args, &candidates,
4587                                           &any_viable_p, tf_none);
4588       if (cand)
4589         *args = align_args;
4590       /* If no aligned allocation function matches, try again without the
4591          alignment.  */
4592     }
4593
4594   /* Figure out what function is being called.  */
4595   if (!cand)
4596     cand = perform_overload_resolution (fns, *args, &candidates, &any_viable_p,
4597                                         complain);
4598
4599   /* If no suitable function could be found, issue an error message
4600      and give up.  */
4601   if (!cand)
4602     {
4603       if (complain & tf_error)
4604         print_error_for_call_failure (fns, *args, candidates);
4605       return error_mark_node;
4606     }
4607
4608    /* If a cookie is required, add some extra space.  Whether
4609       or not a cookie is required cannot be determined until
4610       after we know which function was called.  */
4611    if (*cookie_size)
4612      {
4613        bool use_cookie = true;
4614        tree arg_types;
4615
4616        arg_types = TYPE_ARG_TYPES (TREE_TYPE (cand->fn));
4617        /* Skip the size_t parameter.  */
4618        arg_types = TREE_CHAIN (arg_types);
4619        /* Check the remaining parameters (if any).  */
4620        if (arg_types
4621            && TREE_CHAIN (arg_types) == void_list_node
4622            && same_type_p (TREE_VALUE (arg_types),
4623                            ptr_type_node))
4624          use_cookie = false;
4625        /* If we need a cookie, adjust the number of bytes allocated.  */
4626        if (use_cookie)
4627          {
4628            /* Update the total size.  */
4629            *size = size_binop (PLUS_EXPR, original_size, *cookie_size);
4630            if (size_check)
4631              {
4632                /* Set to (size_t)-1 if the size check fails.  */
4633                gcc_assert (size_check != NULL_TREE);
4634                *size = fold_build3 (COND_EXPR, sizetype, size_check,
4635                                     *size, TYPE_MAX_VALUE (sizetype));
4636             }
4637            /* Update the argument list to reflect the adjusted size.  */
4638            (**args)[0] = *size;
4639          }
4640        else
4641          *cookie_size = NULL_TREE;
4642      }
4643
4644    /* Tell our caller which function we decided to call.  */
4645    if (fn)
4646      *fn = cand->fn;
4647
4648    /* Build the CALL_EXPR.  */
4649    return build_over_call (cand, LOOKUP_NORMAL, complain);
4650 }
4651
4652 /* Build a new call to operator().  This may change ARGS.  */
4653
4654 static tree
4655 build_op_call_1 (tree obj, vec<tree, va_gc> **args, tsubst_flags_t complain)
4656 {
4657   struct z_candidate *candidates = 0, *cand;
4658   tree fns, convs, first_mem_arg = NULL_TREE;
4659   bool any_viable_p;
4660   tree result = NULL_TREE;
4661   void *p;
4662
4663   obj = mark_lvalue_use (obj);
4664
4665   if (error_operand_p (obj))
4666     return error_mark_node;
4667
4668   tree type = TREE_TYPE (obj);
4669
4670   obj = prep_operand (obj);
4671
4672   if (TYPE_PTRMEMFUNC_P (type))
4673     {
4674       if (complain & tf_error)
4675         /* It's no good looking for an overloaded operator() on a
4676            pointer-to-member-function.  */
4677         error ("pointer-to-member function %qE cannot be called without "
4678                "an object; consider using %<.*%> or %<->*%>", obj);
4679       return error_mark_node;
4680     }
4681
4682   if (TYPE_BINFO (type))
4683     {
4684       fns = lookup_fnfields (TYPE_BINFO (type), call_op_identifier, 1);
4685       if (fns == error_mark_node)
4686         return error_mark_node;
4687     }
4688   else
4689     fns = NULL_TREE;
4690
4691   if (args != NULL && *args != NULL)
4692     {
4693       *args = resolve_args (*args, complain);
4694       if (*args == NULL)
4695         return error_mark_node;
4696     }
4697
4698   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
4699   p = conversion_obstack_alloc (0);
4700
4701   if (fns)
4702     {
4703       first_mem_arg = obj;
4704
4705       add_candidates (BASELINK_FUNCTIONS (fns),
4706                       first_mem_arg, *args, NULL_TREE,
4707                       NULL_TREE, false,
4708                       BASELINK_BINFO (fns), BASELINK_ACCESS_BINFO (fns),
4709                       LOOKUP_NORMAL, &candidates, complain);
4710     }
4711
4712   convs = lookup_conversions (type);
4713
4714   for (; convs; convs = TREE_CHAIN (convs))
4715     {
4716       tree totype = TREE_TYPE (convs);
4717
4718       if (TYPE_PTRFN_P (totype)
4719           || TYPE_REFFN_P (totype)
4720           || (TYPE_REF_P (totype)
4721               && TYPE_PTRFN_P (TREE_TYPE (totype))))
4722         for (ovl_iterator iter (TREE_VALUE (convs)); iter; ++iter)
4723           {
4724             tree fn = *iter;
4725
4726             if (DECL_NONCONVERTING_P (fn))
4727               continue;
4728
4729             if (TREE_CODE (fn) == TEMPLATE_DECL)
4730               add_template_conv_candidate
4731                 (&candidates, fn, obj, *args, totype,
4732                  /*access_path=*/NULL_TREE,
4733                  /*conversion_path=*/NULL_TREE, complain);
4734             else
4735               add_conv_candidate (&candidates, fn, obj,
4736                                   *args, /*conversion_path=*/NULL_TREE,
4737                                   /*access_path=*/NULL_TREE, complain);
4738           }
4739     }
4740
4741   /* Be strict here because if we choose a bad conversion candidate, the
4742      errors we get won't mention the call context.  */
4743   candidates = splice_viable (candidates, true, &any_viable_p);
4744   if (!any_viable_p)
4745     {
4746       if (complain & tf_error)
4747         {
4748           auto_diagnostic_group d;
4749           error ("no match for call to %<(%T) (%A)%>", TREE_TYPE (obj),
4750                  build_tree_list_vec (*args));
4751           print_z_candidates (location_of (TREE_TYPE (obj)), candidates);
4752         }
4753       result = error_mark_node;
4754     }
4755   else
4756     {
4757       cand = tourney (candidates, complain);
4758       if (cand == 0)
4759         {
4760           if (complain & tf_error)
4761             {
4762               auto_diagnostic_group d;
4763               error ("call of %<(%T) (%A)%> is ambiguous", 
4764                      TREE_TYPE (obj), build_tree_list_vec (*args));
4765               print_z_candidates (location_of (TREE_TYPE (obj)), candidates);
4766             }
4767           result = error_mark_node;
4768         }
4769       else if (TREE_CODE (cand->fn) == FUNCTION_DECL
4770                && DECL_OVERLOADED_OPERATOR_P (cand->fn)
4771                && DECL_OVERLOADED_OPERATOR_IS (cand->fn, CALL_EXPR))
4772         result = build_over_call (cand, LOOKUP_NORMAL, complain);
4773       else
4774         {
4775           if (TREE_CODE (cand->fn) == FUNCTION_DECL)
4776             obj = convert_like_with_context (cand->convs[0], obj, cand->fn,
4777                                              -1, complain);
4778           else
4779             {
4780               gcc_checking_assert (TYPE_P (cand->fn));
4781               obj = convert_like (cand->convs[0], obj, complain);
4782             }
4783           obj = convert_from_reference (obj);
4784           result = cp_build_function_call_vec (obj, args, complain);
4785         }
4786     }
4787
4788   /* Free all the conversions we allocated.  */
4789   obstack_free (&conversion_obstack, p);
4790
4791   return result;
4792 }
4793
4794 /* Wrapper for above.  */
4795
4796 tree
4797 build_op_call (tree obj, vec<tree, va_gc> **args, tsubst_flags_t complain)
4798 {
4799   tree ret;
4800   bool subtime = timevar_cond_start (TV_OVERLOAD);
4801   ret = build_op_call_1 (obj, args, complain);
4802   timevar_cond_stop (TV_OVERLOAD, subtime);
4803   return ret;
4804 }
4805
4806 /* Called by op_error to prepare format strings suitable for the error
4807    function.  It concatenates a prefix (controlled by MATCH), ERRMSG,
4808    and a suffix (controlled by NTYPES).  */
4809
4810 static const char *
4811 op_error_string (const char *errmsg, int ntypes, bool match)
4812 {
4813   const char *msg;
4814
4815   const char *msgp = concat (match ? G_("ambiguous overload for ")
4816                                    : G_("no match for "), errmsg, NULL);
4817
4818   if (ntypes == 3)
4819     msg = concat (msgp, G_(" (operand types are %qT, %qT, and %qT)"), NULL);
4820   else if (ntypes == 2)
4821     msg = concat (msgp, G_(" (operand types are %qT and %qT)"), NULL);
4822   else
4823     msg = concat (msgp, G_(" (operand type is %qT)"), NULL);
4824
4825   return msg;
4826 }
4827
4828 static void
4829 op_error (const op_location_t &loc,
4830           enum tree_code code, enum tree_code code2,
4831           tree arg1, tree arg2, tree arg3, bool match)
4832 {
4833   bool assop = code == MODIFY_EXPR;
4834   const char *opname = OVL_OP_INFO (assop, assop ? code2 : code)->name;
4835
4836   switch (code)
4837     {
4838     case COND_EXPR:
4839       if (flag_diagnostics_show_caret)
4840         error_at (loc, op_error_string (G_("ternary %<operator?:%>"),
4841                                         3, match),
4842                   TREE_TYPE (arg1), TREE_TYPE (arg2), TREE_TYPE (arg3));
4843       else
4844         error_at (loc, op_error_string (G_("ternary %<operator?:%> "
4845                                            "in %<%E ? %E : %E%>"), 3, match),
4846                   arg1, arg2, arg3,
4847                   TREE_TYPE (arg1), TREE_TYPE (arg2), TREE_TYPE (arg3));
4848       break;
4849
4850     case POSTINCREMENT_EXPR:
4851     case POSTDECREMENT_EXPR:
4852       if (flag_diagnostics_show_caret)
4853         error_at (loc, op_error_string (G_("%<operator%s%>"), 1, match),
4854                   opname, TREE_TYPE (arg1));
4855       else
4856         error_at (loc, op_error_string (G_("%<operator%s%> in %<%E%s%>"),
4857                                         1, match),
4858                   opname, arg1, opname, TREE_TYPE (arg1));
4859       break;
4860
4861     case ARRAY_REF:
4862       if (flag_diagnostics_show_caret)
4863         error_at (loc, op_error_string (G_("%<operator[]%>"), 2, match),
4864                   TREE_TYPE (arg1), TREE_TYPE (arg2));
4865       else
4866         error_at (loc, op_error_string (G_("%<operator[]%> in %<%E[%E]%>"),
4867                                         2, match),
4868                   arg1, arg2, TREE_TYPE (arg1), TREE_TYPE (arg2));
4869       break;
4870
4871     case REALPART_EXPR:
4872     case IMAGPART_EXPR:
4873       if (flag_diagnostics_show_caret)
4874         error_at (loc, op_error_string (G_("%qs"), 1, match),
4875                   opname, TREE_TYPE (arg1));
4876       else
4877         error_at (loc, op_error_string (G_("%qs in %<%s %E%>"), 1, match),
4878                   opname, opname, arg1, TREE_TYPE (arg1));
4879       break;
4880
4881     default:
4882       if (arg2)
4883         if (flag_diagnostics_show_caret)
4884           {
4885             binary_op_rich_location richloc (loc, arg1, arg2, true);
4886             error_at (&richloc,
4887                       op_error_string (G_("%<operator%s%>"), 2, match),
4888                       opname, TREE_TYPE (arg1), TREE_TYPE (arg2));
4889           }
4890         else
4891           error_at (loc, op_error_string (G_("%<operator%s%> in %<%E %s %E%>"),
4892                                           2, match),
4893                     opname, arg1, opname, arg2,
4894                     TREE_TYPE (arg1), TREE_TYPE (arg2));
4895       else
4896         if (flag_diagnostics_show_caret)
4897           error_at (loc, op_error_string (G_("%<operator%s%>"), 1, match),
4898                     opname, TREE_TYPE (arg1));
4899         else
4900           error_at (loc, op_error_string (G_("%<operator%s%> in %<%s%E%>"),
4901                                           1, match),
4902                     opname, opname, arg1, TREE_TYPE (arg1));
4903       break;
4904     }
4905 }
4906
4907 /* Return the implicit conversion sequence that could be used to
4908    convert E1 to E2 in [expr.cond].  */
4909
4910 static conversion *
4911 conditional_conversion (tree e1, tree e2, tsubst_flags_t complain)
4912 {
4913   tree t1 = non_reference (TREE_TYPE (e1));
4914   tree t2 = non_reference (TREE_TYPE (e2));
4915   conversion *conv;
4916   bool good_base;
4917
4918   /* [expr.cond]
4919
4920      If E2 is an lvalue: E1 can be converted to match E2 if E1 can be
4921      implicitly converted (clause _conv_) to the type "lvalue reference to
4922      T2", subject to the constraint that in the conversion the
4923      reference must bind directly (_dcl.init.ref_) to an lvalue.
4924
4925      If E2 is an xvalue: E1 can be converted to match E2 if E1 can be
4926      implicitly converted to the type "rvalue reference to T2", subject to
4927      the constraint that the reference must bind directly.  */
4928   if (glvalue_p (e2))
4929     {
4930       tree rtype = cp_build_reference_type (t2, !lvalue_p (e2));
4931       conv = implicit_conversion (rtype,
4932                                   t1,
4933                                   e1,
4934                                   /*c_cast_p=*/false,
4935                                   LOOKUP_NO_TEMP_BIND|LOOKUP_NO_RVAL_BIND
4936                                   |LOOKUP_ONLYCONVERTING,
4937                                   complain);
4938       if (conv && !conv->bad_p)
4939         return conv;
4940     }
4941
4942   /* If E2 is a prvalue or if neither of the conversions above can be done
4943      and at least one of the operands has (possibly cv-qualified) class
4944      type: */
4945   if (!CLASS_TYPE_P (t1) && !CLASS_TYPE_P (t2))
4946     return NULL;
4947
4948   /* [expr.cond]
4949
4950      If E1 and E2 have class type, and the underlying class types are
4951      the same or one is a base class of the other: E1 can be converted
4952      to match E2 if the class of T2 is the same type as, or a base
4953      class of, the class of T1, and the cv-qualification of T2 is the
4954      same cv-qualification as, or a greater cv-qualification than, the
4955      cv-qualification of T1.  If the conversion is applied, E1 is
4956      changed to an rvalue of type T2 that still refers to the original
4957      source class object (or the appropriate subobject thereof).  */
4958   if (CLASS_TYPE_P (t1) && CLASS_TYPE_P (t2)
4959       && ((good_base = DERIVED_FROM_P (t2, t1)) || DERIVED_FROM_P (t1, t2)))
4960     {
4961       if (good_base && at_least_as_qualified_p (t2, t1))
4962         {
4963           conv = build_identity_conv (t1, e1);
4964           if (!same_type_p (TYPE_MAIN_VARIANT (t1),
4965                             TYPE_MAIN_VARIANT (t2)))
4966             conv = build_conv (ck_base, t2, conv);
4967           else
4968             conv = build_conv (ck_rvalue, t2, conv);
4969           return conv;
4970         }
4971       else
4972         return NULL;
4973     }
4974   else
4975     /* [expr.cond]
4976
4977        Otherwise: E1 can be converted to match E2 if E1 can be implicitly
4978        converted to the type that expression E2 would have if E2 were
4979        converted to an rvalue (or the type it has, if E2 is an rvalue).  */
4980     return implicit_conversion (t2, t1, e1, /*c_cast_p=*/false,
4981                                 LOOKUP_IMPLICIT, complain);
4982 }
4983
4984 /* Implement [expr.cond].  ARG1, ARG2, and ARG3 are the three
4985    arguments to the conditional expression.  */
4986
4987 static tree
4988 build_conditional_expr_1 (const op_location_t &loc,
4989                           tree arg1, tree arg2, tree arg3,
4990                           tsubst_flags_t complain)
4991 {
4992   tree arg2_type;
4993   tree arg3_type;
4994   tree result = NULL_TREE;
4995   tree result_type = NULL_TREE;
4996   bool is_glvalue = true;
4997   struct z_candidate *candidates = 0;
4998   struct z_candidate *cand;
4999   void *p;
5000   tree orig_arg2, orig_arg3;
5001
5002   /* As a G++ extension, the second argument to the conditional can be
5003      omitted.  (So that `a ? : c' is roughly equivalent to `a ? a :
5004      c'.)  If the second operand is omitted, make sure it is
5005      calculated only once.  */
5006   if (!arg2)
5007     {
5008       if (complain & tf_error)
5009         pedwarn (loc, OPT_Wpedantic,
5010                  "ISO C++ forbids omitting the middle term of "
5011                  "a %<?:%> expression");
5012
5013       if ((complain & tf_warning) && !truth_value_p (TREE_CODE (arg1)))
5014         warn_for_omitted_condop (loc, arg1);
5015
5016       /* Make sure that lvalues remain lvalues.  See g++.oliva/ext1.C.  */
5017       if (lvalue_p (arg1))
5018         arg2 = arg1 = cp_stabilize_reference (arg1);
5019       else
5020         arg2 = arg1 = cp_save_expr (arg1);
5021     }
5022
5023   /* If something has already gone wrong, just pass that fact up the
5024      tree.  */
5025   if (error_operand_p (arg1)
5026       || error_operand_p (arg2)
5027       || error_operand_p (arg3))
5028     return error_mark_node;
5029
5030   orig_arg2 = arg2;
5031   orig_arg3 = arg3;
5032
5033   if (VECTOR_INTEGER_TYPE_P (TREE_TYPE (arg1)))
5034     {
5035       tree arg1_type = TREE_TYPE (arg1);
5036
5037       /* If arg1 is another cond_expr choosing between -1 and 0,
5038          then we can use its comparison.  It may help to avoid
5039          additional comparison, produce more accurate diagnostics
5040          and enables folding.  */
5041       if (TREE_CODE (arg1) == VEC_COND_EXPR
5042           && integer_minus_onep (TREE_OPERAND (arg1, 1))
5043           && integer_zerop (TREE_OPERAND (arg1, 2)))
5044         arg1 = TREE_OPERAND (arg1, 0);
5045
5046       arg1 = force_rvalue (arg1, complain);
5047       arg2 = force_rvalue (arg2, complain);
5048       arg3 = force_rvalue (arg3, complain);
5049
5050       /* force_rvalue can return error_mark on valid arguments.  */
5051       if (error_operand_p (arg1)
5052           || error_operand_p (arg2)
5053           || error_operand_p (arg3))
5054         return error_mark_node;
5055
5056       arg2_type = TREE_TYPE (arg2);
5057       arg3_type = TREE_TYPE (arg3);
5058
5059       if (!VECTOR_TYPE_P (arg2_type)
5060           && !VECTOR_TYPE_P (arg3_type))
5061         {
5062           /* Rely on the error messages of the scalar version.  */
5063           tree scal = build_conditional_expr_1 (loc, integer_one_node,
5064                                                 orig_arg2, orig_arg3, complain);
5065           if (scal == error_mark_node)
5066             return error_mark_node;
5067           tree stype = TREE_TYPE (scal);
5068           tree ctype = TREE_TYPE (arg1_type);
5069           if (TYPE_SIZE (stype) != TYPE_SIZE (ctype)
5070               || (!INTEGRAL_TYPE_P (stype) && !SCALAR_FLOAT_TYPE_P (stype)))
5071             {
5072               if (complain & tf_error)
5073                 error_at (loc, "inferred scalar type %qT is not an integer or "
5074                           "floating-point type of the same size as %qT", stype,
5075                           COMPARISON_CLASS_P (arg1)
5076                           ? TREE_TYPE (TREE_TYPE (TREE_OPERAND (arg1, 0)))
5077                           : ctype);
5078               return error_mark_node;
5079             }
5080
5081           tree vtype = build_opaque_vector_type (stype,
5082                          TYPE_VECTOR_SUBPARTS (arg1_type));
5083           /* We could pass complain & tf_warning to unsafe_conversion_p,
5084              but the warnings (like Wsign-conversion) have already been
5085              given by the scalar build_conditional_expr_1. We still check
5086              unsafe_conversion_p to forbid truncating long long -> float.  */
5087           if (unsafe_conversion_p (loc, stype, arg2, NULL_TREE, false))
5088             {
5089               if (complain & tf_error)
5090                 error_at (loc, "conversion of scalar %qH to vector %qI "
5091                                "involves truncation", arg2_type, vtype);
5092               return error_mark_node;
5093             }
5094           if (unsafe_conversion_p (loc, stype, arg3, NULL_TREE, false))
5095             {
5096               if (complain & tf_error)
5097                 error_at (loc, "conversion of scalar %qH to vector %qI "
5098                                "involves truncation", arg3_type, vtype);
5099               return error_mark_node;
5100             }
5101
5102           arg2 = cp_convert (stype, arg2, complain);
5103           arg2 = save_expr (arg2);
5104           arg2 = build_vector_from_val (vtype, arg2);
5105           arg2_type = vtype;
5106           arg3 = cp_convert (stype, arg3, complain);
5107           arg3 = save_expr (arg3);
5108           arg3 = build_vector_from_val (vtype, arg3);
5109           arg3_type = vtype;
5110         }
5111
5112       if (VECTOR_TYPE_P (arg2_type) != VECTOR_TYPE_P (arg3_type))
5113         {
5114           enum stv_conv convert_flag =
5115             scalar_to_vector (loc, VEC_COND_EXPR, arg2, arg3,
5116                               complain & tf_error);
5117
5118           switch (convert_flag)
5119             {
5120               case stv_error:
5121                 return error_mark_node;
5122               case stv_firstarg:
5123                 {
5124                   arg2 = save_expr (arg2);
5125                   arg2 = convert (TREE_TYPE (arg3_type), arg2);
5126                   arg2 = build_vector_from_val (arg3_type, arg2);
5127                   arg2_type = TREE_TYPE (arg2);
5128                   break;
5129                 }
5130               case stv_secondarg:
5131                 {
5132                   arg3 = save_expr (arg3);
5133                   arg3 = convert (TREE_TYPE (arg2_type), arg3);
5134                   arg3 = build_vector_from_val (arg2_type, arg3);
5135                   arg3_type = TREE_TYPE (arg3);
5136                   break;
5137                 }
5138               default:
5139                 break;
5140             }
5141         }
5142
5143       if (!same_type_p (arg2_type, arg3_type)
5144           || maybe_ne (TYPE_VECTOR_SUBPARTS (arg1_type),
5145                        TYPE_VECTOR_SUBPARTS (arg2_type))
5146           || TYPE_SIZE (arg1_type) != TYPE_SIZE (arg2_type))
5147         {
5148           if (complain & tf_error)
5149             error_at (loc,
5150                       "incompatible vector types in conditional expression: "
5151                       "%qT, %qT and %qT", TREE_TYPE (arg1),
5152                       TREE_TYPE (orig_arg2), TREE_TYPE (orig_arg3));
5153           return error_mark_node;
5154         }
5155
5156       if (!COMPARISON_CLASS_P (arg1))
5157         {
5158           tree cmp_type = build_same_sized_truth_vector_type (arg1_type);
5159           arg1 = build2 (NE_EXPR, cmp_type, arg1, build_zero_cst (arg1_type));
5160         }
5161       return build3_loc (loc, VEC_COND_EXPR, arg2_type, arg1, arg2, arg3);
5162     }
5163
5164   /* [expr.cond]
5165
5166      The first expression is implicitly converted to bool (clause
5167      _conv_).  */
5168   arg1 = perform_implicit_conversion_flags (boolean_type_node, arg1, complain,
5169                                             LOOKUP_NORMAL);
5170   if (error_operand_p (arg1))
5171     return error_mark_node;
5172
5173   /* [expr.cond]
5174
5175      If either the second or the third operand has type (possibly
5176      cv-qualified) void, then the lvalue-to-rvalue (_conv.lval_),
5177      array-to-pointer (_conv.array_), and function-to-pointer
5178      (_conv.func_) standard conversions are performed on the second
5179      and third operands.  */
5180   arg2_type = unlowered_expr_type (arg2);
5181   arg3_type = unlowered_expr_type (arg3);
5182   if (VOID_TYPE_P (arg2_type) || VOID_TYPE_P (arg3_type))
5183     {
5184       /* 'void' won't help in resolving an overloaded expression on the
5185          other side, so require it to resolve by itself.  */
5186       if (arg2_type == unknown_type_node)
5187         {
5188           arg2 = resolve_nondeduced_context_or_error (arg2, complain);
5189           arg2_type = TREE_TYPE (arg2);
5190         }
5191       if (arg3_type == unknown_type_node)
5192         {
5193           arg3 = resolve_nondeduced_context_or_error (arg3, complain);
5194           arg3_type = TREE_TYPE (arg3);
5195         }
5196
5197       /* [expr.cond]
5198
5199          One of the following shall hold:
5200
5201          --The second or the third operand (but not both) is a
5202            throw-expression (_except.throw_); the result is of the type
5203            and value category of the other.
5204
5205          --Both the second and the third operands have type void; the
5206            result is of type void and is a prvalue.  */
5207       if (TREE_CODE (arg2) == THROW_EXPR
5208           && TREE_CODE (arg3) != THROW_EXPR)
5209         {
5210           result_type = arg3_type;
5211           is_glvalue = glvalue_p (arg3);
5212         }
5213       else if (TREE_CODE (arg2) != THROW_EXPR
5214                && TREE_CODE (arg3) == THROW_EXPR)
5215         {
5216           result_type = arg2_type;
5217           is_glvalue = glvalue_p (arg2);
5218         }
5219       else if (VOID_TYPE_P (arg2_type) && VOID_TYPE_P (arg3_type))
5220         {
5221           result_type = void_type_node;
5222           is_glvalue = false;
5223         }
5224       else
5225         {
5226           if (complain & tf_error)
5227             {
5228               if (VOID_TYPE_P (arg2_type))
5229                 error_at (cp_expr_loc_or_loc (arg3, loc),
5230                           "second operand to the conditional operator "
5231                           "is of type %<void%>, but the third operand is "
5232                           "neither a throw-expression nor of type %<void%>");
5233               else
5234                 error_at (cp_expr_loc_or_loc (arg2, loc),
5235                           "third operand to the conditional operator "
5236                           "is of type %<void%>, but the second operand is "
5237                           "neither a throw-expression nor of type %<void%>");
5238             }
5239           return error_mark_node;
5240         }
5241
5242       goto valid_operands;
5243     }
5244   /* [expr.cond]
5245
5246      Otherwise, if the second and third operand have different types,
5247      and either has (possibly cv-qualified) class type, or if both are
5248      glvalues of the same value category and the same type except for
5249      cv-qualification, an attempt is made to convert each of those operands
5250      to the type of the other.  */
5251   else if (!same_type_p (arg2_type, arg3_type)
5252             && (CLASS_TYPE_P (arg2_type) || CLASS_TYPE_P (arg3_type)
5253                 || (same_type_ignoring_top_level_qualifiers_p (arg2_type,
5254                                                                arg3_type)
5255                     && glvalue_p (arg2) && glvalue_p (arg3)
5256                     && lvalue_p (arg2) == lvalue_p (arg3))))
5257     {
5258       conversion *conv2;
5259       conversion *conv3;
5260       bool converted = false;
5261
5262       /* Get the high-water mark for the CONVERSION_OBSTACK.  */
5263       p = conversion_obstack_alloc (0);
5264
5265       conv2 = conditional_conversion (arg2, arg3, complain);
5266       conv3 = conditional_conversion (arg3, arg2, complain);
5267
5268       /* [expr.cond]
5269
5270          If both can be converted, or one can be converted but the
5271          conversion is ambiguous, the program is ill-formed.  If
5272          neither can be converted, the operands are left unchanged and
5273          further checking is performed as described below.  If exactly
5274          one conversion is possible, that conversion is applied to the
5275          chosen operand and the converted operand is used in place of
5276          the original operand for the remainder of this section.  */
5277       if ((conv2 && !conv2->bad_p
5278            && conv3 && !conv3->bad_p)
5279           || (conv2 && conv2->kind == ck_ambig)
5280           || (conv3 && conv3->kind == ck_ambig))
5281         {
5282           if (complain & tf_error)
5283             {
5284               error_at (loc, "operands to %<?:%> have different types "
5285                         "%qT and %qT",
5286                         arg2_type, arg3_type);
5287               if (conv2 && !conv2->bad_p && conv3 && !conv3->bad_p)
5288                 inform (loc, "  and each type can be converted to the other");
5289               else if (conv2 && conv2->kind == ck_ambig)
5290                 convert_like (conv2, arg2, complain);
5291               else
5292                 convert_like (conv3, arg3, complain);
5293             }
5294           result = error_mark_node;
5295         }
5296       else if (conv2 && !conv2->bad_p)
5297         {
5298           arg2 = convert_like (conv2, arg2, complain);
5299           arg2 = convert_from_reference (arg2);
5300           arg2_type = TREE_TYPE (arg2);
5301           /* Even if CONV2 is a valid conversion, the result of the
5302              conversion may be invalid.  For example, if ARG3 has type
5303              "volatile X", and X does not have a copy constructor
5304              accepting a "volatile X&", then even if ARG2 can be
5305              converted to X, the conversion will fail.  */
5306           if (error_operand_p (arg2))
5307             result = error_mark_node;
5308           converted = true;
5309         }
5310       else if (conv3 && !conv3->bad_p)
5311         {
5312           arg3 = convert_like (conv3, arg3, complain);
5313           arg3 = convert_from_reference (arg3);
5314           arg3_type = TREE_TYPE (arg3);
5315           if (error_operand_p (arg3))
5316             result = error_mark_node;
5317           converted = true;
5318         }
5319
5320       /* Free all the conversions we allocated.  */
5321       obstack_free (&conversion_obstack, p);
5322
5323       if (result)
5324         return result;
5325
5326       /* If, after the conversion, both operands have class type,
5327          treat the cv-qualification of both operands as if it were the
5328          union of the cv-qualification of the operands.
5329
5330          The standard is not clear about what to do in this
5331          circumstance.  For example, if the first operand has type
5332          "const X" and the second operand has a user-defined
5333          conversion to "volatile X", what is the type of the second
5334          operand after this step?  Making it be "const X" (matching
5335          the first operand) seems wrong, as that discards the
5336          qualification without actually performing a copy.  Leaving it
5337          as "volatile X" seems wrong as that will result in the
5338          conditional expression failing altogether, even though,
5339          according to this step, the one operand could be converted to
5340          the type of the other.  */
5341       if (converted
5342           && CLASS_TYPE_P (arg2_type)
5343           && cp_type_quals (arg2_type) != cp_type_quals (arg3_type))
5344         arg2_type = arg3_type =
5345           cp_build_qualified_type (arg2_type,
5346                                    cp_type_quals (arg2_type)
5347                                    | cp_type_quals (arg3_type));
5348     }
5349
5350   /* [expr.cond]
5351
5352      If the second and third operands are glvalues of the same value
5353      category and have the same type, the result is of that type and
5354      value category.  */
5355   if (((lvalue_p (arg2) && lvalue_p (arg3))
5356        || (xvalue_p (arg2) && xvalue_p (arg3)))
5357       && same_type_p (arg2_type, arg3_type))
5358     {
5359       result_type = arg2_type;
5360       arg2 = mark_lvalue_use (arg2);
5361       arg3 = mark_lvalue_use (arg3);
5362       goto valid_operands;
5363     }
5364
5365   /* [expr.cond]
5366
5367      Otherwise, the result is an rvalue.  If the second and third
5368      operand do not have the same type, and either has (possibly
5369      cv-qualified) class type, overload resolution is used to
5370      determine the conversions (if any) to be applied to the operands
5371      (_over.match.oper_, _over.built_).  */
5372   is_glvalue = false;
5373   if (!same_type_p (arg2_type, arg3_type)
5374       && (CLASS_TYPE_P (arg2_type) || CLASS_TYPE_P (arg3_type)))
5375     {
5376       tree args[3];
5377       conversion *conv;
5378       bool any_viable_p;
5379
5380       /* Rearrange the arguments so that add_builtin_candidate only has
5381          to know about two args.  In build_builtin_candidate, the
5382          arguments are unscrambled.  */
5383       args[0] = arg2;
5384       args[1] = arg3;
5385       args[2] = arg1;
5386       add_builtin_candidates (&candidates,
5387                               COND_EXPR,
5388                               NOP_EXPR,
5389                               ovl_op_identifier (false, COND_EXPR),
5390                               args,
5391                               LOOKUP_NORMAL, complain);
5392
5393       /* [expr.cond]
5394
5395          If the overload resolution fails, the program is
5396          ill-formed.  */
5397       candidates = splice_viable (candidates, false, &any_viable_p);
5398       if (!any_viable_p)
5399         {
5400           if (complain & tf_error)
5401             error_at (loc, "operands to %<?:%> have different types %qT and %qT",
5402                       arg2_type, arg3_type);
5403           return error_mark_node;
5404         }
5405       cand = tourney (candidates, complain);
5406       if (!cand)
5407         {
5408           if (complain & tf_error)
5409             {
5410               auto_diagnostic_group d;
5411               op_error (loc, COND_EXPR, NOP_EXPR, arg1, arg2, arg3, FALSE);
5412               print_z_candidates (loc, candidates);
5413             }
5414           return error_mark_node;
5415         }
5416
5417       /* [expr.cond]
5418
5419          Otherwise, the conversions thus determined are applied, and
5420          the converted operands are used in place of the original
5421          operands for the remainder of this section.  */
5422       conv = cand->convs[0];
5423       arg1 = convert_like (conv, arg1, complain);
5424       conv = cand->convs[1];
5425       arg2 = convert_like (conv, arg2, complain);
5426       arg2_type = TREE_TYPE (arg2);
5427       conv = cand->convs[2];
5428       arg3 = convert_like (conv, arg3, complain);
5429       arg3_type = TREE_TYPE (arg3);
5430     }
5431
5432   /* [expr.cond]
5433
5434      Lvalue-to-rvalue (_conv.lval_), array-to-pointer (_conv.array_),
5435      and function-to-pointer (_conv.func_) standard conversions are
5436      performed on the second and third operands.
5437
5438      We need to force the lvalue-to-rvalue conversion here for class types,
5439      so we get TARGET_EXPRs; trying to deal with a COND_EXPR of class rvalues
5440      that isn't wrapped with a TARGET_EXPR plays havoc with exception
5441      regions.  */
5442
5443   arg2 = force_rvalue (arg2, complain);
5444   if (!CLASS_TYPE_P (arg2_type))
5445     arg2_type = TREE_TYPE (arg2);
5446
5447   arg3 = force_rvalue (arg3, complain);
5448   if (!CLASS_TYPE_P (arg3_type))
5449     arg3_type = TREE_TYPE (arg3);
5450
5451   if (arg2 == error_mark_node || arg3 == error_mark_node)
5452     return error_mark_node;
5453
5454   /* [expr.cond]
5455
5456      After those conversions, one of the following shall hold:
5457
5458      --The second and third operands have the same type; the result  is  of
5459        that type.  */
5460   if (same_type_p (arg2_type, arg3_type))
5461     result_type = arg2_type;
5462   /* [expr.cond]
5463
5464      --The second and third operands have arithmetic or enumeration
5465        type; the usual arithmetic conversions are performed to bring
5466        them to a common type, and the result is of that type.  */
5467   else if ((ARITHMETIC_TYPE_P (arg2_type)
5468             || UNSCOPED_ENUM_P (arg2_type))
5469            && (ARITHMETIC_TYPE_P (arg3_type)
5470                || UNSCOPED_ENUM_P (arg3_type)))
5471     {
5472       /* In this case, there is always a common type.  */
5473       result_type = type_after_usual_arithmetic_conversions (arg2_type,
5474                                                              arg3_type);
5475       if (complain & tf_warning)
5476         do_warn_double_promotion (result_type, arg2_type, arg3_type,
5477                                   "implicit conversion from %qH to %qI to "
5478                                   "match other result of conditional",
5479                                   loc);
5480
5481       if (TREE_CODE (arg2_type) == ENUMERAL_TYPE
5482           && TREE_CODE (arg3_type) == ENUMERAL_TYPE)
5483         {
5484           tree stripped_orig_arg2 = tree_strip_any_location_wrapper (orig_arg2);
5485           tree stripped_orig_arg3 = tree_strip_any_location_wrapper (orig_arg3);
5486           if (TREE_CODE (stripped_orig_arg2) == CONST_DECL
5487               && TREE_CODE (stripped_orig_arg3) == CONST_DECL
5488               && (DECL_CONTEXT (stripped_orig_arg2)
5489                   == DECL_CONTEXT (stripped_orig_arg3)))
5490             /* Two enumerators from the same enumeration can have different
5491                types when the enumeration is still being defined.  */;
5492           else if (complain & tf_warning)
5493             warning_at (loc, OPT_Wenum_compare, "enumerated mismatch "
5494                         "in conditional expression: %qT vs %qT",
5495                         arg2_type, arg3_type);
5496         }
5497       else if (extra_warnings
5498                && ((TREE_CODE (arg2_type) == ENUMERAL_TYPE
5499                     && !same_type_p (arg3_type, type_promotes_to (arg2_type)))
5500                    || (TREE_CODE (arg3_type) == ENUMERAL_TYPE
5501                        && !same_type_p (arg2_type,
5502                                         type_promotes_to (arg3_type)))))
5503         {
5504           if (complain & tf_warning)
5505             warning_at (loc, OPT_Wextra, "enumerated and non-enumerated "
5506                         "type in conditional expression");
5507         }
5508
5509       arg2 = perform_implicit_conversion (result_type, arg2, complain);
5510       arg3 = perform_implicit_conversion (result_type, arg3, complain);
5511     }
5512   /* [expr.cond]
5513
5514      --The second and third operands have pointer type, or one has
5515        pointer type and the other is a null pointer constant; pointer
5516        conversions (_conv.ptr_) and qualification conversions
5517        (_conv.qual_) are performed to bring them to their composite
5518        pointer type (_expr.rel_).  The result is of the composite
5519        pointer type.
5520
5521      --The second and third operands have pointer to member type, or
5522        one has pointer to member type and the other is a null pointer
5523        constant; pointer to member conversions (_conv.mem_) and
5524        qualification conversions (_conv.qual_) are performed to bring
5525        them to a common type, whose cv-qualification shall match the
5526        cv-qualification of either the second or the third operand.
5527        The result is of the common type.  */
5528   else if ((null_ptr_cst_p (arg2)
5529             && TYPE_PTR_OR_PTRMEM_P (arg3_type))
5530            || (null_ptr_cst_p (arg3)
5531                && TYPE_PTR_OR_PTRMEM_P (arg2_type))
5532            || (TYPE_PTR_P (arg2_type) && TYPE_PTR_P (arg3_type))
5533            || (TYPE_PTRDATAMEM_P (arg2_type) && TYPE_PTRDATAMEM_P (arg3_type))
5534            || (TYPE_PTRMEMFUNC_P (arg2_type) && TYPE_PTRMEMFUNC_P (arg3_type)))
5535     {
5536       result_type = composite_pointer_type (arg2_type, arg3_type, arg2,
5537                                             arg3, CPO_CONDITIONAL_EXPR,
5538                                             complain);
5539       if (result_type == error_mark_node)
5540         return error_mark_node;
5541       arg2 = perform_implicit_conversion (result_type, arg2, complain);
5542       arg3 = perform_implicit_conversion (result_type, arg3, complain);
5543     }
5544
5545   if (!result_type)
5546     {
5547       if (complain & tf_error)
5548         error_at (loc, "operands to %<?:%> have different types %qT and %qT",
5549                   arg2_type, arg3_type);
5550       return error_mark_node;
5551     }
5552
5553   if (arg2 == error_mark_node || arg3 == error_mark_node)
5554     return error_mark_node;
5555
5556  valid_operands:
5557   if (processing_template_decl && is_glvalue)
5558     {
5559       /* Let lvalue_kind know this was a glvalue.  */
5560       tree arg = (result_type == arg2_type ? arg2 : arg3);
5561       result_type = cp_build_reference_type (result_type, xvalue_p (arg));
5562     }
5563
5564   result = build3_loc (loc, COND_EXPR, result_type, arg1, arg2, arg3);
5565
5566   /* If the ARG2 and ARG3 are the same and don't have side-effects,
5567      warn here, because the COND_EXPR will be turned into ARG2.  */
5568   if (warn_duplicated_branches
5569       && (complain & tf_warning)
5570       && (arg2 == arg3 || operand_equal_p (arg2, arg3, 0)))
5571     warning_at (EXPR_LOCATION (result), OPT_Wduplicated_branches,
5572                 "this condition has identical branches");
5573
5574   /* We can't use result_type below, as fold might have returned a
5575      throw_expr.  */
5576
5577   if (!is_glvalue)
5578     {
5579       /* Expand both sides into the same slot, hopefully the target of
5580          the ?: expression.  We used to check for TARGET_EXPRs here,
5581          but now we sometimes wrap them in NOP_EXPRs so the test would
5582          fail.  */
5583       if (CLASS_TYPE_P (TREE_TYPE (result)))
5584         result = get_target_expr_sfinae (result, complain);
5585       /* If this expression is an rvalue, but might be mistaken for an
5586          lvalue, we must add a NON_LVALUE_EXPR.  */
5587       result = rvalue (result);
5588     }
5589   else
5590     result = force_paren_expr (result);
5591
5592   return result;
5593 }
5594
5595 /* Wrapper for above.  */
5596
5597 tree
5598 build_conditional_expr (const op_location_t &loc,
5599                         tree arg1, tree arg2, tree arg3,
5600                         tsubst_flags_t complain)
5601 {
5602   tree ret;
5603   bool subtime = timevar_cond_start (TV_OVERLOAD);
5604   ret = build_conditional_expr_1 (loc, arg1, arg2, arg3, complain);
5605   timevar_cond_stop (TV_OVERLOAD, subtime);
5606   return ret;
5607 }
5608
5609 /* OPERAND is an operand to an expression.  Perform necessary steps
5610    required before using it.  If OPERAND is NULL_TREE, NULL_TREE is
5611    returned.  */
5612
5613 static tree
5614 prep_operand (tree operand)
5615 {
5616   if (operand)
5617     {
5618       if (CLASS_TYPE_P (TREE_TYPE (operand))
5619           && CLASSTYPE_TEMPLATE_INSTANTIATION (TREE_TYPE (operand)))
5620         /* Make sure the template type is instantiated now.  */
5621         instantiate_class_template (TYPE_MAIN_VARIANT (TREE_TYPE (operand)));
5622     }
5623
5624   return operand;
5625 }
5626
5627 /* Add each of the viable functions in FNS (a FUNCTION_DECL or
5628    OVERLOAD) to the CANDIDATES, returning an updated list of
5629    CANDIDATES.  The ARGS are the arguments provided to the call;
5630    if FIRST_ARG is non-null it is the implicit object argument,
5631    otherwise the first element of ARGS is used if needed.  The
5632    EXPLICIT_TARGS are explicit template arguments provided.
5633    TEMPLATE_ONLY is true if only template functions should be
5634    considered.  CONVERSION_PATH, ACCESS_PATH, and FLAGS are as for
5635    add_function_candidate.  */
5636
5637 static void
5638 add_candidates (tree fns, tree first_arg, const vec<tree, va_gc> *args,
5639                 tree return_type,
5640                 tree explicit_targs, bool template_only,
5641                 tree conversion_path, tree access_path,
5642                 int flags,
5643                 struct z_candidate **candidates,
5644                 tsubst_flags_t complain)
5645 {
5646   tree ctype;
5647   const vec<tree, va_gc> *non_static_args;
5648   bool check_list_ctor = false;
5649   bool check_converting = false;
5650   unification_kind_t strict;
5651
5652   if (!fns)
5653     return;
5654
5655   /* Precalculate special handling of constructors and conversion ops.  */
5656   tree fn = OVL_FIRST (fns);
5657   if (DECL_CONV_FN_P (fn))
5658     {
5659       check_list_ctor = false;
5660       check_converting = (flags & LOOKUP_ONLYCONVERTING) != 0;
5661       if (flags & LOOKUP_NO_CONVERSION)
5662         /* We're doing return_type(x).  */
5663         strict = DEDUCE_CONV;
5664       else
5665         /* We're doing x.operator return_type().  */
5666         strict = DEDUCE_EXACT;
5667       /* [over.match.funcs] For conversion functions, the function
5668          is considered to be a member of the class of the implicit
5669          object argument for the purpose of defining the type of
5670          the implicit object parameter.  */
5671       ctype = TYPE_MAIN_VARIANT (TREE_TYPE (first_arg));
5672     }
5673   else
5674     {
5675       if (DECL_CONSTRUCTOR_P (fn))
5676         {
5677           check_list_ctor = (flags & LOOKUP_LIST_ONLY) != 0;
5678           /* For list-initialization we consider explicit constructors
5679              and complain if one is chosen.  */
5680           check_converting
5681             = ((flags & (LOOKUP_ONLYCONVERTING|LOOKUP_LIST_INIT_CTOR))
5682                == LOOKUP_ONLYCONVERTING);
5683         }
5684       strict = DEDUCE_CALL;
5685       ctype = conversion_path ? BINFO_TYPE (conversion_path) : NULL_TREE;
5686     }
5687
5688   if (first_arg)
5689     non_static_args = args;
5690   else
5691     /* Delay creating the implicit this parameter until it is needed.  */
5692     non_static_args = NULL;
5693
5694   for (lkp_iterator iter (fns); iter; ++iter)
5695     {
5696       fn = *iter;
5697
5698       if (check_converting && DECL_NONCONVERTING_P (fn))
5699         continue;
5700       if (check_list_ctor && !is_list_ctor (fn))
5701         continue;
5702
5703       tree fn_first_arg = NULL_TREE;
5704       const vec<tree, va_gc> *fn_args = args;
5705
5706       if (DECL_NONSTATIC_MEMBER_FUNCTION_P (fn))
5707         {
5708           /* Figure out where the object arg comes from.  If this
5709              function is a non-static member and we didn't get an
5710              implicit object argument, move it out of args.  */
5711           if (first_arg == NULL_TREE)
5712             {
5713               unsigned int ix;
5714               tree arg;
5715               vec<tree, va_gc> *tempvec;
5716               vec_alloc (tempvec, args->length () - 1);
5717               for (ix = 1; args->iterate (ix, &arg); ++ix)
5718                 tempvec->quick_push (arg);
5719               non_static_args = tempvec;
5720               first_arg = (*args)[0];
5721             }
5722
5723           fn_first_arg = first_arg;
5724           fn_args = non_static_args;
5725         }
5726
5727       if (TREE_CODE (fn) == TEMPLATE_DECL)
5728         add_template_candidate (candidates,
5729                                 fn,
5730                                 ctype,
5731                                 explicit_targs,
5732                                 fn_first_arg, 
5733                                 fn_args,
5734                                 return_type,
5735                                 access_path,
5736                                 conversion_path,
5737                                 flags,
5738                                 strict,
5739                                 complain);
5740       else if (!template_only)
5741         add_function_candidate (candidates,
5742                                 fn,
5743                                 ctype,
5744                                 fn_first_arg,
5745                                 fn_args,
5746                                 access_path,
5747                                 conversion_path,
5748                                 flags,
5749                                 NULL,
5750                                 complain);
5751     }
5752 }
5753
5754 /* Returns 1 if P0145R2 says that the LHS of operator CODE is evaluated first,
5755    -1 if the RHS is evaluated first, or 0 if the order is unspecified.  */
5756
5757 static int
5758 op_is_ordered (tree_code code)
5759 {
5760   switch (code)
5761     {
5762       // 5. b @= a
5763     case MODIFY_EXPR:
5764       return (flag_strong_eval_order > 1 ? -1 : 0);
5765
5766       // 6. a[b]
5767     case ARRAY_REF:
5768       return (flag_strong_eval_order > 1 ? 1 : 0);
5769
5770       // 1. a.b
5771       // Not overloadable (yet).
5772       // 2. a->b
5773       // Only one argument.
5774       // 3. a->*b
5775     case MEMBER_REF:
5776       // 7. a << b
5777     case LSHIFT_EXPR:
5778       // 8. a >> b
5779     case RSHIFT_EXPR:
5780       return (flag_strong_eval_order ? 1 : 0);
5781
5782     default:
5783       return 0;
5784     }
5785 }
5786
5787 static tree
5788 build_new_op_1 (const op_location_t &loc, enum tree_code code, int flags,
5789                 tree arg1, tree arg2, tree arg3, tree *overload,
5790                 tsubst_flags_t complain)
5791 {
5792   struct z_candidate *candidates = 0, *cand;
5793   vec<tree, va_gc> *arglist;
5794   tree args[3];
5795   tree result = NULL_TREE;
5796   bool result_valid_p = false;
5797   enum tree_code code2 = NOP_EXPR;
5798   enum tree_code code_orig_arg1 = ERROR_MARK;
5799   enum tree_code code_orig_arg2 = ERROR_MARK;
5800   conversion *conv;
5801   void *p;
5802   bool strict_p;
5803   bool any_viable_p;
5804
5805   if (error_operand_p (arg1)
5806       || error_operand_p (arg2)
5807       || error_operand_p (arg3))
5808     return error_mark_node;
5809
5810   bool ismodop = code == MODIFY_EXPR;
5811   if (ismodop)
5812     {
5813       code2 = TREE_CODE (arg3);
5814       arg3 = NULL_TREE;
5815     }
5816   tree fnname = ovl_op_identifier (ismodop, ismodop ? code2 : code);
5817
5818   arg1 = prep_operand (arg1);
5819
5820   bool memonly = false;
5821   switch (code)
5822     {
5823     case NEW_EXPR:
5824     case VEC_NEW_EXPR:
5825     case VEC_DELETE_EXPR:
5826     case DELETE_EXPR:
5827       /* Use build_op_new_call and build_op_delete_call instead.  */
5828       gcc_unreachable ();
5829
5830     case CALL_EXPR:
5831       /* Use build_op_call instead.  */
5832       gcc_unreachable ();
5833
5834     case TRUTH_ORIF_EXPR:
5835     case TRUTH_ANDIF_EXPR:
5836     case TRUTH_AND_EXPR:
5837     case TRUTH_OR_EXPR:
5838       /* These are saved for the sake of warn_logical_operator.  */
5839       code_orig_arg1 = TREE_CODE (arg1);
5840       code_orig_arg2 = TREE_CODE (arg2);
5841       break;
5842     case GT_EXPR:
5843     case LT_EXPR:
5844     case GE_EXPR:
5845     case LE_EXPR:
5846     case EQ_EXPR:
5847     case NE_EXPR:
5848       /* These are saved for the sake of maybe_warn_bool_compare.  */
5849       code_orig_arg1 = TREE_CODE (TREE_TYPE (arg1));
5850       code_orig_arg2 = TREE_CODE (TREE_TYPE (arg2));
5851       break;
5852
5853       /* =, ->, [], () must be non-static member functions.  */
5854     case MODIFY_EXPR:
5855       if (code2 != NOP_EXPR)
5856         break;
5857       /* FALLTHRU */
5858     case COMPONENT_REF:
5859     case ARRAY_REF:
5860       memonly = true;
5861       break;
5862
5863     default:
5864       break;
5865     }
5866
5867   arg2 = prep_operand (arg2);
5868   arg3 = prep_operand (arg3);
5869
5870   if (code == COND_EXPR)
5871     /* Use build_conditional_expr instead.  */
5872     gcc_unreachable ();
5873   else if (! OVERLOAD_TYPE_P (TREE_TYPE (arg1))
5874            && (! arg2 || ! OVERLOAD_TYPE_P (TREE_TYPE (arg2))))
5875     goto builtin;
5876
5877   if (code == POSTINCREMENT_EXPR || code == POSTDECREMENT_EXPR)
5878     arg2 = integer_zero_node;
5879
5880   vec_alloc (arglist, 3);
5881   arglist->quick_push (arg1);
5882   if (arg2 != NULL_TREE)
5883     arglist->quick_push (arg2);
5884   if (arg3 != NULL_TREE)
5885     arglist->quick_push (arg3);
5886
5887   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
5888   p = conversion_obstack_alloc (0);
5889
5890   /* Add namespace-scope operators to the list of functions to
5891      consider.  */
5892   if (!memonly)
5893     {
5894       tree fns = lookup_name_real (fnname, 0, 1, /*block_p=*/true, 0, 0);
5895       fns = lookup_arg_dependent (fnname, fns, arglist);
5896       add_candidates (fns, NULL_TREE, arglist, NULL_TREE,
5897                       NULL_TREE, false, NULL_TREE, NULL_TREE,
5898                       flags, &candidates, complain);
5899     }
5900
5901   args[0] = arg1;
5902   args[1] = arg2;
5903   args[2] = NULL_TREE;
5904
5905   /* Add class-member operators to the candidate set.  */
5906   if (CLASS_TYPE_P (TREE_TYPE (arg1)))
5907     {
5908       tree fns;
5909
5910       fns = lookup_fnfields (TREE_TYPE (arg1), fnname, 1);
5911       if (fns == error_mark_node)
5912         {
5913           result = error_mark_node;
5914           goto user_defined_result_ready;
5915         }
5916       if (fns)
5917         add_candidates (BASELINK_FUNCTIONS (fns),
5918                         NULL_TREE, arglist, NULL_TREE,
5919                         NULL_TREE, false,
5920                         BASELINK_BINFO (fns),
5921                         BASELINK_ACCESS_BINFO (fns),
5922                         flags, &candidates, complain);
5923     }
5924   /* Per 13.3.1.2/3, 2nd bullet, if no operand has a class type, then
5925      only non-member functions that have type T1 or reference to
5926      cv-qualified-opt T1 for the first argument, if the first argument
5927      has an enumeration type, or T2 or reference to cv-qualified-opt
5928      T2 for the second argument, if the second argument has an
5929      enumeration type.  Filter out those that don't match.  */
5930   else if (! arg2 || ! CLASS_TYPE_P (TREE_TYPE (arg2)))
5931     {
5932       struct z_candidate **candp, **next;
5933
5934       for (candp = &candidates; *candp; candp = next)
5935         {
5936           tree parmlist, parmtype;
5937           int i, nargs = (arg2 ? 2 : 1);
5938
5939           cand = *candp;
5940           next = &cand->next;
5941
5942           parmlist = TYPE_ARG_TYPES (TREE_TYPE (cand->fn));
5943
5944           for (i = 0; i < nargs; ++i)
5945             {
5946               parmtype = TREE_VALUE (parmlist);
5947
5948               if (TYPE_REF_P (parmtype))
5949                 parmtype = TREE_TYPE (parmtype);
5950               if (TREE_CODE (TREE_TYPE (args[i])) == ENUMERAL_TYPE
5951                   && (same_type_ignoring_top_level_qualifiers_p
5952                       (TREE_TYPE (args[i]), parmtype)))
5953                 break;
5954
5955               parmlist = TREE_CHAIN (parmlist);
5956             }
5957
5958           /* No argument has an appropriate type, so remove this
5959              candidate function from the list.  */
5960           if (i == nargs)
5961             {
5962               *candp = cand->next;
5963               next = candp;
5964             }
5965         }
5966     }
5967
5968   add_builtin_candidates (&candidates, code, code2, fnname, args,
5969                           flags, complain);
5970
5971   switch (code)
5972     {
5973     case COMPOUND_EXPR:
5974     case ADDR_EXPR:
5975       /* For these, the built-in candidates set is empty
5976          [over.match.oper]/3.  We don't want non-strict matches
5977          because exact matches are always possible with built-in
5978          operators.  The built-in candidate set for COMPONENT_REF
5979          would be empty too, but since there are no such built-in
5980          operators, we accept non-strict matches for them.  */
5981       strict_p = true;
5982       break;
5983
5984     default:
5985       strict_p = false;
5986       break;
5987     }
5988
5989   candidates = splice_viable (candidates, strict_p, &any_viable_p);
5990   if (!any_viable_p)
5991     {
5992       switch (code)
5993         {
5994         case POSTINCREMENT_EXPR:
5995         case POSTDECREMENT_EXPR:
5996           /* Don't try anything fancy if we're not allowed to produce
5997              errors.  */
5998           if (!(complain & tf_error))
5999             return error_mark_node;
6000
6001           /* Look for an `operator++ (int)'. Pre-1985 C++ didn't
6002              distinguish between prefix and postfix ++ and
6003              operator++() was used for both, so we allow this with
6004              -fpermissive.  */
6005           else
6006             {
6007               const char *msg = (flag_permissive) 
6008                 ? G_("no %<%D(int)%> declared for postfix %qs,"
6009                      " trying prefix operator instead")
6010                 : G_("no %<%D(int)%> declared for postfix %qs");
6011               permerror (loc, msg, fnname, OVL_OP_INFO (false, code)->name);
6012             }
6013
6014           if (!flag_permissive)
6015             return error_mark_node;
6016
6017           if (code == POSTINCREMENT_EXPR)
6018             code = PREINCREMENT_EXPR;
6019           else
6020             code = PREDECREMENT_EXPR;
6021           result = build_new_op_1 (loc, code, flags, arg1, NULL_TREE,
6022                                    NULL_TREE, overload, complain);
6023           break;
6024
6025           /* The caller will deal with these.  */
6026         case ADDR_EXPR:
6027         case COMPOUND_EXPR:
6028         case COMPONENT_REF:
6029           result = NULL_TREE;
6030           result_valid_p = true;
6031           break;
6032
6033         default:
6034           if (complain & tf_error)
6035             {
6036                 /* If one of the arguments of the operator represents
6037                    an invalid use of member function pointer, try to report
6038                    a meaningful error ...  */
6039               if (invalid_nonstatic_memfn_p (loc, arg1, tf_error)
6040                     || invalid_nonstatic_memfn_p (loc, arg2, tf_error)
6041                     || invalid_nonstatic_memfn_p (loc, arg3, tf_error))
6042                   /* We displayed the error message.  */;
6043                 else
6044                   {
6045                     /* ... Otherwise, report the more generic
6046                        "no matching operator found" error */
6047                     auto_diagnostic_group d;
6048                     op_error (loc, code, code2, arg1, arg2, arg3, FALSE);
6049                     print_z_candidates (loc, candidates);
6050                   }
6051             }
6052           result = error_mark_node;
6053           break;
6054         }
6055     }
6056   else
6057     {
6058       cand = tourney (candidates, complain);
6059       if (cand == 0)
6060         {
6061           if (complain & tf_error)
6062             {
6063               auto_diagnostic_group d;
6064               op_error (loc, code, code2, arg1, arg2, arg3, TRUE);
6065               print_z_candidates (loc, candidates);
6066             }
6067           result = error_mark_node;
6068         }
6069       else if (TREE_CODE (cand->fn) == FUNCTION_DECL)
6070         {
6071           if (overload)
6072             *overload = cand->fn;
6073
6074           if (resolve_args (arglist, complain) == NULL)
6075             result = error_mark_node;
6076           else
6077             result = build_over_call (cand, LOOKUP_NORMAL, complain);
6078
6079           if (trivial_fn_p (cand->fn))
6080             /* There won't be a CALL_EXPR.  */;
6081           else if (result && result != error_mark_node)
6082             {
6083               tree call = extract_call_expr (result);
6084               CALL_EXPR_OPERATOR_SYNTAX (call) = true;
6085
6086               if (processing_template_decl && DECL_HIDDEN_FRIEND_P (cand->fn))
6087                 /* This prevents build_new_function_call from discarding this
6088                    function during instantiation of the enclosing template.  */
6089                 KOENIG_LOOKUP_P (call) = 1;
6090
6091               /* Specify evaluation order as per P0145R2.  */
6092               CALL_EXPR_ORDERED_ARGS (call) = false;
6093               switch (op_is_ordered (code))
6094                 {
6095                 case -1:
6096                   CALL_EXPR_REVERSE_ARGS (call) = true;
6097                   break;
6098
6099                 case 1:
6100                   CALL_EXPR_ORDERED_ARGS (call) = true;
6101                   break;
6102
6103                 default:
6104                   break;
6105                 }
6106             }
6107         }
6108       else
6109         {
6110           /* Give any warnings we noticed during overload resolution.  */
6111           if (cand->warnings && (complain & tf_warning))
6112             {
6113               struct candidate_warning *w;
6114               for (w = cand->warnings; w; w = w->next)
6115                 joust (cand, w->loser, 1, complain);
6116             }
6117
6118           /* Check for comparison of different enum types.  */
6119           switch (code)
6120             {
6121             case GT_EXPR:
6122             case LT_EXPR:
6123             case GE_EXPR:
6124             case LE_EXPR:
6125             case EQ_EXPR:
6126             case NE_EXPR:
6127               if (TREE_CODE (TREE_TYPE (arg1)) == ENUMERAL_TYPE
6128                   && TREE_CODE (TREE_TYPE (arg2)) == ENUMERAL_TYPE
6129                   && (TYPE_MAIN_VARIANT (TREE_TYPE (arg1))
6130                       != TYPE_MAIN_VARIANT (TREE_TYPE (arg2)))
6131                   && (complain & tf_warning))
6132                 {
6133                   warning (OPT_Wenum_compare,
6134                            "comparison between %q#T and %q#T",
6135                            TREE_TYPE (arg1), TREE_TYPE (arg2));
6136                 }
6137               break;
6138             default:
6139               break;
6140             }
6141
6142           /* We need to strip any leading REF_BIND so that bitfields
6143              don't cause errors.  This should not remove any important
6144              conversions, because builtins don't apply to class
6145              objects directly.  */
6146           conv = cand->convs[0];
6147           if (conv->kind == ck_ref_bind)
6148             conv = next_conversion (conv);
6149           arg1 = convert_like (conv, arg1, complain);
6150
6151           if (arg2)
6152             {
6153               conv = cand->convs[1];
6154               if (conv->kind == ck_ref_bind)
6155                 conv = next_conversion (conv);
6156               else
6157                 arg2 = decay_conversion (arg2, complain);
6158
6159               /* We need to call warn_logical_operator before
6160                  converting arg2 to a boolean_type, but after
6161                  decaying an enumerator to its value.  */
6162               if (complain & tf_warning)
6163                 warn_logical_operator (loc, code, boolean_type_node,
6164                                        code_orig_arg1, arg1,
6165                                        code_orig_arg2, arg2);
6166
6167               arg2 = convert_like (conv, arg2, complain);
6168             }
6169           if (arg3)
6170             {
6171               conv = cand->convs[2];
6172               if (conv->kind == ck_ref_bind)
6173                 conv = next_conversion (conv);
6174               convert_like (conv, arg3, complain);
6175             }
6176
6177         }
6178     }
6179
6180  user_defined_result_ready:
6181
6182   /* Free all the conversions we allocated.  */
6183   obstack_free (&conversion_obstack, p);
6184
6185   if (result || result_valid_p)
6186     return result;
6187
6188  builtin:
6189   switch (code)
6190     {
6191     case MODIFY_EXPR:
6192       return cp_build_modify_expr (loc, arg1, code2, arg2, complain);
6193
6194     case INDIRECT_REF:
6195       return cp_build_indirect_ref (arg1, RO_UNARY_STAR, complain);
6196
6197     case TRUTH_ANDIF_EXPR:
6198     case TRUTH_ORIF_EXPR:
6199     case TRUTH_AND_EXPR:
6200     case TRUTH_OR_EXPR:
6201       if (complain & tf_warning)
6202         warn_logical_operator (loc, code, boolean_type_node,
6203                                code_orig_arg1, arg1,
6204                                code_orig_arg2, arg2);
6205       /* Fall through.  */
6206     case GT_EXPR:
6207     case LT_EXPR:
6208     case GE_EXPR:
6209     case LE_EXPR:
6210     case EQ_EXPR:
6211     case NE_EXPR:
6212       if ((complain & tf_warning)
6213           && ((code_orig_arg1 == BOOLEAN_TYPE)
6214               ^ (code_orig_arg2 == BOOLEAN_TYPE)))
6215         maybe_warn_bool_compare (loc, code, arg1, arg2);
6216       if (complain & tf_warning && warn_tautological_compare)
6217         warn_tautological_cmp (loc, code, arg1, arg2);
6218       /* Fall through.  */
6219     case PLUS_EXPR:
6220     case MINUS_EXPR:
6221     case MULT_EXPR:
6222     case TRUNC_DIV_EXPR:
6223     case MAX_EXPR:
6224     case MIN_EXPR:
6225     case LSHIFT_EXPR:
6226     case RSHIFT_EXPR:
6227     case TRUNC_MOD_EXPR:
6228     case BIT_AND_EXPR:
6229     case BIT_IOR_EXPR:
6230     case BIT_XOR_EXPR:
6231       return cp_build_binary_op (loc, code, arg1, arg2, complain);
6232
6233     case UNARY_PLUS_EXPR:
6234     case NEGATE_EXPR:
6235     case BIT_NOT_EXPR:
6236     case TRUTH_NOT_EXPR:
6237     case PREINCREMENT_EXPR:
6238     case POSTINCREMENT_EXPR:
6239     case PREDECREMENT_EXPR:
6240     case POSTDECREMENT_EXPR:
6241     case REALPART_EXPR:
6242     case IMAGPART_EXPR:
6243     case ABS_EXPR:
6244       return cp_build_unary_op (code, arg1, candidates != 0, complain);
6245
6246     case ARRAY_REF:
6247       return cp_build_array_ref (input_location, arg1, arg2, complain);
6248
6249     case MEMBER_REF:
6250       return build_m_component_ref (cp_build_indirect_ref (arg1, RO_ARROW_STAR, 
6251                                                            complain), 
6252                                     arg2, complain);
6253
6254       /* The caller will deal with these.  */
6255     case ADDR_EXPR:
6256     case COMPONENT_REF:
6257     case COMPOUND_EXPR:
6258       return NULL_TREE;
6259
6260     default:
6261       gcc_unreachable ();
6262     }
6263   return NULL_TREE;
6264 }
6265
6266 /* Wrapper for above.  */
6267
6268 tree
6269 build_new_op (const op_location_t &loc, enum tree_code code, int flags,
6270               tree arg1, tree arg2, tree arg3,
6271               tree *overload, tsubst_flags_t complain)
6272 {
6273   tree ret;
6274   bool subtime = timevar_cond_start (TV_OVERLOAD);
6275   ret = build_new_op_1 (loc, code, flags, arg1, arg2, arg3,
6276                         overload, complain);
6277   timevar_cond_stop (TV_OVERLOAD, subtime);
6278   return ret;
6279 }
6280
6281 /* CALL was returned by some call-building function; extract the actual
6282    CALL_EXPR from any bits that have been tacked on, e.g. by
6283    convert_from_reference.  */
6284
6285 tree
6286 extract_call_expr (tree call)
6287 {
6288   while (TREE_CODE (call) == COMPOUND_EXPR)
6289     call = TREE_OPERAND (call, 1);
6290   if (REFERENCE_REF_P (call))
6291     call = TREE_OPERAND (call, 0);
6292   if (TREE_CODE (call) == TARGET_EXPR)
6293     call = TARGET_EXPR_INITIAL (call);
6294   gcc_assert (TREE_CODE (call) == CALL_EXPR
6295               || TREE_CODE (call) == AGGR_INIT_EXPR
6296               || call == error_mark_node);
6297   return call;
6298 }
6299
6300 /* Returns true if FN has two parameters, of which the second has type
6301    size_t.  */
6302
6303 static bool
6304 second_parm_is_size_t (tree fn)
6305 {
6306   tree t = FUNCTION_ARG_CHAIN (fn);
6307   if (!t || !same_type_p (TREE_VALUE (t), size_type_node))
6308     return false;
6309   t = TREE_CHAIN (t);
6310   if (t == void_list_node)
6311     return true;
6312   return false;
6313 }
6314
6315 /* True if T, an allocation function, has std::align_val_t as its second
6316    argument.  */
6317
6318 bool
6319 aligned_allocation_fn_p (tree t)
6320 {
6321   if (!aligned_new_threshold)
6322     return false;
6323
6324   tree a = FUNCTION_ARG_CHAIN (t);
6325   return (a && same_type_p (TREE_VALUE (a), align_type_node));
6326 }
6327
6328 /* True if T is std::destroying_delete_t.  */
6329
6330 static bool
6331 std_destroying_delete_t_p (tree t)
6332 {
6333   return (TYPE_CONTEXT (t) == std_node
6334           && id_equal (TYPE_IDENTIFIER (t), "destroying_delete_t"));
6335 }
6336
6337 /* A deallocation function with at least two parameters whose second parameter
6338    type is of type std::destroying_delete_t is a destroying operator delete. A
6339    destroying operator delete shall be a class member function named operator
6340    delete. [ Note: Array deletion cannot use a destroying operator
6341    delete. --end note ] */
6342
6343 tree
6344 destroying_delete_p (tree t)
6345 {
6346   tree a = TYPE_ARG_TYPES (TREE_TYPE (t));
6347   if (!a || !TREE_CHAIN (a))
6348     return NULL_TREE;
6349   tree type = TREE_VALUE (TREE_CHAIN (a));
6350   return std_destroying_delete_t_p (type) ? type : NULL_TREE;
6351 }
6352
6353 struct dealloc_info
6354 {
6355   bool sized;
6356   bool aligned;
6357   tree destroying;
6358 };
6359
6360 /* Returns true iff T, an element of an OVERLOAD chain, is a usual deallocation
6361    function (3.7.4.2 [basic.stc.dynamic.deallocation]).  If so, and DI is
6362    non-null, also set *DI. */
6363
6364 static bool
6365 usual_deallocation_fn_p (tree t, dealloc_info *di)
6366 {
6367   if (di) *di = dealloc_info();
6368
6369   /* A template instance is never a usual deallocation function,
6370      regardless of its signature.  */
6371   if (TREE_CODE (t) == TEMPLATE_DECL
6372       || primary_template_specialization_p (t))
6373     return false;
6374
6375   /* A usual deallocation function is a deallocation function whose parameters
6376      after the first are
6377      - optionally, a parameter of type std::destroying_delete_t, then
6378      - optionally, a parameter of type std::size_t, then
6379      - optionally, a parameter of type std::align_val_t.  */
6380   bool global = DECL_NAMESPACE_SCOPE_P (t);
6381   tree chain = FUNCTION_ARG_CHAIN (t);
6382   if (chain && destroying_delete_p (t))
6383     {
6384       if (di) di->destroying = TREE_VALUE (chain);
6385       chain = TREE_CHAIN (chain);
6386     }
6387   if (chain
6388       && (!global || flag_sized_deallocation)
6389       && same_type_p (TREE_VALUE (chain), size_type_node))
6390     {
6391       if (di) di->sized = true;
6392       chain = TREE_CHAIN (chain);
6393     }
6394   if (chain && aligned_new_threshold
6395       && same_type_p (TREE_VALUE (chain), align_type_node))
6396     {
6397       if (di) di->aligned = true;
6398       chain = TREE_CHAIN (chain);
6399     }
6400   return (chain == void_list_node);
6401 }
6402
6403 /* Just return whether FN is a usual deallocation function.  */
6404
6405 bool
6406 usual_deallocation_fn_p (tree fn)
6407 {
6408   return usual_deallocation_fn_p (fn, NULL);
6409 }
6410
6411 /* Build a call to operator delete.  This has to be handled very specially,
6412    because the restrictions on what signatures match are different from all
6413    other call instances.  For a normal delete, only a delete taking (void *)
6414    or (void *, size_t) is accepted.  For a placement delete, only an exact
6415    match with the placement new is accepted.
6416
6417    CODE is either DELETE_EXPR or VEC_DELETE_EXPR.
6418    ADDR is the pointer to be deleted.
6419    SIZE is the size of the memory block to be deleted.
6420    GLOBAL_P is true if the delete-expression should not consider
6421    class-specific delete operators.
6422    PLACEMENT is the corresponding placement new call, or NULL_TREE.
6423
6424    If this call to "operator delete" is being generated as part to
6425    deallocate memory allocated via a new-expression (as per [expr.new]
6426    which requires that if the initialization throws an exception then
6427    we call a deallocation function), then ALLOC_FN is the allocation
6428    function.  */
6429
6430 tree
6431 build_op_delete_call (enum tree_code code, tree addr, tree size,
6432                       bool global_p, tree placement,
6433                       tree alloc_fn, tsubst_flags_t complain)
6434 {
6435   tree fn = NULL_TREE;
6436   tree fns, fnname, type, t;
6437   dealloc_info di_fn = { };
6438
6439   if (addr == error_mark_node)
6440     return error_mark_node;
6441
6442   type = strip_array_types (TREE_TYPE (TREE_TYPE (addr)));
6443
6444   fnname = ovl_op_identifier (false, code);
6445
6446   if (CLASS_TYPE_P (type)
6447       && COMPLETE_TYPE_P (complete_type (type))
6448       && !global_p)
6449     /* In [class.free]
6450
6451        If the result of the lookup is ambiguous or inaccessible, or if
6452        the lookup selects a placement deallocation function, the
6453        program is ill-formed.
6454
6455        Therefore, we ask lookup_fnfields to complain about ambiguity.  */
6456     {
6457       fns = lookup_fnfields (TYPE_BINFO (type), fnname, 1);
6458       if (fns == error_mark_node)
6459         return error_mark_node;
6460     }
6461   else
6462     fns = NULL_TREE;
6463
6464   if (fns == NULL_TREE)
6465     fns = lookup_name_nonclass (fnname);
6466
6467   /* Strip const and volatile from addr.  */
6468   tree oaddr = addr;
6469   addr = cp_convert (ptr_type_node, addr, complain);
6470
6471   if (placement)
6472     {
6473       /* "A declaration of a placement deallocation function matches the
6474          declaration of a placement allocation function if it has the same
6475          number of parameters and, after parameter transformations (8.3.5),
6476          all parameter types except the first are identical."
6477
6478          So we build up the function type we want and ask instantiate_type
6479          to get it for us.  */
6480       t = FUNCTION_ARG_CHAIN (alloc_fn);
6481       t = tree_cons (NULL_TREE, ptr_type_node, t);
6482       t = build_function_type (void_type_node, t);
6483
6484       fn = instantiate_type (t, fns, tf_none);
6485       if (fn == error_mark_node)
6486         return NULL_TREE;
6487
6488       fn = MAYBE_BASELINK_FUNCTIONS (fn);
6489
6490       /* "If the lookup finds the two-parameter form of a usual deallocation
6491          function (3.7.4.2) and that function, considered as a placement
6492          deallocation function, would have been selected as a match for the
6493          allocation function, the program is ill-formed."  */
6494       if (second_parm_is_size_t (fn))
6495         {
6496           const char *const msg1
6497             = G_("exception cleanup for this placement new selects "
6498                  "non-placement %<operator delete%>");
6499           const char *const msg2
6500             = G_("%qD is a usual (non-placement) deallocation "
6501                  "function in C++14 (or with %<-fsized-deallocation%>)");
6502
6503           /* But if the class has an operator delete (void *), then that is
6504              the usual deallocation function, so we shouldn't complain
6505              about using the operator delete (void *, size_t).  */
6506           if (DECL_CLASS_SCOPE_P (fn))
6507             for (lkp_iterator iter (MAYBE_BASELINK_FUNCTIONS (fns));
6508                  iter; ++iter)
6509               {
6510                 tree elt = *iter;
6511                 if (usual_deallocation_fn_p (elt)
6512                     && FUNCTION_ARG_CHAIN (elt) == void_list_node)
6513                   goto ok;
6514               }
6515           /* Before C++14 a two-parameter global deallocation function is
6516              always a placement deallocation function, but warn if
6517              -Wc++14-compat.  */
6518           else if (!flag_sized_deallocation)
6519             {
6520               if (complain & tf_warning)
6521                 {
6522                   auto_diagnostic_group d;
6523                   if (warning (OPT_Wc__14_compat, msg1))
6524                     inform (DECL_SOURCE_LOCATION (fn), msg2, fn);
6525                 }
6526               goto ok;
6527             }
6528
6529           if (complain & tf_warning_or_error)
6530             {
6531               auto_diagnostic_group d;
6532               if (permerror (input_location, msg1))
6533                 {
6534                   /* Only mention C++14 for namespace-scope delete.  */
6535                   if (DECL_NAMESPACE_SCOPE_P (fn))
6536                     inform (DECL_SOURCE_LOCATION (fn), msg2, fn);
6537                   else
6538                     inform (DECL_SOURCE_LOCATION (fn),
6539                             "%qD is a usual (non-placement) deallocation "
6540                             "function", fn);
6541                 }
6542             }
6543           else
6544             return error_mark_node;
6545         ok:;
6546         }
6547     }
6548   else
6549     /* "Any non-placement deallocation function matches a non-placement
6550        allocation function. If the lookup finds a single matching
6551        deallocation function, that function will be called; otherwise, no
6552        deallocation function will be called."  */
6553     for (lkp_iterator iter (MAYBE_BASELINK_FUNCTIONS (fns)); iter; ++iter)
6554       {
6555         tree elt = *iter;
6556         dealloc_info di_elt;
6557         if (usual_deallocation_fn_p (elt, &di_elt))
6558           {
6559             if (!fn)
6560               {
6561                 fn = elt;
6562                 di_fn = di_elt;
6563                 continue;
6564               }
6565
6566             /* -- If any of the deallocation functions is a destroying
6567                operator delete, all deallocation functions that are not
6568                destroying operator deletes are eliminated from further
6569                consideration.  */
6570             if (di_elt.destroying != di_fn.destroying)
6571               {
6572                 if (di_elt.destroying)
6573                   {
6574                     fn = elt;
6575                     di_fn = di_elt;
6576                   }
6577                 continue;
6578               }
6579
6580             /* -- If the type has new-extended alignment, a function with a
6581                parameter of type std::align_val_t is preferred; otherwise a
6582                function without such a parameter is preferred. If exactly one
6583                preferred function is found, that function is selected and the
6584                selection process terminates. If more than one preferred
6585                function is found, all non-preferred functions are eliminated
6586                from further consideration.  */
6587             if (aligned_new_threshold)
6588               {
6589                 bool want_align = type_has_new_extended_alignment (type);
6590                 if (di_elt.aligned != di_fn.aligned)
6591                   {
6592                     if (want_align == di_elt.aligned)
6593                       {
6594                         fn = elt;
6595                         di_fn = di_elt;
6596                       }
6597                     continue;
6598                   }
6599               }
6600
6601             /* -- If the deallocation functions have class scope, the one
6602                without a parameter of type std::size_t is selected.  */
6603             bool want_size;
6604             if (DECL_CLASS_SCOPE_P (fn))
6605               want_size = false;
6606
6607             /* -- If the type is complete and if, for the second alternative
6608                (delete array) only, the operand is a pointer to a class type
6609                with a non-trivial destructor or a (possibly multi-dimensional)
6610                array thereof, the function with a parameter of type std::size_t
6611                is selected.
6612
6613                -- Otherwise, it is unspecified whether a deallocation function
6614                with a parameter of type std::size_t is selected.  */
6615             else
6616               {
6617                 want_size = COMPLETE_TYPE_P (type);
6618                 if (code == VEC_DELETE_EXPR
6619                     && !TYPE_VEC_NEW_USES_COOKIE (type))
6620                   /* We need a cookie to determine the array size.  */
6621                   want_size = false;
6622               }
6623             gcc_assert (di_fn.sized != di_elt.sized);
6624             if (want_size == di_elt.sized)
6625               {
6626                 fn = elt;
6627                 di_fn = di_elt;
6628               }
6629           }
6630       }
6631
6632   /* If we have a matching function, call it.  */
6633   if (fn)
6634     {
6635       gcc_assert (TREE_CODE (fn) == FUNCTION_DECL);
6636
6637       /* If the FN is a member function, make sure that it is
6638          accessible.  */
6639       if (BASELINK_P (fns))
6640         perform_or_defer_access_check (BASELINK_BINFO (fns), fn, fn,
6641                                        complain);
6642
6643       /* Core issue 901: It's ok to new a type with deleted delete.  */
6644       if (DECL_DELETED_FN (fn) && alloc_fn)
6645         return NULL_TREE;
6646
6647       if (placement)
6648         {
6649           /* The placement args might not be suitable for overload
6650              resolution at this point, so build the call directly.  */
6651           int nargs = call_expr_nargs (placement);
6652           tree *argarray = XALLOCAVEC (tree, nargs);
6653           int i;
6654           argarray[0] = addr;
6655           for (i = 1; i < nargs; i++)
6656             argarray[i] = CALL_EXPR_ARG (placement, i);
6657           if (!mark_used (fn, complain) && !(complain & tf_error))
6658             return error_mark_node;
6659           return build_cxx_call (fn, nargs, argarray, complain);
6660         }
6661       else
6662         {
6663           tree destroying = di_fn.destroying;
6664           if (destroying)
6665             {
6666               /* Strip const and volatile from addr but retain the type of the
6667                  object.  */
6668               tree rtype = TREE_TYPE (TREE_TYPE (oaddr));
6669               rtype = cv_unqualified (rtype);
6670               rtype = TYPE_POINTER_TO (rtype);
6671               addr = cp_convert (rtype, oaddr, complain);
6672               destroying = build_functional_cast (destroying, NULL_TREE,
6673                                                   complain);
6674             }
6675
6676           tree ret;
6677           releasing_vec args;
6678           args->quick_push (addr);
6679           if (destroying)
6680             args->quick_push (destroying);
6681           if (di_fn.sized)
6682             args->quick_push (size);
6683           if (di_fn.aligned)
6684             {
6685               tree al = build_int_cst (align_type_node, TYPE_ALIGN_UNIT (type));
6686               args->quick_push (al);
6687             }
6688           ret = cp_build_function_call_vec (fn, &args, complain);
6689           return ret;
6690         }
6691     }
6692
6693   /* [expr.new]
6694
6695      If no unambiguous matching deallocation function can be found,
6696      propagating the exception does not cause the object's memory to
6697      be freed.  */
6698   if (alloc_fn)
6699     {
6700       if ((complain & tf_warning)
6701           && !placement)
6702         warning (0, "no corresponding deallocation function for %qD",
6703                  alloc_fn);
6704       return NULL_TREE;
6705     }
6706
6707   if (complain & tf_error)
6708     error ("no suitable %<operator %s%> for %qT",
6709            OVL_OP_INFO (false, code)->name, type);
6710   return error_mark_node;
6711 }
6712
6713 /* Issue diagnostics about a disallowed access of DECL, using DIAG_DECL
6714    in the diagnostics.
6715
6716    If ISSUE_ERROR is true, then issue an error about the
6717    access, followed by a note showing the declaration.
6718    Otherwise, just show the note.  */
6719
6720 void
6721 complain_about_access (tree decl, tree diag_decl, bool issue_error)
6722 {
6723   if (TREE_PRIVATE (decl))
6724     {
6725       if (issue_error)
6726         error ("%q#D is private within this context", diag_decl);
6727       inform (DECL_SOURCE_LOCATION (diag_decl),
6728               "declared private here");
6729     }
6730   else if (TREE_PROTECTED (decl))
6731     {
6732       if (issue_error)
6733         error ("%q#D is protected within this context", diag_decl);
6734       inform (DECL_SOURCE_LOCATION (diag_decl),
6735               "declared protected here");
6736     }
6737   else
6738     {
6739       if (issue_error)
6740         error ("%q#D is inaccessible within this context", diag_decl);
6741       inform (DECL_SOURCE_LOCATION (diag_decl), "declared here");
6742     }
6743 }
6744
6745 /* If the current scope isn't allowed to access DECL along
6746    BASETYPE_PATH, give an error.  The most derived class in
6747    BASETYPE_PATH is the one used to qualify DECL. DIAG_DECL is
6748    the declaration to use in the error diagnostic.  */
6749
6750 bool
6751 enforce_access (tree basetype_path, tree decl, tree diag_decl,
6752                 tsubst_flags_t complain, access_failure_info *afi)
6753 {
6754   gcc_assert (TREE_CODE (basetype_path) == TREE_BINFO);
6755
6756   if (flag_new_inheriting_ctors
6757       && DECL_INHERITED_CTOR (decl))
6758     {
6759       /* 7.3.3/18: The additional constructors are accessible if they would be
6760          accessible when used to construct an object of the corresponding base
6761          class.  */
6762       decl = strip_inheriting_ctors (decl);
6763       basetype_path = lookup_base (basetype_path, DECL_CONTEXT (decl),
6764                                    ba_any, NULL, complain);
6765     }
6766
6767   if (!accessible_p (basetype_path, decl, true))
6768     {
6769       if (flag_new_inheriting_ctors)
6770         diag_decl = strip_inheriting_ctors (diag_decl);
6771       if (complain & tf_error)
6772         complain_about_access (decl, diag_decl, true);
6773       if (afi)
6774         afi->record_access_failure (basetype_path, decl, diag_decl);
6775       return false;
6776     }
6777
6778   return true;
6779 }
6780
6781 /* Initialize a temporary of type TYPE with EXPR.  The FLAGS are a
6782    bitwise or of LOOKUP_* values.  If any errors are warnings are
6783    generated, set *DIAGNOSTIC_FN to "error" or "warning",
6784    respectively.  If no diagnostics are generated, set *DIAGNOSTIC_FN
6785    to NULL.  */
6786
6787 static tree
6788 build_temp (tree expr, tree type, int flags,
6789             diagnostic_t *diagnostic_kind, tsubst_flags_t complain)
6790 {
6791   int savew, savee;
6792
6793   *diagnostic_kind = DK_UNSPECIFIED;
6794
6795   /* If the source is a packed field, calling the copy constructor will require
6796      binding the field to the reference parameter to the copy constructor, and
6797      we'll end up with an infinite loop.  If we can use a bitwise copy, then
6798      do that now.  */
6799   if ((lvalue_kind (expr) & clk_packed)
6800       && CLASS_TYPE_P (TREE_TYPE (expr))
6801       && !type_has_nontrivial_copy_init (TREE_TYPE (expr)))
6802     return get_target_expr_sfinae (expr, complain);
6803
6804   savew = warningcount + werrorcount, savee = errorcount;
6805   releasing_vec args (make_tree_vector_single (expr));
6806   expr = build_special_member_call (NULL_TREE, complete_ctor_identifier,
6807                                     &args, type, flags, complain);
6808   if (warningcount + werrorcount > savew)
6809     *diagnostic_kind = DK_WARNING;
6810   else if (errorcount > savee)
6811     *diagnostic_kind = DK_ERROR;
6812   return expr;
6813 }
6814
6815 /* Get any location for EXPR, falling back to input_location.
6816
6817    If the result is in a system header and is the virtual location for
6818    a token coming from the expansion of a macro, unwind it to the
6819    location of the expansion point of the macro (e.g. to avoid the
6820    diagnostic being suppressed for expansions of NULL where "NULL" is
6821    in a system header).  */
6822
6823 static location_t
6824 get_location_for_expr_unwinding_for_system_header (tree expr)
6825 {
6826   location_t loc = EXPR_LOC_OR_LOC (expr, input_location);
6827   loc = expansion_point_location_if_in_system_header (loc);
6828   return loc;
6829 }
6830
6831 /* Perform warnings about peculiar, but valid, conversions from/to NULL.
6832    Also handle a subset of zero as null warnings.
6833    EXPR is implicitly converted to type TOTYPE.
6834    FN and ARGNUM are used for diagnostics.  */
6835
6836 static void
6837 conversion_null_warnings (tree totype, tree expr, tree fn, int argnum)
6838 {
6839   /* Issue warnings about peculiar, but valid, uses of NULL.  */
6840   if (TREE_CODE (totype) != BOOLEAN_TYPE
6841       && ARITHMETIC_TYPE_P (totype)
6842       && null_node_p (expr))
6843     {
6844       location_t loc = get_location_for_expr_unwinding_for_system_header (expr);
6845       if (fn)
6846         {
6847           auto_diagnostic_group d;
6848           if (warning_at (loc, OPT_Wconversion_null,
6849                           "passing NULL to non-pointer argument %P of %qD",
6850                           argnum, fn))
6851             inform (get_fndecl_argument_location (fn, argnum),
6852                     "  declared here");
6853         }
6854       else
6855         warning_at (loc, OPT_Wconversion_null,
6856                     "converting to non-pointer type %qT from NULL", totype);
6857     }
6858
6859   /* Issue warnings if "false" is converted to a NULL pointer */
6860   else if (TREE_CODE (TREE_TYPE (expr)) == BOOLEAN_TYPE
6861            && TYPE_PTR_P (totype))
6862     {
6863       location_t loc = get_location_for_expr_unwinding_for_system_header (expr);
6864       if (fn)
6865         {
6866           auto_diagnostic_group d;
6867           if (warning_at (loc, OPT_Wconversion_null,
6868                           "converting %<false%> to pointer type for argument "
6869                           "%P of %qD", argnum, fn))
6870             inform (get_fndecl_argument_location (fn, argnum),
6871                     "  declared here");
6872         }
6873       else
6874         warning_at (loc, OPT_Wconversion_null,
6875                     "converting %<false%> to pointer type %qT", totype);
6876     }
6877   /* Handle zero as null pointer warnings for cases other
6878      than EQ_EXPR and NE_EXPR */
6879   else if ((TYPE_PTR_OR_PTRMEM_P (totype) || NULLPTR_TYPE_P (totype))
6880            && null_ptr_cst_p (expr))
6881     {
6882       location_t loc = get_location_for_expr_unwinding_for_system_header (expr);
6883       maybe_warn_zero_as_null_pointer_constant (expr, loc);
6884     }
6885 }
6886
6887 /* We gave a diagnostic during a conversion.  If this was in the second
6888    standard conversion sequence of a user-defined conversion sequence, say
6889    which user-defined conversion.  */
6890
6891 static void
6892 maybe_print_user_conv_context (conversion *convs)
6893 {
6894   if (convs->user_conv_p)
6895     for (conversion *t = convs; t; t = next_conversion (t))
6896       if (t->kind == ck_user)
6897         {
6898           print_z_candidate (0, N_("  after user-defined conversion:"),
6899                              t->cand);
6900           break;
6901         }
6902 }
6903
6904 /* Locate the parameter with the given index within FNDECL.
6905    ARGNUM is zero based, -1 indicates the `this' argument of a method.
6906    Return the location of the FNDECL itself if there are problems.  */
6907
6908 location_t
6909 get_fndecl_argument_location (tree fndecl, int argnum)
6910 {
6911   /* The locations of implicitly-declared functions are likely to be
6912      more meaningful than those of their parameters.  */
6913   if (DECL_ARTIFICIAL (fndecl))
6914     return DECL_SOURCE_LOCATION (fndecl);
6915
6916   int i;
6917   tree param;
6918
6919   /* Locate param by index within DECL_ARGUMENTS (fndecl).  */
6920   for (i = 0, param = FUNCTION_FIRST_USER_PARM (fndecl);
6921        i < argnum && param;
6922        i++, param = TREE_CHAIN (param))
6923     ;
6924
6925   /* If something went wrong (e.g. if we have a builtin and thus no arguments),
6926      return the location of FNDECL.  */
6927   if (param == NULL)
6928     return DECL_SOURCE_LOCATION (fndecl);
6929
6930   return DECL_SOURCE_LOCATION (param);
6931 }
6932
6933 /* If FNDECL is non-NULL, issue a note highlighting ARGNUM
6934    within its declaration (or the fndecl itself if something went
6935    wrong).  */
6936
6937 void
6938 maybe_inform_about_fndecl_for_bogus_argument_init (tree fn, int argnum)
6939 {
6940   if (fn)
6941     inform (get_fndecl_argument_location (fn, argnum),
6942             "  initializing argument %P of %qD", argnum, fn);
6943 }
6944
6945 /* Perform the conversions in CONVS on the expression EXPR.  FN and
6946    ARGNUM are used for diagnostics.  ARGNUM is zero based, -1
6947    indicates the `this' argument of a method.  INNER is nonzero when
6948    being called to continue a conversion chain. It is negative when a
6949    reference binding will be applied, positive otherwise.  If
6950    ISSUE_CONVERSION_WARNINGS is true, warnings about suspicious
6951    conversions will be emitted if appropriate.  If C_CAST_P is true,
6952    this conversion is coming from a C-style cast; in that case,
6953    conversions to inaccessible bases are permitted.  */
6954
6955 static tree
6956 convert_like_real (conversion *convs, tree expr, tree fn, int argnum,
6957                    bool issue_conversion_warnings,
6958                    bool c_cast_p, tsubst_flags_t complain)
6959 {
6960   tree totype = convs->type;
6961   diagnostic_t diag_kind;
6962   int flags;
6963   location_t loc = cp_expr_loc_or_input_loc (expr);
6964
6965   if (convs->bad_p && !(complain & tf_error))
6966     return error_mark_node;
6967
6968   if (convs->bad_p
6969       && convs->kind != ck_user
6970       && convs->kind != ck_list
6971       && convs->kind != ck_ambig
6972       && (convs->kind != ck_ref_bind
6973           || (convs->user_conv_p && next_conversion (convs)->bad_p))
6974       && (convs->kind != ck_rvalue
6975           || SCALAR_TYPE_P (totype))
6976       && convs->kind != ck_base)
6977     {
6978       bool complained = false;
6979       conversion *t = convs;
6980
6981       /* Give a helpful error if this is bad because of excess braces.  */
6982       if (BRACE_ENCLOSED_INITIALIZER_P (expr)
6983           && SCALAR_TYPE_P (totype)
6984           && CONSTRUCTOR_NELTS (expr) > 0
6985           && BRACE_ENCLOSED_INITIALIZER_P (CONSTRUCTOR_ELT (expr, 0)->value))
6986         {
6987           complained = permerror (loc, "too many braces around initializer "
6988                                   "for %qT", totype);
6989           while (BRACE_ENCLOSED_INITIALIZER_P (expr)
6990                  && CONSTRUCTOR_NELTS (expr) == 1)
6991             expr = CONSTRUCTOR_ELT (expr, 0)->value;
6992         }
6993
6994       /* Give a helpful error if this is bad because a conversion to bool
6995          from std::nullptr_t requires direct-initialization.  */
6996       if (NULLPTR_TYPE_P (TREE_TYPE (expr))
6997           && TREE_CODE (totype) == BOOLEAN_TYPE)
6998         complained = permerror (loc, "converting to %qH from %qI requires "
6999                                 "direct-initialization",
7000                                 totype, TREE_TYPE (expr));
7001
7002       for (; t ; t = next_conversion (t))
7003         {
7004           if (t->kind == ck_user && t->cand->reason)
7005             {
7006               auto_diagnostic_group d;
7007               complained = permerror (loc, "invalid user-defined conversion "
7008                                       "from %qH to %qI", TREE_TYPE (expr),
7009                                       totype);
7010               if (complained)
7011                 print_z_candidate (loc, N_("candidate is:"), t->cand);
7012               expr = convert_like_real (t, expr, fn, argnum,
7013                                         /*issue_conversion_warnings=*/false,
7014                                         /*c_cast_p=*/false,
7015                                         complain);
7016               if (convs->kind == ck_ref_bind)
7017                 expr = convert_to_reference (totype, expr, CONV_IMPLICIT,
7018                                              LOOKUP_NORMAL, NULL_TREE,
7019                                              complain);
7020               else
7021                 expr = cp_convert (totype, expr, complain);
7022               if (complained)
7023                 maybe_inform_about_fndecl_for_bogus_argument_init (fn, argnum);
7024               return expr;
7025             }
7026           else if (t->kind == ck_user || !t->bad_p)
7027             {
7028               expr = convert_like_real (t, expr, fn, argnum,
7029                                         /*issue_conversion_warnings=*/false,
7030                                         /*c_cast_p=*/false,
7031                                         complain);
7032               break;
7033             }
7034           else if (t->kind == ck_ambig)
7035             return convert_like_real (t, expr, fn, argnum,
7036                                       /*issue_conversion_warnings=*/false,
7037                                       /*c_cast_p=*/false,
7038                                       complain);
7039           else if (t->kind == ck_identity)
7040             break;
7041         }
7042       if (!complained)
7043         {
7044           range_label_for_type_mismatch label (TREE_TYPE (expr), totype);
7045           gcc_rich_location richloc (loc, &label);
7046           complained = permerror (&richloc,
7047                                   "invalid conversion from %qH to %qI",
7048                                   TREE_TYPE (expr), totype);
7049         }
7050       if (complained)
7051         maybe_inform_about_fndecl_for_bogus_argument_init (fn, argnum);
7052
7053       return cp_convert (totype, expr, complain);
7054     }
7055
7056   if (issue_conversion_warnings && (complain & tf_warning))
7057     conversion_null_warnings (totype, expr, fn, argnum);
7058
7059   switch (convs->kind)
7060     {
7061     case ck_user:
7062       {
7063         struct z_candidate *cand = convs->cand;
7064
7065         if (cand == NULL)
7066           /* We chose the surrogate function from add_conv_candidate, now we
7067              actually need to build the conversion.  */
7068           cand = build_user_type_conversion_1 (totype, expr,
7069                                                LOOKUP_NO_CONVERSION, complain);
7070
7071         tree convfn = cand->fn;
7072
7073         /* When converting from an init list we consider explicit
7074            constructors, but actually trying to call one is an error.  */
7075         if (DECL_NONCONVERTING_P (convfn) && DECL_CONSTRUCTOR_P (convfn)
7076             && BRACE_ENCLOSED_INITIALIZER_P (expr)
7077             /* Unless this is for direct-list-initialization.  */
7078             && (!CONSTRUCTOR_IS_DIRECT_INIT (expr) || convs->need_temporary_p)
7079             /* And in C++98 a default constructor can't be explicit.  */
7080             && cxx_dialect >= cxx11)
7081           {
7082             if (!(complain & tf_error))
7083               return error_mark_node;
7084             location_t loc = location_of (expr);
7085             if (CONSTRUCTOR_NELTS (expr) == 0
7086                 && FUNCTION_FIRST_USER_PARMTYPE (convfn) != void_list_node)
7087               {
7088                 auto_diagnostic_group d;
7089                 if (pedwarn (loc, 0, "converting to %qT from initializer list "
7090                              "would use explicit constructor %qD",
7091                              totype, convfn))
7092                   inform (loc, "in C++11 and above a default constructor "
7093                           "can be explicit");
7094               }
7095             else
7096               error ("converting to %qT from initializer list would use "
7097                      "explicit constructor %qD", totype, convfn);
7098           }
7099
7100         /* If we're initializing from {}, it's value-initialization.  */
7101         if (BRACE_ENCLOSED_INITIALIZER_P (expr)
7102             && CONSTRUCTOR_NELTS (expr) == 0
7103             && TYPE_HAS_DEFAULT_CONSTRUCTOR (totype)
7104             && !processing_template_decl)
7105           {
7106             bool direct = CONSTRUCTOR_IS_DIRECT_INIT (expr);
7107             if (abstract_virtuals_error_sfinae (NULL_TREE, totype, complain))
7108               return error_mark_node;
7109             expr = build_value_init (totype, complain);
7110             expr = get_target_expr_sfinae (expr, complain);
7111             if (expr != error_mark_node)
7112               {
7113                 TARGET_EXPR_LIST_INIT_P (expr) = true;
7114                 TARGET_EXPR_DIRECT_INIT_P (expr) = direct;
7115               }
7116             return expr;
7117           }
7118
7119         /* We don't know here whether EXPR is being used as an lvalue or
7120            rvalue, but we know it's read.  */
7121         mark_exp_read (expr);
7122
7123         /* Pass LOOKUP_NO_CONVERSION so rvalue/base handling knows not to allow
7124            any more UDCs.  */
7125         expr = build_over_call (cand, LOOKUP_NORMAL|LOOKUP_NO_CONVERSION,
7126                                 complain);
7127
7128         /* If this is a constructor or a function returning an aggr type,
7129            we need to build up a TARGET_EXPR.  */
7130         if (DECL_CONSTRUCTOR_P (convfn))
7131           {
7132             expr = build_cplus_new (totype, expr, complain);
7133
7134             /* Remember that this was list-initialization.  */
7135             if (convs->check_narrowing && expr != error_mark_node)
7136               TARGET_EXPR_LIST_INIT_P (expr) = true;
7137           }
7138
7139         return expr;
7140       }
7141     case ck_identity:
7142       if (BRACE_ENCLOSED_INITIALIZER_P (expr))
7143         {
7144           int nelts = CONSTRUCTOR_NELTS (expr);
7145           if (nelts == 0)
7146             expr = build_value_init (totype, complain);
7147           else if (nelts == 1)
7148             expr = CONSTRUCTOR_ELT (expr, 0)->value;
7149           else
7150             gcc_unreachable ();
7151         }
7152       expr = mark_use (expr, /*rvalue_p=*/!convs->rvaluedness_matches_p,
7153                        /*read_p=*/true, UNKNOWN_LOCATION,
7154                        /*reject_builtin=*/true);
7155
7156       if (type_unknown_p (expr))
7157         expr = instantiate_type (totype, expr, complain);
7158       if (expr == null_node
7159           && INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (totype))
7160         /* If __null has been converted to an integer type, we do not want to
7161            continue to warn about uses of EXPR as an integer, rather than as a
7162            pointer.  */
7163         expr = build_int_cst (totype, 0);
7164       return expr;
7165     case ck_ambig:
7166       /* We leave bad_p off ck_ambig because overload resolution considers
7167          it valid, it just fails when we try to perform it.  So we need to
7168          check complain here, too.  */
7169       if (complain & tf_error)
7170         {
7171           /* Call build_user_type_conversion again for the error.  */
7172           int flags = (convs->need_temporary_p
7173                        ? LOOKUP_IMPLICIT : LOOKUP_NORMAL);
7174           build_user_type_conversion (totype, convs->u.expr, flags, complain);
7175           gcc_assert (seen_error ());
7176           maybe_inform_about_fndecl_for_bogus_argument_init (fn, argnum);
7177         }
7178       return error_mark_node;
7179
7180     case ck_list:
7181       {
7182         /* Conversion to std::initializer_list<T>.  */
7183         tree elttype = TREE_VEC_ELT (CLASSTYPE_TI_ARGS (totype), 0);
7184         unsigned len = CONSTRUCTOR_NELTS (expr);
7185         tree array;
7186
7187         if (len)
7188           {
7189             tree val; unsigned ix;
7190
7191             tree new_ctor = build_constructor (init_list_type_node, NULL);
7192
7193             /* Convert all the elements.  */
7194             FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (expr), ix, val)
7195               {
7196                 tree sub = convert_like_real (convs->u.list[ix], val, fn,
7197                                               argnum, false, false, complain);
7198                 if (sub == error_mark_node)
7199                   return sub;
7200                 if (!BRACE_ENCLOSED_INITIALIZER_P (val)
7201                     && !check_narrowing (TREE_TYPE (sub), val, complain))
7202                   return error_mark_node;
7203                 CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (new_ctor),
7204                                         NULL_TREE, sub);
7205                 if (!TREE_CONSTANT (sub))
7206                   TREE_CONSTANT (new_ctor) = false;
7207               }
7208             /* Build up the array.  */
7209             elttype = cp_build_qualified_type
7210               (elttype, cp_type_quals (elttype) | TYPE_QUAL_CONST);
7211             array = build_array_of_n_type (elttype, len);
7212             array = finish_compound_literal (array, new_ctor, complain);
7213             /* Take the address explicitly rather than via decay_conversion
7214                to avoid the error about taking the address of a temporary.  */
7215             array = cp_build_addr_expr (array, complain);
7216           }
7217         else
7218           array = nullptr_node;
7219
7220         array = cp_convert (build_pointer_type (elttype), array, complain);
7221         if (array == error_mark_node)
7222           return error_mark_node;
7223
7224         /* Build up the initializer_list object.  Note: fail gracefully
7225            if the object cannot be completed because, for example, no
7226            definition is provided (c++/80956).  */
7227         totype = complete_type_or_maybe_complain (totype, NULL_TREE, complain);
7228         if (!totype)
7229           return error_mark_node;
7230         tree field = next_initializable_field (TYPE_FIELDS (totype));
7231         vec<constructor_elt, va_gc> *vec = NULL;
7232         CONSTRUCTOR_APPEND_ELT (vec, field, array);
7233         field = next_initializable_field (DECL_CHAIN (field));
7234         CONSTRUCTOR_APPEND_ELT (vec, field, size_int (len));
7235         tree new_ctor = build_constructor (totype, vec);
7236         return get_target_expr_sfinae (new_ctor, complain);
7237       }
7238
7239     case ck_aggr:
7240       if (TREE_CODE (totype) == COMPLEX_TYPE)
7241         {
7242           tree real = CONSTRUCTOR_ELT (expr, 0)->value;
7243           tree imag = CONSTRUCTOR_ELT (expr, 1)->value;
7244           real = perform_implicit_conversion (TREE_TYPE (totype),
7245                                               real, complain);
7246           imag = perform_implicit_conversion (TREE_TYPE (totype),
7247                                               imag, complain);
7248           expr = build2 (COMPLEX_EXPR, totype, real, imag);
7249           return expr;
7250         }
7251       expr = reshape_init (totype, expr, complain);
7252       expr = get_target_expr_sfinae (digest_init (totype, expr, complain),
7253                                      complain);
7254       if (expr != error_mark_node)
7255         TARGET_EXPR_LIST_INIT_P (expr) = true;
7256       return expr;
7257
7258     default:
7259       break;
7260     };
7261
7262   expr = convert_like_real (next_conversion (convs), expr, fn, argnum,
7263                             convs->kind == ck_ref_bind
7264                             ? issue_conversion_warnings : false, 
7265                             c_cast_p, complain);
7266   if (expr == error_mark_node)
7267     return error_mark_node;
7268
7269   switch (convs->kind)
7270     {
7271     case ck_rvalue:
7272       expr = decay_conversion (expr, complain);
7273       if (expr == error_mark_node)
7274         {
7275           if (complain & tf_error)
7276             {
7277               auto_diagnostic_group d;
7278               maybe_print_user_conv_context (convs);
7279               maybe_inform_about_fndecl_for_bogus_argument_init (fn, argnum);
7280             }
7281           return error_mark_node;
7282         }
7283
7284       if (! MAYBE_CLASS_TYPE_P (totype))
7285         return expr;
7286
7287       /* Don't introduce copies when passing arguments along to the inherited
7288          constructor.  */
7289       if (current_function_decl
7290           && flag_new_inheriting_ctors
7291           && DECL_INHERITED_CTOR (current_function_decl))
7292         return expr;
7293
7294       if (TREE_CODE (expr) == TARGET_EXPR
7295           && TARGET_EXPR_LIST_INIT_P (expr))
7296         /* Copy-list-initialization doesn't actually involve a copy.  */
7297         return expr;
7298
7299       /* Fall through.  */
7300     case ck_base:
7301       if (convs->kind == ck_base && !convs->need_temporary_p)
7302         {
7303           /* We are going to bind a reference directly to a base-class
7304              subobject of EXPR.  */
7305           /* Build an expression for `*((base*) &expr)'.  */
7306           expr = convert_to_base (expr, totype,
7307                                   !c_cast_p, /*nonnull=*/true, complain);
7308           return expr;
7309         }
7310
7311       /* Copy-initialization where the cv-unqualified version of the source
7312          type is the same class as, or a derived class of, the class of the
7313          destination [is treated as direct-initialization].  [dcl.init] */
7314       flags = LOOKUP_NORMAL;
7315       if (convs->user_conv_p)
7316         /* This conversion is being done in the context of a user-defined
7317            conversion (i.e. the second step of copy-initialization), so
7318            don't allow any more.  */
7319         flags |= LOOKUP_NO_CONVERSION;
7320       else
7321         flags |= LOOKUP_ONLYCONVERTING;
7322       if (convs->rvaluedness_matches_p)
7323         /* standard_conversion got LOOKUP_PREFER_RVALUE.  */
7324         flags |= LOOKUP_PREFER_RVALUE;
7325       expr = build_temp (expr, totype, flags, &diag_kind, complain);
7326       if (diag_kind && complain)
7327         {
7328           auto_diagnostic_group d;
7329           maybe_print_user_conv_context (convs);
7330           maybe_inform_about_fndecl_for_bogus_argument_init (fn, argnum);
7331         }
7332
7333       return build_cplus_new (totype, expr, complain);
7334
7335     case ck_ref_bind:
7336       {
7337         tree ref_type = totype;
7338
7339         if (convs->bad_p && !next_conversion (convs)->bad_p)
7340           {
7341             tree extype = TREE_TYPE (expr);
7342             auto_diagnostic_group d;
7343             if (TYPE_REF_IS_RVALUE (ref_type)
7344                 && lvalue_p (expr))
7345               error_at (loc, "cannot bind rvalue reference of type %qH to "
7346                         "lvalue of type %qI", totype, extype);
7347             else if (!TYPE_REF_IS_RVALUE (ref_type) && !lvalue_p (expr)
7348                      && !CP_TYPE_CONST_NON_VOLATILE_P (TREE_TYPE (ref_type)))
7349               error_at (loc, "cannot bind non-const lvalue reference of "
7350                         "type %qH to an rvalue of type %qI", totype, extype);
7351             else if (!reference_compatible_p (TREE_TYPE (totype), extype))
7352               error_at (loc, "binding reference of type %qH to %qI "
7353                         "discards qualifiers", totype, extype);
7354             else
7355               gcc_unreachable ();
7356             maybe_print_user_conv_context (convs);
7357             maybe_inform_about_fndecl_for_bogus_argument_init (fn, argnum);
7358
7359             return error_mark_node;
7360           }
7361
7362         /* If necessary, create a temporary. 
7363
7364            VA_ARG_EXPR and CONSTRUCTOR expressions are special cases
7365            that need temporaries, even when their types are reference
7366            compatible with the type of reference being bound, so the
7367            upcoming call to cp_build_addr_expr doesn't fail.  */
7368         if (convs->need_temporary_p
7369             || TREE_CODE (expr) == CONSTRUCTOR
7370             || TREE_CODE (expr) == VA_ARG_EXPR)
7371           {
7372             /* Otherwise, a temporary of type "cv1 T1" is created and
7373                initialized from the initializer expression using the rules
7374                for a non-reference copy-initialization (8.5).  */
7375
7376             tree type = TREE_TYPE (ref_type);
7377             cp_lvalue_kind lvalue = lvalue_kind (expr);
7378
7379             gcc_assert (same_type_ignoring_top_level_qualifiers_p
7380                         (type, next_conversion (convs)->type));
7381             if (!CP_TYPE_CONST_NON_VOLATILE_P (type)
7382                 && !TYPE_REF_IS_RVALUE (ref_type))
7383               {
7384                 /* If the reference is volatile or non-const, we
7385                    cannot create a temporary.  */
7386                 if (lvalue & clk_bitfield)
7387                   error_at (loc, "cannot bind bit-field %qE to %qT",
7388                             expr, ref_type);
7389                 else if (lvalue & clk_packed)
7390                   error_at (loc, "cannot bind packed field %qE to %qT",
7391                             expr, ref_type);
7392                 else
7393                   error_at (loc, "cannot bind rvalue %qE to %qT",
7394                             expr, ref_type);
7395                 return error_mark_node;
7396               }
7397             /* If the source is a packed field, and we must use a copy
7398                constructor, then building the target expr will require
7399                binding the field to the reference parameter to the
7400                copy constructor, and we'll end up with an infinite
7401                loop.  If we can use a bitwise copy, then we'll be
7402                OK.  */
7403             if ((lvalue & clk_packed)
7404                 && CLASS_TYPE_P (type)
7405                 && type_has_nontrivial_copy_init (type))
7406               {
7407                 error_at (loc, "cannot bind packed field %qE to %qT",
7408                           expr, ref_type);
7409                 return error_mark_node;
7410               }
7411             if (lvalue & clk_bitfield)
7412               {
7413                 expr = convert_bitfield_to_declared_type (expr);
7414                 expr = fold_convert (type, expr);
7415               }
7416             expr = build_target_expr_with_type (expr, type, complain);
7417           }
7418
7419         /* Take the address of the thing to which we will bind the
7420            reference.  */
7421         expr = cp_build_addr_expr (expr, complain);
7422         if (expr == error_mark_node)
7423           return error_mark_node;
7424
7425         /* Convert it to a pointer to the type referred to by the
7426            reference.  This will adjust the pointer if a derived to
7427            base conversion is being performed.  */
7428         expr = cp_convert (build_pointer_type (TREE_TYPE (ref_type)),
7429                            expr, complain);
7430         /* Convert the pointer to the desired reference type.  */
7431         return build_nop (ref_type, expr);
7432       }
7433
7434     case ck_lvalue:
7435       return decay_conversion (expr, complain);
7436
7437     case ck_fnptr:
7438       /* ??? Should the address of a transaction-safe pointer point to the TM
7439         clone, and this conversion look up the primary function?  */
7440       return build_nop (totype, expr);
7441
7442     case ck_qual:
7443       /* Warn about deprecated conversion if appropriate.  */
7444       if (complain & tf_warning)
7445         string_conv_p (totype, expr, 1);
7446       break;
7447
7448     case ck_ptr:
7449       if (convs->base_p)
7450         expr = convert_to_base (expr, totype, !c_cast_p,
7451                                 /*nonnull=*/false, complain);
7452       return build_nop (totype, expr);
7453
7454     case ck_pmem:
7455       return convert_ptrmem (totype, expr, /*allow_inverse_p=*/false,
7456                              c_cast_p, complain);
7457
7458     default:
7459       break;
7460     }
7461
7462   if (convs->check_narrowing
7463       && !check_narrowing (totype, expr, complain,
7464                            convs->check_narrowing_const_only))
7465     return error_mark_node;
7466
7467   warning_sentinel w (warn_zero_as_null_pointer_constant);
7468   if (issue_conversion_warnings)
7469     expr = cp_convert_and_check (totype, expr, complain);
7470   else
7471     expr = cp_convert (totype, expr, complain);
7472
7473   return expr;
7474 }
7475
7476 /* ARG is being passed to a varargs function.  Perform any conversions
7477    required.  Return the converted value.  */
7478
7479 tree
7480 convert_arg_to_ellipsis (tree arg, tsubst_flags_t complain)
7481 {
7482   tree arg_type;
7483   location_t loc = cp_expr_loc_or_input_loc (arg);
7484
7485   /* [expr.call]
7486
7487      The lvalue-to-rvalue, array-to-pointer, and function-to-pointer
7488      standard conversions are performed.  */
7489   arg = decay_conversion (arg, complain);
7490   arg_type = TREE_TYPE (arg);
7491   /* [expr.call]
7492
7493      If the argument has integral or enumeration type that is subject
7494      to the integral promotions (_conv.prom_), or a floating-point
7495      type that is subject to the floating-point promotion
7496      (_conv.fpprom_), the value of the argument is converted to the
7497      promoted type before the call.  */
7498   if (TREE_CODE (arg_type) == REAL_TYPE
7499       && (TYPE_PRECISION (arg_type)
7500           < TYPE_PRECISION (double_type_node))
7501       && !DECIMAL_FLOAT_MODE_P (TYPE_MODE (arg_type)))
7502     {
7503       if ((complain & tf_warning)
7504           && warn_double_promotion && !c_inhibit_evaluation_warnings)
7505         warning_at (loc, OPT_Wdouble_promotion,
7506                     "implicit conversion from %qH to %qI when passing "
7507                     "argument to function",
7508                     arg_type, double_type_node);
7509       arg = convert_to_real_nofold (double_type_node, arg);
7510     }
7511   else if (NULLPTR_TYPE_P (arg_type))
7512     arg = null_pointer_node;
7513   else if (INTEGRAL_OR_ENUMERATION_TYPE_P (arg_type))
7514     {
7515       if (SCOPED_ENUM_P (arg_type))
7516         {
7517           tree prom = cp_convert (ENUM_UNDERLYING_TYPE (arg_type), arg,
7518                                   complain);
7519           prom = cp_perform_integral_promotions (prom, complain);
7520           if (abi_version_crosses (6)
7521               && TYPE_MODE (TREE_TYPE (prom)) != TYPE_MODE (arg_type)
7522               && (complain & tf_warning))
7523             warning_at (loc, OPT_Wabi, "scoped enum %qT passed through %<...%>"
7524                         "as %qT before %<-fabi-version=6%>, %qT after",
7525                         arg_type,
7526                         TREE_TYPE (prom), ENUM_UNDERLYING_TYPE (arg_type));
7527           if (!abi_version_at_least (6))
7528             arg = prom;
7529         }
7530       else
7531         arg = cp_perform_integral_promotions (arg, complain);
7532     }
7533
7534   arg = require_complete_type_sfinae (arg, complain);
7535   arg_type = TREE_TYPE (arg);
7536
7537   if (arg != error_mark_node
7538       /* In a template (or ill-formed code), we can have an incomplete type
7539          even after require_complete_type_sfinae, in which case we don't know
7540          whether it has trivial copy or not.  */
7541       && COMPLETE_TYPE_P (arg_type)
7542       && !cp_unevaluated_operand)
7543     {
7544       /* [expr.call] 5.2.2/7:
7545          Passing a potentially-evaluated argument of class type (Clause 9)
7546          with a non-trivial copy constructor or a non-trivial destructor
7547          with no corresponding parameter is conditionally-supported, with
7548          implementation-defined semantics.
7549
7550          We support it as pass-by-invisible-reference, just like a normal
7551          value parameter.
7552
7553          If the call appears in the context of a sizeof expression,
7554          it is not potentially-evaluated.  */
7555       if (type_has_nontrivial_copy_init (arg_type)
7556           || TYPE_HAS_NONTRIVIAL_DESTRUCTOR (arg_type))
7557         {
7558           arg = force_rvalue (arg, complain);
7559           if (complain & tf_warning)
7560             warning (OPT_Wconditionally_supported,
7561                      "passing objects of non-trivially-copyable "
7562                      "type %q#T through %<...%> is conditionally supported",
7563                      arg_type);
7564           return build1 (ADDR_EXPR, build_reference_type (arg_type), arg);
7565         }
7566       /* Build up a real lvalue-to-rvalue conversion in case the
7567          copy constructor is trivial but not callable.  */
7568       else if (CLASS_TYPE_P (arg_type))
7569         force_rvalue (arg, complain);
7570
7571     }
7572
7573   return arg;
7574 }
7575
7576 /* va_arg (EXPR, TYPE) is a builtin. Make sure it is not abused.  */
7577
7578 tree
7579 build_x_va_arg (location_t loc, tree expr, tree type)
7580 {
7581   if (processing_template_decl)
7582     {
7583       tree r = build_min (VA_ARG_EXPR, type, expr);
7584       SET_EXPR_LOCATION (r, loc);
7585       return r;
7586     }
7587
7588   type = complete_type_or_else (type, NULL_TREE);
7589
7590   if (expr == error_mark_node || !type)
7591     return error_mark_node;
7592
7593   expr = mark_lvalue_use (expr);
7594
7595   if (TYPE_REF_P (type))
7596     {
7597       error ("cannot receive reference type %qT through %<...%>", type);
7598       return error_mark_node;
7599     }
7600
7601   if (type_has_nontrivial_copy_init (type)
7602       || TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
7603     {
7604       /* conditionally-supported behavior [expr.call] 5.2.2/7.  Let's treat
7605          it as pass by invisible reference.  */
7606       warning_at (loc, OPT_Wconditionally_supported,
7607                  "receiving objects of non-trivially-copyable type %q#T "
7608                  "through %<...%> is conditionally-supported", type);
7609
7610       tree ref = cp_build_reference_type (type, false);
7611       expr = build_va_arg (loc, expr, ref);
7612       return convert_from_reference (expr);
7613     }
7614
7615   tree ret = build_va_arg (loc, expr, type);
7616   if (CLASS_TYPE_P (type))
7617     /* Wrap the VA_ARG_EXPR in a TARGET_EXPR now so other code doesn't need to
7618        know how to handle it.  */
7619     ret = get_target_expr (ret);
7620   return ret;
7621 }
7622
7623 /* TYPE has been given to va_arg.  Apply the default conversions which
7624    would have happened when passed via ellipsis.  Return the promoted
7625    type, or the passed type if there is no change.  */
7626
7627 tree
7628 cxx_type_promotes_to (tree type)
7629 {
7630   tree promote;
7631
7632   /* Perform the array-to-pointer and function-to-pointer
7633      conversions.  */
7634   type = type_decays_to (type);
7635
7636   promote = type_promotes_to (type);
7637   if (same_type_p (type, promote))
7638     promote = type;
7639
7640   return promote;
7641 }
7642
7643 /* ARG is a default argument expression being passed to a parameter of
7644    the indicated TYPE, which is a parameter to FN.  PARMNUM is the
7645    zero-based argument number.  Do any required conversions.  Return
7646    the converted value.  */
7647
7648 static GTY(()) vec<tree, va_gc> *default_arg_context;
7649 void
7650 push_defarg_context (tree fn)
7651 { vec_safe_push (default_arg_context, fn); }
7652
7653 void
7654 pop_defarg_context (void)
7655 { default_arg_context->pop (); }
7656
7657 tree
7658 convert_default_arg (tree type, tree arg, tree fn, int parmnum,
7659                      tsubst_flags_t complain)
7660 {
7661   int i;
7662   tree t;
7663
7664   /* See through clones.  */
7665   fn = DECL_ORIGIN (fn);
7666   /* And inheriting ctors.  */
7667   if (flag_new_inheriting_ctors)
7668     fn = strip_inheriting_ctors (fn);
7669
7670   /* Detect recursion.  */
7671   FOR_EACH_VEC_SAFE_ELT (default_arg_context, i, t)
7672     if (t == fn)
7673       {
7674         if (complain & tf_error)
7675           error ("recursive evaluation of default argument for %q#D", fn);
7676         return error_mark_node;
7677       }
7678
7679   /* If the ARG is an unparsed default argument expression, the
7680      conversion cannot be performed.  */
7681   if (TREE_CODE (arg) == DEFERRED_PARSE)
7682     {
7683       if (complain & tf_error)
7684         error ("call to %qD uses the default argument for parameter %P, which "
7685                "is not yet defined", fn, parmnum);
7686       return error_mark_node;
7687     }
7688
7689   push_defarg_context (fn);
7690
7691   if (fn && DECL_TEMPLATE_INFO (fn))
7692     arg = tsubst_default_argument (fn, parmnum, type, arg, complain);
7693
7694   /* Due to:
7695
7696        [dcl.fct.default]
7697
7698        The names in the expression are bound, and the semantic
7699        constraints are checked, at the point where the default
7700        expressions appears.
7701
7702      we must not perform access checks here.  */
7703   push_deferring_access_checks (dk_no_check);
7704   /* We must make a copy of ARG, in case subsequent processing
7705      alters any part of it.  */
7706   arg = break_out_target_exprs (arg, /*clear location*/true);
7707
7708   arg = convert_for_initialization (0, type, arg, LOOKUP_IMPLICIT,
7709                                     ICR_DEFAULT_ARGUMENT, fn, parmnum,
7710                                     complain);
7711   arg = convert_for_arg_passing (type, arg, complain);
7712   pop_deferring_access_checks();
7713
7714   pop_defarg_context ();
7715
7716   return arg;
7717 }
7718
7719 /* Returns the type which will really be used for passing an argument of
7720    type TYPE.  */
7721
7722 tree
7723 type_passed_as (tree type)
7724 {
7725   /* Pass classes with copy ctors by invisible reference.  */
7726   if (TREE_ADDRESSABLE (type))
7727     {
7728       type = build_reference_type (type);
7729       /* There are no other pointers to this temporary.  */
7730       type = cp_build_qualified_type (type, TYPE_QUAL_RESTRICT);
7731     }
7732   else if (targetm.calls.promote_prototypes (NULL_TREE)
7733            && INTEGRAL_TYPE_P (type)
7734            && COMPLETE_TYPE_P (type)
7735            && tree_int_cst_lt (TYPE_SIZE (type), TYPE_SIZE (integer_type_node)))
7736     type = integer_type_node;
7737
7738   return type;
7739 }
7740
7741 /* Actually perform the appropriate conversion.  */
7742
7743 tree
7744 convert_for_arg_passing (tree type, tree val, tsubst_flags_t complain)
7745 {
7746   tree bitfield_type;
7747
7748   /* If VAL is a bitfield, then -- since it has already been converted
7749      to TYPE -- it cannot have a precision greater than TYPE.  
7750
7751      If it has a smaller precision, we must widen it here.  For
7752      example, passing "int f:3;" to a function expecting an "int" will
7753      not result in any conversion before this point.
7754
7755      If the precision is the same we must not risk widening.  For
7756      example, the COMPONENT_REF for a 32-bit "long long" bitfield will
7757      often have type "int", even though the C++ type for the field is
7758      "long long".  If the value is being passed to a function
7759      expecting an "int", then no conversions will be required.  But,
7760      if we call convert_bitfield_to_declared_type, the bitfield will
7761      be converted to "long long".  */
7762   bitfield_type = is_bitfield_expr_with_lowered_type (val);
7763   if (bitfield_type 
7764       && TYPE_PRECISION (TREE_TYPE (val)) < TYPE_PRECISION (type))
7765     val = convert_to_integer_nofold (TYPE_MAIN_VARIANT (bitfield_type), val);
7766
7767   if (val == error_mark_node)
7768     ;
7769   /* Pass classes with copy ctors by invisible reference.  */
7770   else if (TREE_ADDRESSABLE (type))
7771     val = build1 (ADDR_EXPR, build_reference_type (type), val);
7772   else if (targetm.calls.promote_prototypes (NULL_TREE)
7773            && INTEGRAL_TYPE_P (type)
7774            && COMPLETE_TYPE_P (type)
7775            && tree_int_cst_lt (TYPE_SIZE (type), TYPE_SIZE (integer_type_node)))
7776     val = cp_perform_integral_promotions (val, complain);
7777   if (complain & tf_warning)
7778     {
7779       if (warn_suggest_attribute_format)
7780         {
7781           tree rhstype = TREE_TYPE (val);
7782           const enum tree_code coder = TREE_CODE (rhstype);
7783           const enum tree_code codel = TREE_CODE (type);
7784           if ((codel == POINTER_TYPE || codel == REFERENCE_TYPE)
7785               && coder == codel
7786               && check_missing_format_attribute (type, rhstype))
7787             warning (OPT_Wsuggest_attribute_format,
7788                      "argument of function call might be a candidate "
7789                      "for a format attribute");
7790         }
7791       maybe_warn_parm_abi (type, cp_expr_loc_or_input_loc (val));
7792     }
7793
7794   if (complain & tf_warning)
7795     warn_for_address_or_pointer_of_packed_member (type, val);
7796
7797   return val;
7798 }
7799
7800 /* Returns non-zero iff FN is a function with magic varargs, i.e. ones for
7801    which just decay_conversion or no conversions at all should be done.
7802    This is true for some builtins which don't act like normal functions.
7803    Return 2 if no conversions at all should be done, 1 if just
7804    decay_conversion.  Return 3 for special treatment of the 3rd argument
7805    for __builtin_*_overflow_p.  */
7806
7807 int
7808 magic_varargs_p (tree fn)
7809 {
7810   if (DECL_BUILT_IN_CLASS (fn) == BUILT_IN_NORMAL)
7811     switch (DECL_FUNCTION_CODE (fn))
7812       {
7813       case BUILT_IN_CLASSIFY_TYPE:
7814       case BUILT_IN_CONSTANT_P:
7815       case BUILT_IN_NEXT_ARG:
7816       case BUILT_IN_VA_START:
7817         return 1;
7818
7819       case BUILT_IN_ADD_OVERFLOW_P:
7820       case BUILT_IN_SUB_OVERFLOW_P:
7821       case BUILT_IN_MUL_OVERFLOW_P:
7822         return 3;
7823
7824       default:;
7825         return lookup_attribute ("type generic",
7826                                  TYPE_ATTRIBUTES (TREE_TYPE (fn))) != 0;
7827       }
7828
7829   return 0;
7830 }
7831
7832 /* Returns the decl of the dispatcher function if FN is a function version.  */
7833
7834 tree
7835 get_function_version_dispatcher (tree fn)
7836 {
7837   tree dispatcher_decl = NULL;
7838
7839   gcc_assert (TREE_CODE (fn) == FUNCTION_DECL
7840               && DECL_FUNCTION_VERSIONED (fn));
7841
7842   gcc_assert (targetm.get_function_versions_dispatcher);
7843   dispatcher_decl = targetm.get_function_versions_dispatcher (fn);
7844
7845   if (dispatcher_decl == NULL)
7846     {
7847       error_at (input_location, "use of multiversioned function "
7848                                 "without a default");
7849       return NULL;
7850     }
7851
7852   retrofit_lang_decl (dispatcher_decl);
7853   gcc_assert (dispatcher_decl != NULL);
7854   return dispatcher_decl;
7855 }
7856
7857 /* fn is a function version dispatcher that is marked used. Mark all the 
7858    semantically identical function versions it will dispatch as used.  */
7859
7860 void
7861 mark_versions_used (tree fn)
7862 {
7863   struct cgraph_node *node;
7864   struct cgraph_function_version_info *node_v;
7865   struct cgraph_function_version_info *it_v;
7866
7867   gcc_assert (TREE_CODE (fn) == FUNCTION_DECL);
7868
7869   node = cgraph_node::get (fn);
7870   if (node == NULL)
7871     return;
7872
7873   gcc_assert (node->dispatcher_function);
7874
7875   node_v = node->function_version ();
7876   if (node_v == NULL)
7877     return;
7878
7879   /* All semantically identical versions are chained.  Traverse and mark each
7880      one of them as used.  */
7881   it_v = node_v->next;
7882   while (it_v != NULL)
7883     {
7884       mark_used (it_v->this_node->decl);
7885       it_v = it_v->next;
7886     }
7887 }
7888
7889 /* Build a call to "the copy constructor" for the type of A, even if it
7890    wouldn't be selected by normal overload resolution.  Used for
7891    diagnostics.  */
7892
7893 static tree
7894 call_copy_ctor (tree a, tsubst_flags_t complain)
7895 {
7896   tree ctype = TYPE_MAIN_VARIANT (TREE_TYPE (a));
7897   tree binfo = TYPE_BINFO (ctype);
7898   tree copy = get_copy_ctor (ctype, complain);
7899   copy = build_baselink (binfo, binfo, copy, NULL_TREE);
7900   tree ob = build_dummy_object (ctype);
7901   releasing_vec args (make_tree_vector_single (a));
7902   tree r = build_new_method_call (ob, copy, &args, NULL_TREE,
7903                                   LOOKUP_NORMAL, NULL, complain);
7904   return r;
7905 }
7906
7907 /* Return true iff T refers to a base field.  */
7908
7909 static bool
7910 is_base_field_ref (tree t)
7911 {
7912   STRIP_NOPS (t);
7913   if (TREE_CODE (t) == ADDR_EXPR)
7914     t = TREE_OPERAND (t, 0);
7915   if (TREE_CODE (t) == COMPONENT_REF)
7916     t = TREE_OPERAND (t, 1);
7917   if (TREE_CODE (t) == FIELD_DECL)
7918     return DECL_FIELD_IS_BASE (t);
7919   return false;
7920 }
7921
7922 /* We can't elide a copy from a function returning by value to a base
7923    subobject, as the callee might clobber tail padding.  Return true iff this
7924    could be that case.  */
7925
7926 static bool
7927 unsafe_copy_elision_p (tree target, tree exp)
7928 {
7929   /* Copy elision only happens with a TARGET_EXPR.  */
7930   if (TREE_CODE (exp) != TARGET_EXPR)
7931     return false;
7932   tree type = TYPE_MAIN_VARIANT (TREE_TYPE (exp));
7933   /* It's safe to elide the copy for a class with no tail padding.  */
7934   if (tree_int_cst_equal (TYPE_SIZE (type), CLASSTYPE_SIZE (type)))
7935     return false;
7936   /* It's safe to elide the copy if we aren't initializing a base object.  */
7937   if (!is_base_field_ref (target))
7938     return false;
7939   tree init = TARGET_EXPR_INITIAL (exp);
7940   /* build_compound_expr pushes COMPOUND_EXPR inside TARGET_EXPR.  */
7941   while (TREE_CODE (init) == COMPOUND_EXPR)
7942     init = TREE_OPERAND (init, 1);
7943   if (TREE_CODE (init) == COND_EXPR)
7944     {
7945       /* We'll end up copying from each of the arms of the COND_EXPR directly
7946          into the target, so look at them. */
7947       if (tree op = TREE_OPERAND (init, 1))
7948         if (unsafe_copy_elision_p (target, op))
7949           return true;
7950       return unsafe_copy_elision_p (target, TREE_OPERAND (init, 2));
7951     }
7952   return (TREE_CODE (init) == AGGR_INIT_EXPR
7953           && !AGGR_INIT_VIA_CTOR_P (init));
7954 }
7955
7956 /* True iff C is a conversion that binds a reference to a prvalue.  */
7957
7958 static bool
7959 conv_binds_ref_to_prvalue (conversion *c)
7960 {
7961   if (c->kind != ck_ref_bind)
7962     return false;
7963   if (c->need_temporary_p)
7964     return true;
7965
7966   c = next_conversion (c);
7967
7968   if (c->kind == ck_rvalue)
7969     return true;
7970   if (c->kind == ck_user && !TYPE_REF_P (c->type))
7971     return true;
7972   if (c->kind == ck_identity && c->u.expr
7973       && TREE_CODE (c->u.expr) == TARGET_EXPR)
7974     return true;
7975
7976   return false;
7977 }
7978
7979 /* Call the trivial destructor for INSTANCE, which can be either an lvalue of
7980    class type or a pointer to class type.  */
7981
7982 tree
7983 build_trivial_dtor_call (tree instance)
7984 {
7985   gcc_assert (!is_dummy_object (instance));
7986
7987   if (!flag_lifetime_dse)
7988     {
7989     no_clobber:
7990       return fold_convert (void_type_node, instance);
7991     }
7992
7993   if (INDIRECT_TYPE_P (TREE_TYPE (instance)))
7994     {
7995       if (VOID_TYPE_P (TREE_TYPE (TREE_TYPE (instance))))
7996         goto no_clobber;
7997       instance = cp_build_fold_indirect_ref (instance);
7998     }
7999
8000   /* A trivial destructor should still clobber the object.  */
8001   tree clobber = build_clobber (TREE_TYPE (instance));
8002   return build2 (MODIFY_EXPR, void_type_node,
8003                  instance, clobber);
8004 }
8005
8006 /* Subroutine of the various build_*_call functions.  Overload resolution
8007    has chosen a winning candidate CAND; build up a CALL_EXPR accordingly.
8008    ARGS is a TREE_LIST of the unconverted arguments to the call.  FLAGS is a
8009    bitmask of various LOOKUP_* flags which apply to the call itself.  */
8010
8011 static tree
8012 build_over_call (struct z_candidate *cand, int flags, tsubst_flags_t complain)
8013 {
8014   tree fn = cand->fn;
8015   const vec<tree, va_gc> *args = cand->args;
8016   tree first_arg = cand->first_arg;
8017   conversion **convs = cand->convs;
8018   conversion *conv;
8019   tree parm = TYPE_ARG_TYPES (TREE_TYPE (fn));
8020   int parmlen;
8021   tree val;
8022   int i = 0;
8023   int j = 0;
8024   unsigned int arg_index = 0;
8025   int is_method = 0;
8026   int nargs;
8027   tree *argarray;
8028   bool already_used = false;
8029
8030   /* In a template, there is no need to perform all of the work that
8031      is normally done.  We are only interested in the type of the call
8032      expression, i.e., the return type of the function.  Any semantic
8033      errors will be deferred until the template is instantiated.  */
8034   if (processing_template_decl)
8035     {
8036       tree expr, addr;
8037       tree return_type;
8038       const tree *argarray;
8039       unsigned int nargs;
8040
8041       if (undeduced_auto_decl (fn))
8042         mark_used (fn, complain);
8043       else
8044         /* Otherwise set TREE_USED for the benefit of -Wunused-function.
8045            See PR80598.  */
8046         TREE_USED (fn) = 1;
8047
8048       return_type = TREE_TYPE (TREE_TYPE (fn));
8049       nargs = vec_safe_length (args);
8050       if (first_arg == NULL_TREE)
8051         argarray = args->address ();
8052       else
8053         {
8054           tree *alcarray;
8055           unsigned int ix;
8056           tree arg;
8057
8058           ++nargs;
8059           alcarray = XALLOCAVEC (tree, nargs);
8060           alcarray[0] = build_this (first_arg);
8061           FOR_EACH_VEC_SAFE_ELT (args, ix, arg)
8062             alcarray[ix + 1] = arg;
8063           argarray = alcarray;
8064         }
8065
8066       addr = build_addr_func (fn, complain);
8067       if (addr == error_mark_node)
8068         return error_mark_node;
8069       expr = build_call_array_loc (input_location, return_type,
8070                                    addr, nargs, argarray);
8071       if (TREE_THIS_VOLATILE (fn) && cfun)
8072         current_function_returns_abnormally = 1;
8073       return convert_from_reference (expr);
8074     }
8075
8076   /* Give any warnings we noticed during overload resolution.  */
8077   if (cand->warnings && (complain & tf_warning))
8078     {
8079       struct candidate_warning *w;
8080       for (w = cand->warnings; w; w = w->next)
8081         joust (cand, w->loser, 1, complain);
8082     }
8083
8084   /* Core issue 2327: P0135 doesn't say how to handle the case where the
8085      argument to the copy constructor ends up being a prvalue after
8086      conversion.  Let's do the normal processing, but pretend we aren't
8087      actually using the copy constructor.  */
8088   bool force_elide = false;
8089   if (cxx_dialect >= cxx17
8090       && cand->num_convs == 1
8091       && DECL_COMPLETE_CONSTRUCTOR_P (fn)
8092       && (DECL_COPY_CONSTRUCTOR_P (fn)
8093           || DECL_MOVE_CONSTRUCTOR_P (fn))
8094       && conv_binds_ref_to_prvalue (convs[0]))
8095     {
8096       force_elide = true;
8097       goto not_really_used;
8098     }
8099
8100   /* OK, we're actually calling this inherited constructor; set its deletedness
8101      appropriately.  We can get away with doing this here because calling is
8102      the only way to refer to a constructor.  */
8103   if (DECL_INHERITED_CTOR (fn))
8104     deduce_inheriting_ctor (fn);
8105
8106   /* Make =delete work with SFINAE.  */
8107   if (DECL_DELETED_FN (fn))
8108     {
8109       if (complain & tf_error)
8110         mark_used (fn);
8111       return error_mark_node;
8112     }
8113
8114   if (DECL_FUNCTION_MEMBER_P (fn))
8115     {
8116       tree access_fn;
8117       /* If FN is a template function, two cases must be considered.
8118          For example:
8119
8120            struct A {
8121              protected:
8122                template <class T> void f();
8123            };
8124            template <class T> struct B {
8125              protected:
8126                void g();
8127            };
8128            struct C : A, B<int> {
8129              using A::f;        // #1
8130              using B<int>::g;   // #2
8131            };
8132
8133          In case #1 where `A::f' is a member template, DECL_ACCESS is
8134          recorded in the primary template but not in its specialization.
8135          We check access of FN using its primary template.
8136
8137          In case #2, where `B<int>::g' has a DECL_TEMPLATE_INFO simply
8138          because it is a member of class template B, DECL_ACCESS is
8139          recorded in the specialization `B<int>::g'.  We cannot use its
8140          primary template because `B<T>::g' and `B<int>::g' may have
8141          different access.  */
8142       if (DECL_TEMPLATE_INFO (fn)
8143           && DECL_MEMBER_TEMPLATE_P (DECL_TI_TEMPLATE (fn)))
8144         access_fn = DECL_TI_TEMPLATE (fn);
8145       else
8146         access_fn = fn;
8147       if (!perform_or_defer_access_check (cand->access_path, access_fn,
8148                                           fn, complain))
8149         return error_mark_node;
8150     }
8151
8152   /* If we're checking for implicit delete, don't bother with argument
8153      conversions.  */
8154   if (flags & LOOKUP_SPECULATIVE)
8155     {
8156       if (cand->viable == 1)
8157         return fn;
8158       else if (!(complain & tf_error))
8159         /* Reject bad conversions now.  */
8160         return error_mark_node;
8161       /* else continue to get conversion error.  */
8162     }
8163
8164  not_really_used:
8165
8166   /* N3276 magic doesn't apply to nested calls.  */
8167   tsubst_flags_t decltype_flag = (complain & tf_decltype);
8168   complain &= ~tf_decltype;
8169   /* No-Cleanup doesn't apply to nested calls either.  */
8170   tsubst_flags_t no_cleanup_complain = complain;
8171   complain &= ~tf_no_cleanup;
8172
8173   /* Find maximum size of vector to hold converted arguments.  */
8174   parmlen = list_length (parm);
8175   nargs = vec_safe_length (args) + (first_arg != NULL_TREE ? 1 : 0);
8176   if (parmlen > nargs)
8177     nargs = parmlen;
8178   argarray = XALLOCAVEC (tree, nargs);
8179
8180   /* The implicit parameters to a constructor are not considered by overload
8181      resolution, and must be of the proper type.  */
8182   if (DECL_CONSTRUCTOR_P (fn))
8183     {
8184       tree object_arg;
8185       if (first_arg != NULL_TREE)
8186         {
8187           object_arg = first_arg;
8188           first_arg = NULL_TREE;
8189         }
8190       else
8191         {
8192           object_arg = (*args)[arg_index];
8193           ++arg_index;
8194         }
8195       argarray[j++] = build_this (object_arg);
8196       parm = TREE_CHAIN (parm);
8197       /* We should never try to call the abstract constructor.  */
8198       gcc_assert (!DECL_HAS_IN_CHARGE_PARM_P (fn));
8199
8200       if (DECL_HAS_VTT_PARM_P (fn))
8201         {
8202           argarray[j++] = (*args)[arg_index];
8203           ++arg_index;
8204           parm = TREE_CHAIN (parm);
8205         }
8206
8207       if (flags & LOOKUP_PREFER_RVALUE)
8208         {
8209           /* The implicit move specified in 15.8.3/3 fails "...if the type of
8210              the first parameter of the selected constructor is not an rvalue
8211              reference to the object's type (possibly cv-qualified)...." */
8212           gcc_assert (!(complain & tf_error));
8213           tree ptype = convs[0]->type;
8214           if (!TYPE_REF_P (ptype)
8215               || !TYPE_REF_IS_RVALUE (ptype)
8216               || CONVERSION_RANK (convs[0]) > cr_exact)
8217             return error_mark_node;
8218         }
8219     }
8220   /* Bypass access control for 'this' parameter.  */
8221   else if (TREE_CODE (TREE_TYPE (fn)) == METHOD_TYPE)
8222     {
8223       tree parmtype = TREE_VALUE (parm);
8224       tree arg = build_this (first_arg != NULL_TREE
8225                              ? first_arg
8226                              : (*args)[arg_index]);
8227       tree argtype = TREE_TYPE (arg);
8228       tree converted_arg;
8229       tree base_binfo;
8230
8231       if (arg == error_mark_node)
8232         return error_mark_node;
8233
8234       if (convs[i]->bad_p)
8235         {
8236           if (complain & tf_error)
8237             {
8238               auto_diagnostic_group d;
8239               if (permerror (input_location, "passing %qT as %<this%> "
8240                              "argument discards qualifiers",
8241                              TREE_TYPE (argtype)))
8242                 inform (DECL_SOURCE_LOCATION (fn), "  in call to %qD", fn);
8243             }
8244           else
8245             return error_mark_node;
8246         }
8247
8248       /* Optimize away vtable lookup if we know that this
8249          function can't be overridden.  We need to check if
8250          the context and the type where we found fn are the same,
8251          actually FN might be defined in a different class
8252          type because of a using-declaration. In this case, we
8253          do not want to perform a non-virtual call.  Note that
8254          resolves_to_fixed_type_p checks CLASSTYPE_FINAL too.  */
8255       if (DECL_FINAL_P (fn)
8256           || (resolves_to_fixed_type_p (arg, 0)
8257               && same_type_ignoring_top_level_qualifiers_p
8258               (DECL_CONTEXT (fn), BINFO_TYPE (cand->conversion_path)))) 
8259         flags |= LOOKUP_NONVIRTUAL;
8260
8261       /* [class.mfct.nonstatic]: If a nonstatic member function of a class
8262          X is called for an object that is not of type X, or of a type
8263          derived from X, the behavior is undefined.
8264
8265          So we can assume that anything passed as 'this' is non-null, and
8266          optimize accordingly.  */
8267       gcc_assert (TYPE_PTR_P (parmtype));
8268       /* Convert to the base in which the function was declared.  */
8269       gcc_assert (cand->conversion_path != NULL_TREE);
8270       converted_arg = build_base_path (PLUS_EXPR,
8271                                        arg,
8272                                        cand->conversion_path,
8273                                        1, complain);
8274       /* Check that the base class is accessible.  */
8275       if (!accessible_base_p (TREE_TYPE (argtype),
8276                               BINFO_TYPE (cand->conversion_path), true))
8277         {
8278           if (complain & tf_error)
8279             error ("%qT is not an accessible base of %qT",
8280                    BINFO_TYPE (cand->conversion_path),
8281                    TREE_TYPE (argtype));
8282           else
8283             return error_mark_node;
8284         }
8285       /* If fn was found by a using declaration, the conversion path
8286          will be to the derived class, not the base declaring fn. We
8287          must convert from derived to base.  */
8288       base_binfo = lookup_base (TREE_TYPE (TREE_TYPE (converted_arg)),
8289                                 TREE_TYPE (parmtype), ba_unique,
8290                                 NULL, complain);
8291       converted_arg = build_base_path (PLUS_EXPR, converted_arg,
8292                                        base_binfo, 1, complain);
8293
8294       argarray[j++] = converted_arg;
8295       parm = TREE_CHAIN (parm);
8296       if (first_arg != NULL_TREE)
8297         first_arg = NULL_TREE;
8298       else
8299         ++arg_index;
8300       ++i;
8301       is_method = 1;
8302     }
8303
8304   gcc_assert (first_arg == NULL_TREE);
8305   for (; arg_index < vec_safe_length (args) && parm;
8306        parm = TREE_CHAIN (parm), ++arg_index, ++i)
8307     {
8308       tree type = TREE_VALUE (parm);
8309       tree arg = (*args)[arg_index];
8310       bool conversion_warning = true;
8311
8312       conv = convs[i];
8313
8314       /* If the argument is NULL and used to (implicitly) instantiate a
8315          template function (and bind one of the template arguments to
8316          the type of 'long int'), we don't want to warn about passing NULL
8317          to non-pointer argument.
8318          For example, if we have this template function:
8319
8320            template<typename T> void func(T x) {}
8321
8322          we want to warn (when -Wconversion is enabled) in this case:
8323
8324            void foo() {
8325              func<int>(NULL);
8326            }
8327
8328          but not in this case:
8329
8330            void foo() {
8331              func(NULL);
8332            }
8333       */
8334       if (null_node_p (arg)
8335           && DECL_TEMPLATE_INFO (fn)
8336           && cand->template_decl
8337           && !(flags & LOOKUP_EXPLICIT_TMPL_ARGS))
8338         conversion_warning = false;
8339
8340       /* Warn about initializer_list deduction that isn't currently in the
8341          working draft.  */
8342       if (cxx_dialect > cxx98
8343           && flag_deduce_init_list
8344           && cand->template_decl
8345           && is_std_init_list (non_reference (type))
8346           && BRACE_ENCLOSED_INITIALIZER_P (arg))
8347         {
8348           tree tmpl = TI_TEMPLATE (cand->template_decl);
8349           tree realparm = chain_index (j, DECL_ARGUMENTS (cand->fn));
8350           tree patparm = get_pattern_parm (realparm, tmpl);
8351           tree pattype = TREE_TYPE (patparm);
8352           if (PACK_EXPANSION_P (pattype))
8353             pattype = PACK_EXPANSION_PATTERN (pattype);
8354           pattype = non_reference (pattype);
8355
8356           if (TREE_CODE (pattype) == TEMPLATE_TYPE_PARM
8357               && (cand->explicit_targs == NULL_TREE
8358                   || (TREE_VEC_LENGTH (cand->explicit_targs)
8359                       <= TEMPLATE_TYPE_IDX (pattype))))
8360             {
8361               pedwarn (input_location, 0, "deducing %qT as %qT",
8362                        non_reference (TREE_TYPE (patparm)),
8363                        non_reference (type));
8364               pedwarn (DECL_SOURCE_LOCATION (cand->fn), 0,
8365                        "  in call to %qD", cand->fn);
8366               pedwarn (input_location, 0,
8367                        "  (you can disable this with "
8368                        "%<-fno-deduce-init-list%>)");
8369             }
8370         }
8371
8372       /* Set user_conv_p on the argument conversions, so rvalue/base handling
8373          knows not to allow any more UDCs.  This needs to happen after we
8374          process cand->warnings.  */
8375       if (flags & LOOKUP_NO_CONVERSION)
8376         conv->user_conv_p = true;
8377
8378       tsubst_flags_t arg_complain = complain;
8379       if (!conversion_warning)
8380         arg_complain &= ~tf_warning;
8381
8382       val = convert_like_with_context (conv, arg, fn, i - is_method,
8383                                        arg_complain);
8384       val = convert_for_arg_passing (type, val, arg_complain);
8385         
8386       if (val == error_mark_node)
8387         return error_mark_node;
8388       else
8389         argarray[j++] = val;
8390     }
8391
8392   /* Default arguments */
8393   for (; parm && parm != void_list_node; parm = TREE_CHAIN (parm), i++)
8394     {
8395       if (TREE_VALUE (parm) == error_mark_node)
8396         return error_mark_node;
8397       val = convert_default_arg (TREE_VALUE (parm),
8398                                  TREE_PURPOSE (parm),
8399                                  fn, i - is_method,
8400                                  complain);
8401       if (val == error_mark_node)
8402         return error_mark_node;
8403       argarray[j++] = val;
8404     }
8405
8406   /* Ellipsis */
8407   int magic = magic_varargs_p (fn);
8408   for (; arg_index < vec_safe_length (args); ++arg_index)
8409     {
8410       tree a = (*args)[arg_index];
8411       if ((magic == 3 && arg_index == 2) || magic == 2)
8412         {
8413           /* Do no conversions for certain magic varargs.  */
8414           a = mark_type_use (a);
8415           if (TREE_CODE (a) == FUNCTION_DECL && reject_gcc_builtin (a))
8416             return error_mark_node;
8417         }
8418       else if (magic != 0)
8419         /* For other magic varargs only do decay_conversion.  */
8420         a = decay_conversion (a, complain);
8421       else if (DECL_CONSTRUCTOR_P (fn)
8422                && same_type_ignoring_top_level_qualifiers_p (DECL_CONTEXT (fn),
8423                                                              TREE_TYPE (a)))
8424         {
8425           /* Avoid infinite recursion trying to call A(...).  */
8426           if (complain & tf_error)
8427             /* Try to call the actual copy constructor for a good error.  */
8428             call_copy_ctor (a, complain);
8429           return error_mark_node;
8430         }
8431       else
8432         a = convert_arg_to_ellipsis (a, complain);
8433       if (a == error_mark_node)
8434         return error_mark_node;
8435       argarray[j++] = a;
8436     }
8437
8438   gcc_assert (j <= nargs);
8439   nargs = j;
8440
8441   /* Avoid to do argument-transformation, if warnings for format, and for
8442      nonnull are disabled.  Just in case that at least one of them is active
8443      the check_function_arguments function might warn about something.  */
8444
8445   bool warned_p = false;
8446   if (warn_nonnull
8447       || warn_format
8448       || warn_suggest_attribute_format
8449       || warn_restrict)
8450     {
8451       tree *fargs = (!nargs ? argarray
8452                             : (tree *) alloca (nargs * sizeof (tree)));
8453       for (j = 0; j < nargs; j++)
8454         {
8455           /* For -Wformat undo the implicit passing by hidden reference
8456              done by convert_arg_to_ellipsis.  */
8457           if (TREE_CODE (argarray[j]) == ADDR_EXPR
8458               && TYPE_REF_P (TREE_TYPE (argarray[j])))
8459             fargs[j] = TREE_OPERAND (argarray[j], 0);
8460           else
8461             fargs[j] = argarray[j];
8462         }
8463
8464       warned_p = check_function_arguments (input_location, fn, TREE_TYPE (fn),
8465                                            nargs, fargs, NULL);
8466     }
8467
8468   if (DECL_INHERITED_CTOR (fn))
8469     {
8470       /* Check for passing ellipsis arguments to an inherited constructor.  We
8471          could handle this by open-coding the inherited constructor rather than
8472          defining it, but let's not bother now.  */
8473       if (!cp_unevaluated_operand
8474           && cand->num_convs
8475           && cand->convs[cand->num_convs-1]->ellipsis_p)
8476         {
8477           if (complain & tf_error)
8478             {
8479               sorry ("passing arguments to ellipsis of inherited constructor "
8480                      "%qD", cand->fn);
8481               inform (DECL_SOURCE_LOCATION (cand->fn), "declared here");
8482             }
8483           return error_mark_node;
8484         }
8485
8486       /* A base constructor inheriting from a virtual base doesn't get the
8487          inherited arguments, just this and __vtt.  */
8488       if (ctor_omit_inherited_parms (fn))
8489         nargs = 2;
8490     }
8491
8492   /* Avoid actually calling copy constructors and copy assignment operators,
8493      if possible.  */
8494
8495   if (! flag_elide_constructors && !force_elide)
8496     /* Do things the hard way.  */;
8497   else if (cand->num_convs == 1 
8498            && (DECL_COPY_CONSTRUCTOR_P (fn) 
8499                || DECL_MOVE_CONSTRUCTOR_P (fn))
8500            /* It's unsafe to elide the constructor when handling
8501               a noexcept-expression, it may evaluate to the wrong
8502               value (c++/53025).  */
8503            && (force_elide || cp_noexcept_operand == 0))
8504     {
8505       tree targ;
8506       tree arg = argarray[num_artificial_parms_for (fn)];
8507       tree fa;
8508       bool trivial = trivial_fn_p (fn);
8509
8510       /* Pull out the real argument, disregarding const-correctness.  */
8511       targ = arg;
8512       /* Strip the reference binding for the constructor parameter.  */
8513       if (CONVERT_EXPR_P (targ)
8514           && TYPE_REF_P (TREE_TYPE (targ)))
8515         targ = TREE_OPERAND (targ, 0);
8516       /* But don't strip any other reference bindings; binding a temporary to a
8517          reference prevents copy elision.  */
8518       while ((CONVERT_EXPR_P (targ)
8519               && !TYPE_REF_P (TREE_TYPE (targ)))
8520              || TREE_CODE (targ) == NON_LVALUE_EXPR)
8521         targ = TREE_OPERAND (targ, 0);
8522       if (TREE_CODE (targ) == ADDR_EXPR)
8523         {
8524           targ = TREE_OPERAND (targ, 0);
8525           if (!same_type_ignoring_top_level_qualifiers_p
8526               (TREE_TYPE (TREE_TYPE (arg)), TREE_TYPE (targ)))
8527             targ = NULL_TREE;
8528         }
8529       else
8530         targ = NULL_TREE;
8531
8532       if (targ)
8533         arg = targ;
8534       else
8535         arg = cp_build_fold_indirect_ref (arg);
8536
8537       /* In C++17 we shouldn't be copying a TARGET_EXPR except into a base
8538          subobject.  */
8539       if (CHECKING_P && cxx_dialect >= cxx17)
8540         gcc_assert (TREE_CODE (arg) != TARGET_EXPR
8541                     || force_elide
8542                     /* It's from binding the ref parm to a packed field. */
8543                     || convs[0]->need_temporary_p
8544                     || seen_error ()
8545                     /* See unsafe_copy_elision_p.  */
8546                     || DECL_BASE_CONSTRUCTOR_P (fn));
8547
8548       fa = argarray[0];
8549       bool unsafe = unsafe_copy_elision_p (fa, arg);
8550       bool eliding_temp = (TREE_CODE (arg) == TARGET_EXPR && !unsafe);
8551
8552       /* [class.copy]: the copy constructor is implicitly defined even if the
8553          implementation elided its use.  But don't warn about deprecation when
8554          eliding a temporary, as then no copy is actually performed.  */
8555       warning_sentinel s (warn_deprecated_copy, eliding_temp);
8556       if (force_elide)
8557         /* The language says this isn't called.  */;
8558       else if (!trivial)
8559         {
8560           if (!mark_used (fn, complain) && !(complain & tf_error))
8561             return error_mark_node;
8562           already_used = true;
8563         }
8564       else
8565         cp_warn_deprecated_use (fn, complain);
8566
8567       /* If we're creating a temp and we already have one, don't create a
8568          new one.  If we're not creating a temp but we get one, use
8569          INIT_EXPR to collapse the temp into our target.  Otherwise, if the
8570          ctor is trivial, do a bitwise copy with a simple TARGET_EXPR for a
8571          temp or an INIT_EXPR otherwise.  */
8572       if (is_dummy_object (fa))
8573         {
8574           if (TREE_CODE (arg) == TARGET_EXPR)
8575             return arg;
8576           else if (trivial)
8577             return force_target_expr (DECL_CONTEXT (fn), arg, complain);
8578         }
8579       else if ((trivial || TREE_CODE (arg) == TARGET_EXPR)
8580                && !unsafe)
8581         {
8582           tree to = cp_stabilize_reference (cp_build_fold_indirect_ref (fa));
8583
8584           val = build2 (INIT_EXPR, DECL_CONTEXT (fn), to, arg);
8585           return val;
8586         }
8587     }
8588   else if (DECL_ASSIGNMENT_OPERATOR_P (fn)
8589            && DECL_OVERLOADED_OPERATOR_IS (fn, NOP_EXPR)
8590            && trivial_fn_p (fn))
8591     {
8592       tree to = cp_stabilize_reference
8593         (cp_build_fold_indirect_ref (argarray[0]));
8594       tree type = TREE_TYPE (to);
8595       tree as_base = CLASSTYPE_AS_BASE (type);
8596       tree arg = argarray[1];
8597       location_t loc = cp_expr_loc_or_input_loc (arg);
8598
8599       if (is_really_empty_class (type, /*ignore_vptr*/true))
8600         {
8601           /* Avoid copying empty classes.  */
8602           val = build2 (COMPOUND_EXPR, type, arg, to);
8603           TREE_NO_WARNING (val) = 1;
8604         }
8605       else if (tree_int_cst_equal (TYPE_SIZE (type), TYPE_SIZE (as_base)))
8606         {
8607           if (is_std_init_list (type)
8608               && conv_binds_ref_to_prvalue (convs[1]))
8609             warning_at (loc, OPT_Winit_list_lifetime,
8610                         "assignment from temporary %<initializer_list%> does "
8611                         "not extend the lifetime of the underlying array");
8612           arg = cp_build_fold_indirect_ref (arg);
8613           val = build2 (MODIFY_EXPR, TREE_TYPE (to), to, arg);
8614         }
8615       else
8616         {
8617           /* We must only copy the non-tail padding parts.  */
8618           tree arg0, arg2, t;
8619           tree array_type, alias_set;
8620
8621           arg2 = TYPE_SIZE_UNIT (as_base);
8622           arg0 = cp_build_addr_expr (to, complain);
8623
8624           array_type = build_array_type (unsigned_char_type_node,
8625                                          build_index_type
8626                                            (size_binop (MINUS_EXPR,
8627                                                         arg2, size_int (1))));
8628           alias_set = build_int_cst (build_pointer_type (type), 0);
8629           t = build2 (MODIFY_EXPR, void_type_node,
8630                       build2 (MEM_REF, array_type, arg0, alias_set),
8631                       build2 (MEM_REF, array_type, arg, alias_set));
8632           val = build2 (COMPOUND_EXPR, TREE_TYPE (to), t, to);
8633           TREE_NO_WARNING (val) = 1;
8634         }
8635
8636       cp_warn_deprecated_use (fn, complain);
8637
8638       return val;
8639     }
8640   else if (trivial_fn_p (fn))
8641     {
8642       if (DECL_DESTRUCTOR_P (fn))
8643         return build_trivial_dtor_call (argarray[0]);
8644       else if (default_ctor_p (fn))
8645         {
8646           if (is_dummy_object (argarray[0]))
8647             return force_target_expr (DECL_CONTEXT (fn), void_node,
8648                                       no_cleanup_complain);
8649           else
8650             return cp_build_fold_indirect_ref (argarray[0]);
8651         }
8652     }
8653
8654   gcc_assert (!force_elide);
8655
8656   if (!already_used
8657       && !mark_used (fn, complain))
8658     return error_mark_node;
8659
8660   /* Warn if the built-in writes to an object of a non-trivial type.  */
8661   if (warn_class_memaccess
8662       && vec_safe_length (args) >= 2
8663       && DECL_BUILT_IN_CLASS (fn) == BUILT_IN_NORMAL)
8664     maybe_warn_class_memaccess (input_location, fn, args);
8665
8666   if (DECL_VINDEX (fn) && (flags & LOOKUP_NONVIRTUAL) == 0)
8667     {
8668       tree t;
8669       tree binfo = lookup_base (TREE_TYPE (TREE_TYPE (argarray[0])),
8670                                 DECL_CONTEXT (fn),
8671                                 ba_any, NULL, complain);
8672       gcc_assert (binfo && binfo != error_mark_node);
8673
8674       argarray[0] = build_base_path (PLUS_EXPR, argarray[0], binfo, 1,
8675                                      complain);
8676       if (TREE_SIDE_EFFECTS (argarray[0]))
8677         argarray[0] = save_expr (argarray[0]);
8678       t = build_pointer_type (TREE_TYPE (fn));
8679       fn = build_vfn_ref (argarray[0], DECL_VINDEX (fn));
8680       TREE_TYPE (fn) = t;
8681     }
8682   else
8683     {
8684       fn = build_addr_func (fn, complain);
8685       if (fn == error_mark_node)
8686         return error_mark_node;
8687     }
8688
8689   tree call = build_cxx_call (fn, nargs, argarray, complain|decltype_flag);
8690   if (call == error_mark_node)
8691     return call;
8692   if (cand->flags & LOOKUP_LIST_INIT_CTOR)
8693     {
8694       tree c = extract_call_expr (call);
8695       /* build_new_op_1 will clear this when appropriate.  */
8696       CALL_EXPR_ORDERED_ARGS (c) = true;
8697     }
8698   if (warned_p)
8699     {
8700       tree c = extract_call_expr (call);
8701       if (TREE_CODE (c) == CALL_EXPR)
8702         TREE_NO_WARNING (c) = 1;
8703     }
8704   return call;
8705 }
8706
8707 namespace
8708 {
8709
8710 /* Return the DECL of the first non-static subobject of class TYPE
8711    that satisfies the predicate PRED or null if none can be found.  */
8712
8713 template <class Predicate>
8714 tree
8715 first_non_static_field (tree type, Predicate pred)
8716 {
8717   if (!type || !CLASS_TYPE_P (type))
8718     return NULL_TREE;
8719
8720   for (tree field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
8721     {
8722       if (TREE_CODE (field) != FIELD_DECL)
8723         continue;
8724       if (TREE_STATIC (field))
8725         continue;
8726       if (pred (field))
8727         return field;
8728     }
8729
8730   int i = 0;
8731
8732   for (tree base_binfo, binfo = TYPE_BINFO (type);
8733        BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
8734     {
8735       tree base = TREE_TYPE (base_binfo);
8736       if (pred (base))
8737         return base;
8738       if (tree field = first_non_static_field (base, pred))
8739         return field;
8740     }
8741
8742   return NULL_TREE;
8743 }
8744
8745 struct NonPublicField
8746 {
8747   bool operator() (const_tree t)
8748   {
8749     return DECL_P (t) && (TREE_PRIVATE (t) || TREE_PROTECTED (t));
8750   }
8751 };
8752
8753 /* Return the DECL of the first non-public subobject of class TYPE
8754    or null if none can be found.  */
8755
8756 static inline tree
8757 first_non_public_field (tree type)
8758 {
8759   return first_non_static_field (type, NonPublicField ());
8760 }
8761
8762 struct NonTrivialField
8763 {
8764   bool operator() (const_tree t)
8765   {
8766     return !trivial_type_p (DECL_P (t) ? TREE_TYPE (t) : t);
8767   }
8768 };
8769
8770 /* Return the DECL of the first non-trivial subobject of class TYPE
8771    or null if none can be found.  */
8772
8773 static inline tree
8774 first_non_trivial_field (tree type)
8775 {
8776   return first_non_static_field (type, NonTrivialField ());
8777 }
8778
8779 }   /* unnamed namespace */
8780
8781 /* Return true if all copy and move assignment operator overloads for
8782    class TYPE are trivial and at least one of them is not deleted and,
8783    when ACCESS is set, accessible.  Return false otherwise.  Set
8784    HASASSIGN to true when the TYPE has a (not necessarily trivial)
8785    copy or move assignment.  */
8786
8787 static bool
8788 has_trivial_copy_assign_p (tree type, bool access, bool *hasassign)
8789 {
8790   tree fns = get_class_binding (type, assign_op_identifier);
8791   bool all_trivial = true;
8792
8793   /* Iterate over overloads of the assignment operator, checking
8794      accessible copy assignments for triviality.  */
8795
8796   for (ovl_iterator oi (fns); oi; ++oi)
8797     {
8798       tree f = *oi;
8799
8800       /* Skip operators that aren't copy assignments.  */
8801       if (!copy_fn_p (f))
8802         continue;
8803
8804       bool accessible = (!access || !(TREE_PRIVATE (f) || TREE_PROTECTED (f))
8805                          || accessible_p (TYPE_BINFO (type), f, true));
8806
8807       /* Skip template assignment operators and deleted functions.  */
8808       if (TREE_CODE (f) != FUNCTION_DECL || DECL_DELETED_FN (f))
8809         continue;
8810
8811       if (accessible)
8812         *hasassign = true;
8813
8814       if (!accessible || !trivial_fn_p (f))
8815         all_trivial = false;
8816
8817       /* Break early when both properties have been determined.  */
8818       if (*hasassign && !all_trivial)
8819         break;
8820     }
8821
8822   /* Return true if they're all trivial and one of the expressions
8823      TYPE() = TYPE() or TYPE() = (TYPE&)() is valid.  */
8824   tree ref = cp_build_reference_type (type, false);
8825   return (all_trivial
8826           && (is_trivially_xible (MODIFY_EXPR, type, type)
8827               || is_trivially_xible (MODIFY_EXPR, type, ref)));
8828 }
8829
8830 /* Return true if all copy and move ctor overloads for class TYPE are
8831    trivial and at least one of them is not deleted and, when ACCESS is
8832    set, accessible.  Return false otherwise.  Set each element of HASCTOR[]
8833    to true when the TYPE has a (not necessarily trivial) default and copy
8834    (or move) ctor, respectively.  */
8835
8836 static bool
8837 has_trivial_copy_p (tree type, bool access, bool hasctor[2])
8838 {
8839   tree fns = get_class_binding (type, complete_ctor_identifier);
8840   bool all_trivial = true;
8841
8842   for (ovl_iterator oi (fns); oi; ++oi)
8843     {
8844       tree f = *oi;
8845
8846       /* Skip template constructors.  */
8847       if (TREE_CODE (f) != FUNCTION_DECL)
8848         continue;
8849
8850       bool cpy_or_move_ctor_p = copy_fn_p (f);
8851
8852       /* Skip ctors other than default, copy, and move.  */
8853       if (!cpy_or_move_ctor_p && !default_ctor_p (f))
8854         continue;
8855
8856       if (DECL_DELETED_FN (f))
8857         continue;
8858
8859       bool accessible = (!access || !(TREE_PRIVATE (f) || TREE_PROTECTED (f))
8860                          || accessible_p (TYPE_BINFO (type), f, true));
8861
8862       if (accessible)
8863         hasctor[cpy_or_move_ctor_p] = true;
8864
8865       if (cpy_or_move_ctor_p && (!accessible || !trivial_fn_p (f)))
8866         all_trivial = false;
8867
8868       /* Break early when both properties have been determined.  */
8869       if (hasctor[0] && hasctor[1] && !all_trivial)
8870         break;
8871     }
8872
8873   return all_trivial;
8874 }
8875
8876 /* Issue a warning on a call to the built-in function FNDECL if it is
8877    a raw memory write whose destination is not an object of (something
8878    like) trivial or standard layout type with a non-deleted assignment
8879    and copy ctor.  Detects const correctness violations, corrupting
8880    references, virtual table pointers, and bypassing non-trivial
8881    assignments.  */
8882
8883 static void
8884 maybe_warn_class_memaccess (location_t loc, tree fndecl,
8885                             const vec<tree, va_gc> *args)
8886 {
8887   /* Except for bcopy where it's second, the destination pointer is
8888      the first argument for all functions handled here.  Compute
8889      the index of the destination and source arguments.  */
8890   unsigned dstidx = DECL_FUNCTION_CODE (fndecl) == BUILT_IN_BCOPY;
8891   unsigned srcidx = !dstidx;
8892
8893   tree dest = (*args)[dstidx];
8894   if (!TREE_TYPE (dest) || !INDIRECT_TYPE_P (TREE_TYPE (dest)))
8895     return;
8896
8897   tree srctype = NULL_TREE;
8898
8899   /* Determine the type of the pointed-to object and whether it's
8900      a complete class type.  */
8901   tree desttype = TREE_TYPE (TREE_TYPE (dest));
8902
8903   if (!desttype || !COMPLETE_TYPE_P (desttype) || !CLASS_TYPE_P (desttype))
8904     return;
8905
8906   /* Check to see if the raw memory call is made by a non-static member
8907      function with THIS as the destination argument for the destination
8908      type.  If so, and if the class has no non-trivial bases or members,
8909      be more permissive.  */
8910   if (current_function_decl
8911       && DECL_NONSTATIC_MEMBER_FUNCTION_P (current_function_decl)
8912       && is_this_parameter (tree_strip_nop_conversions (dest)))
8913     {
8914       tree ctx = DECL_CONTEXT (current_function_decl);
8915       bool special = same_type_ignoring_top_level_qualifiers_p (ctx, desttype);
8916       tree binfo = TYPE_BINFO (ctx);
8917
8918       if (special
8919           && !BINFO_VTABLE (binfo)
8920           && !first_non_trivial_field (desttype))
8921         return;
8922     }
8923
8924   /* True if the class is trivial.  */
8925   bool trivial = trivial_type_p (desttype);
8926
8927   /* Set to true if DESTYPE has an accessible copy assignment.  */
8928   bool hasassign = false;
8929   /* True if all of the class' overloaded copy assignment operators
8930      are all trivial (and not deleted) and at least one of them is
8931      accessible.  */
8932   bool trivassign = has_trivial_copy_assign_p (desttype, true, &hasassign);
8933
8934   /* Set to true if DESTTYPE has an accessible default and copy ctor,
8935      respectively.  */
8936   bool hasctors[2] = { false, false };
8937
8938   /* True if all of the class' overloaded copy constructors are all
8939      trivial (and not deleted) and at least one of them is accessible.  */
8940   bool trivcopy = has_trivial_copy_p (desttype, true, hasctors);
8941
8942   /* Set FLD to the first private/protected member of the class.  */
8943   tree fld = trivial ? first_non_public_field (desttype) : NULL_TREE;
8944
8945   /* The warning format string.  */
8946   const char *warnfmt = NULL;
8947   /* A suggested alternative to offer instead of the raw memory call.
8948      Empty string when none can be come up with.  */
8949   const char *suggest = "";
8950   bool warned = false;
8951
8952   switch (DECL_FUNCTION_CODE (fndecl))
8953     {
8954     case BUILT_IN_MEMSET:
8955       if (!integer_zerop (maybe_constant_value ((*args)[1])))
8956         {
8957           /* Diagnose setting non-copy-assignable or non-trivial types,
8958              or types with a private member, to (potentially) non-zero
8959              bytes.  Since the value of the bytes being written is unknown,
8960              suggest using assignment instead (if one exists).  Also warn
8961              for writes into objects for which zero-initialization doesn't
8962              mean all bits clear (pointer-to-member data, where null is all
8963              bits set).  Since the value being written is (most likely)
8964              non-zero, simply suggest assignment (but not copy assignment).  */
8965           suggest = "; use assignment instead";
8966           if (!trivassign)
8967             warnfmt = G_("%qD writing to an object of type %#qT with "
8968                          "no trivial copy-assignment");
8969           else if (!trivial)
8970             warnfmt = G_("%qD writing to an object of non-trivial type %#qT%s");
8971           else if (fld)
8972             {
8973               const char *access = TREE_PRIVATE (fld) ? "private" : "protected";
8974               warned = warning_at (loc, OPT_Wclass_memaccess,
8975                                    "%qD writing to an object of type %#qT with "
8976                                    "%qs member %qD",
8977                                    fndecl, desttype, access, fld);
8978             }
8979           else if (!zero_init_p (desttype))
8980             warnfmt = G_("%qD writing to an object of type %#qT containing "
8981                          "a pointer to data member%s");
8982
8983           break;
8984         }
8985       /* Fall through.  */
8986
8987     case BUILT_IN_BZERO:
8988       /* Similarly to the above, diagnose clearing non-trivial or non-
8989          standard layout objects, or objects of types with no assignmenmt.
8990          Since the value being written is known to be zero, suggest either
8991          copy assignment, copy ctor, or default ctor as an alternative,
8992          depending on what's available.  */
8993
8994       if (hasassign && hasctors[0])
8995         suggest = G_("; use assignment or value-initialization instead");
8996       else if (hasassign)
8997         suggest = G_("; use assignment instead");
8998       else if (hasctors[0])
8999         suggest = G_("; use value-initialization instead");
9000
9001       if (!trivassign)
9002         warnfmt = G_("%qD clearing an object of type %#qT with "
9003                      "no trivial copy-assignment%s");
9004       else if (!trivial)
9005         warnfmt =  G_("%qD clearing an object of non-trivial type %#qT%s");
9006       else if (!zero_init_p (desttype))
9007         warnfmt = G_("%qD clearing an object of type %#qT containing "
9008                      "a pointer-to-member%s");
9009       break;
9010
9011     case BUILT_IN_BCOPY:
9012     case BUILT_IN_MEMCPY:
9013     case BUILT_IN_MEMMOVE:
9014     case BUILT_IN_MEMPCPY:
9015       /* Determine the type of the source object.  */
9016       srctype = TREE_TYPE ((*args)[srcidx]);
9017       if (!srctype || !INDIRECT_TYPE_P (srctype))
9018         srctype = void_type_node;
9019       else
9020         srctype = TREE_TYPE (srctype);
9021
9022       /* Since it's impossible to determine wheter the byte copy is
9023          being used in place of assignment to an existing object or
9024          as a substitute for initialization, assume it's the former.
9025          Determine the best alternative to use instead depending on
9026          what's not deleted.  */
9027       if (hasassign && hasctors[1])
9028         suggest = G_("; use copy-assignment or copy-initialization instead");
9029       else if (hasassign)
9030         suggest = G_("; use copy-assignment instead");
9031       else if (hasctors[1])
9032         suggest = G_("; use copy-initialization instead");
9033
9034       if (!trivassign)
9035         warnfmt = G_("%qD writing to an object of type %#qT with no trivial "
9036                      "copy-assignment%s");
9037       else if (!trivially_copyable_p (desttype))
9038         warnfmt = G_("%qD writing to an object of non-trivially copyable "
9039                      "type %#qT%s");
9040       else if (!trivcopy)
9041         warnfmt = G_("%qD writing to an object with a deleted copy constructor");
9042
9043       else if (!trivial
9044                && !VOID_TYPE_P (srctype)
9045                && !char_type_p (TYPE_MAIN_VARIANT (srctype))
9046                && !same_type_ignoring_top_level_qualifiers_p (desttype,
9047                                                               srctype))
9048         {
9049           /* Warn when copying into a non-trivial object from an object
9050              of a different type other than void or char.  */
9051           warned = warning_at (loc, OPT_Wclass_memaccess,
9052                                "%qD copying an object of non-trivial type "
9053                                "%#qT from an array of %#qT",
9054                                fndecl, desttype, srctype);
9055         }
9056       else if (fld
9057                && !VOID_TYPE_P (srctype)
9058                && !char_type_p (TYPE_MAIN_VARIANT (srctype))
9059                && !same_type_ignoring_top_level_qualifiers_p (desttype,
9060                                                               srctype))
9061         {
9062           const char *access = TREE_PRIVATE (fld) ? "private" : "protected";
9063           warned = warning_at (loc, OPT_Wclass_memaccess,
9064                                "%qD copying an object of type %#qT with "
9065                                "%qs member %qD from an array of %#qT; use "
9066                                "assignment or copy-initialization instead",
9067                                fndecl, desttype, access, fld, srctype);
9068         }
9069       else if (!trivial && vec_safe_length (args) > 2)
9070         {
9071           tree sz = maybe_constant_value ((*args)[2]);
9072           if (!tree_fits_uhwi_p (sz))
9073             break;
9074
9075           /* Finally, warn on partial copies.  */
9076           unsigned HOST_WIDE_INT typesize
9077             = tree_to_uhwi (TYPE_SIZE_UNIT (desttype));
9078           if (unsigned HOST_WIDE_INT partial = tree_to_uhwi (sz) % typesize)
9079             warned = warning_at (loc, OPT_Wclass_memaccess,
9080                                  (typesize - partial > 1
9081                                   ? G_("%qD writing to an object of "
9082                                        "a non-trivial type %#qT leaves %wu "
9083                                        "bytes unchanged")
9084                                   : G_("%qD writing to an object of "
9085                                        "a non-trivial type %#qT leaves %wu "
9086                                        "byte unchanged")),
9087                                  fndecl, desttype, typesize - partial);
9088         }
9089       break;
9090
9091     case BUILT_IN_REALLOC:
9092
9093       if (!trivially_copyable_p (desttype))
9094         warnfmt = G_("%qD moving an object of non-trivially copyable type "
9095                      "%#qT; use %<new%> and %<delete%> instead");
9096       else if (!trivcopy)
9097         warnfmt = G_("%qD moving an object of type %#qT with deleted copy "
9098                      "constructor; use %<new%> and %<delete%> instead");
9099       else if (!get_dtor (desttype, tf_none))
9100         warnfmt = G_("%qD moving an object of type %#qT with deleted "
9101                      "destructor");
9102       else if (!trivial)
9103         {
9104           tree sz = maybe_constant_value ((*args)[1]);
9105           if (TREE_CODE (sz) == INTEGER_CST
9106               && tree_int_cst_lt (sz, TYPE_SIZE_UNIT (desttype)))
9107             /* Finally, warn on reallocation into insufficient space.  */
9108             warned = warning_at (loc, OPT_Wclass_memaccess,
9109                                  "%qD moving an object of non-trivial type "
9110                                  "%#qT and size %E into a region of size %E",
9111                                  fndecl, desttype, TYPE_SIZE_UNIT (desttype),
9112                                  sz);
9113         }
9114       break;
9115
9116     default:
9117       return;
9118     }
9119
9120   if (warnfmt)
9121     {
9122       if (suggest)
9123         warned = warning_at (loc, OPT_Wclass_memaccess,
9124                              warnfmt, fndecl, desttype, suggest);
9125       else
9126         warned = warning_at (loc, OPT_Wclass_memaccess,
9127                              warnfmt, fndecl, desttype);
9128     }
9129
9130   if (warned)
9131     inform (location_of (desttype), "%#qT declared here", desttype);
9132 }
9133
9134 /* Build and return a call to FN, using NARGS arguments in ARGARRAY.
9135    This function performs no overload resolution, conversion, or other
9136    high-level operations.  */
9137
9138 tree
9139 build_cxx_call (tree fn, int nargs, tree *argarray,
9140                 tsubst_flags_t complain)
9141 {
9142   tree fndecl;
9143
9144   /* Remember roughly where this call is.  */
9145   location_t loc = cp_expr_loc_or_input_loc (fn);
9146   fn = build_call_a (fn, nargs, argarray);
9147   SET_EXPR_LOCATION (fn, loc);
9148
9149   fndecl = get_callee_fndecl (fn);
9150
9151   /* Check that arguments to builtin functions match the expectations.  */
9152   if (fndecl
9153       && !processing_template_decl
9154       && fndecl_built_in_p (fndecl, BUILT_IN_NORMAL))
9155     {
9156       int i;
9157
9158       /* We need to take care that values to BUILT_IN_NORMAL
9159          are reduced.  */
9160       for (i = 0; i < nargs; i++)
9161         argarray[i] = maybe_constant_value (argarray[i]);
9162
9163       if (!check_builtin_function_arguments (EXPR_LOCATION (fn), vNULL, fndecl,
9164                                              nargs, argarray))
9165         return error_mark_node;
9166     }
9167
9168   if (VOID_TYPE_P (TREE_TYPE (fn)))
9169     return fn;
9170
9171   /* 5.2.2/11: If a function call is a prvalue of object type: if the
9172      function call is either the operand of a decltype-specifier or the
9173      right operand of a comma operator that is the operand of a
9174      decltype-specifier, a temporary object is not introduced for the
9175      prvalue. The type of the prvalue may be incomplete.  */
9176   if (!(complain & tf_decltype))
9177     {
9178       fn = require_complete_type_sfinae (fn, complain);
9179       if (fn == error_mark_node)
9180         return error_mark_node;
9181
9182       if (MAYBE_CLASS_TYPE_P (TREE_TYPE (fn)))
9183         {
9184           fn = build_cplus_new (TREE_TYPE (fn), fn, complain);
9185           maybe_warn_parm_abi (TREE_TYPE (fn), loc);
9186         }
9187     }
9188   return convert_from_reference (fn);
9189 }
9190
9191 /* Returns the value to use for the in-charge parameter when making a
9192    call to a function with the indicated NAME.
9193
9194    FIXME:Can't we find a neater way to do this mapping?  */
9195
9196 tree
9197 in_charge_arg_for_name (tree name)
9198 {
9199   if (IDENTIFIER_CTOR_P (name))
9200     {
9201       if (name == complete_ctor_identifier)
9202         return integer_one_node;
9203       gcc_checking_assert (name == base_ctor_identifier);
9204     }
9205   else
9206     {
9207       if (name == complete_dtor_identifier)
9208         return integer_two_node;
9209       else if (name == deleting_dtor_identifier)
9210         return integer_three_node;
9211       gcc_checking_assert (name == base_dtor_identifier);
9212     }
9213
9214   return integer_zero_node;
9215 }
9216
9217 /* We've built up a constructor call RET.  Complain if it delegates to the
9218    constructor we're currently compiling.  */
9219
9220 static void
9221 check_self_delegation (tree ret)
9222 {
9223   if (TREE_CODE (ret) == TARGET_EXPR)
9224     ret = TARGET_EXPR_INITIAL (ret);
9225   tree fn = cp_get_callee_fndecl_nofold (ret);
9226   if (fn && DECL_ABSTRACT_ORIGIN (fn) == current_function_decl)
9227     error ("constructor delegates to itself");
9228 }
9229
9230 /* Build a call to a constructor, destructor, or an assignment
9231    operator for INSTANCE, an expression with class type.  NAME
9232    indicates the special member function to call; *ARGS are the
9233    arguments.  ARGS may be NULL.  This may change ARGS.  BINFO
9234    indicates the base of INSTANCE that is to be passed as the `this'
9235    parameter to the member function called.
9236
9237    FLAGS are the LOOKUP_* flags to use when processing the call.
9238
9239    If NAME indicates a complete object constructor, INSTANCE may be
9240    NULL_TREE.  In this case, the caller will call build_cplus_new to
9241    store the newly constructed object into a VAR_DECL.  */
9242
9243 tree
9244 build_special_member_call (tree instance, tree name, vec<tree, va_gc> **args,
9245                            tree binfo, int flags, tsubst_flags_t complain)
9246 {
9247   tree fns;
9248   /* The type of the subobject to be constructed or destroyed.  */
9249   tree class_type;
9250   vec<tree, va_gc> *allocated = NULL;
9251   tree ret;
9252
9253   gcc_assert (IDENTIFIER_CDTOR_P (name) || name == assign_op_identifier);
9254
9255   if (error_operand_p (instance))
9256     return error_mark_node;
9257
9258   if (IDENTIFIER_DTOR_P (name))
9259     {
9260       gcc_assert (args == NULL || vec_safe_is_empty (*args));
9261       if (!type_build_dtor_call (TREE_TYPE (instance)))
9262         /* Shortcut to avoid lazy destructor declaration.  */
9263         return build_trivial_dtor_call (instance);
9264     }
9265
9266   if (TYPE_P (binfo))
9267     {
9268       /* Resolve the name.  */
9269       if (!complete_type_or_maybe_complain (binfo, NULL_TREE, complain))
9270         return error_mark_node;
9271
9272       binfo = TYPE_BINFO (binfo);
9273     }
9274
9275   gcc_assert (binfo != NULL_TREE);
9276
9277   class_type = BINFO_TYPE (binfo);
9278
9279   /* Handle the special case where INSTANCE is NULL_TREE.  */
9280   if (name == complete_ctor_identifier && !instance)
9281     instance = build_dummy_object (class_type);
9282   else
9283     {
9284       /* Convert to the base class, if necessary.  */
9285       if (!same_type_ignoring_top_level_qualifiers_p
9286           (TREE_TYPE (instance), BINFO_TYPE (binfo)))
9287         {
9288           if (IDENTIFIER_CDTOR_P (name))
9289             /* For constructors and destructors, either the base is
9290                non-virtual, or it is virtual but we are doing the
9291                conversion from a constructor or destructor for the
9292                complete object.  In either case, we can convert
9293                statically.  */
9294             instance = convert_to_base_statically (instance, binfo);
9295           else
9296             {
9297               /* However, for assignment operators, we must convert
9298                  dynamically if the base is virtual.  */
9299               gcc_checking_assert (name == assign_op_identifier);
9300               instance = build_base_path (PLUS_EXPR, instance,
9301                                           binfo, /*nonnull=*/1, complain);
9302             }
9303         }
9304     }
9305
9306   gcc_assert (instance != NULL_TREE);
9307
9308   /* In C++17, "If the initializer expression is a prvalue and the
9309      cv-unqualified version of the source type is the same class as the class
9310      of the destination, the initializer expression is used to initialize the
9311      destination object."  Handle that here to avoid doing overload
9312      resolution.  */
9313   if (cxx_dialect >= cxx17
9314       && args && vec_safe_length (*args) == 1
9315       && name == complete_ctor_identifier)
9316     {
9317       tree arg = (**args)[0];
9318
9319       if (BRACE_ENCLOSED_INITIALIZER_P (arg)
9320           && !TYPE_HAS_LIST_CTOR (class_type)
9321           && CONSTRUCTOR_NELTS (arg) == 1)
9322         arg = CONSTRUCTOR_ELT (arg, 0)->value;
9323
9324       if ((TREE_CODE (arg) == TARGET_EXPR
9325            || TREE_CODE (arg) == CONSTRUCTOR)
9326           && (same_type_ignoring_top_level_qualifiers_p
9327               (class_type, TREE_TYPE (arg))))
9328         {
9329           if (is_dummy_object (instance))
9330             return arg;
9331           else if (TREE_CODE (arg) == TARGET_EXPR)
9332             TARGET_EXPR_DIRECT_INIT_P (arg) = true;
9333
9334           if ((complain & tf_error)
9335               && (flags & LOOKUP_DELEGATING_CONS))
9336             check_self_delegation (arg);
9337           /* Avoid change of behavior on Wunused-var-2.C.  */
9338           instance = mark_lvalue_use (instance);
9339           return build2 (INIT_EXPR, class_type, instance, arg);
9340         }
9341     }
9342
9343   fns = lookup_fnfields (binfo, name, 1);
9344
9345   /* When making a call to a constructor or destructor for a subobject
9346      that uses virtual base classes, pass down a pointer to a VTT for
9347      the subobject.  */
9348   if ((name == base_ctor_identifier
9349        || name == base_dtor_identifier)
9350       && CLASSTYPE_VBASECLASSES (class_type))
9351     {
9352       tree vtt;
9353       tree sub_vtt;
9354
9355       /* If the current function is a complete object constructor
9356          or destructor, then we fetch the VTT directly.
9357          Otherwise, we look it up using the VTT we were given.  */
9358       vtt = DECL_CHAIN (CLASSTYPE_VTABLES (current_class_type));
9359       vtt = decay_conversion (vtt, complain);
9360       if (vtt == error_mark_node)
9361         return error_mark_node;
9362       vtt = build_if_in_charge (vtt, current_vtt_parm);
9363       if (BINFO_SUBVTT_INDEX (binfo))
9364         sub_vtt = fold_build_pointer_plus (vtt, BINFO_SUBVTT_INDEX (binfo));
9365       else
9366         sub_vtt = vtt;
9367
9368       if (args == NULL)
9369         {
9370           allocated = make_tree_vector ();
9371           args = &allocated;
9372         }
9373
9374       vec_safe_insert (*args, 0, sub_vtt);
9375     }
9376
9377   ret = build_new_method_call (instance, fns, args,
9378                                TYPE_BINFO (BINFO_TYPE (binfo)),
9379                                flags, /*fn=*/NULL,
9380                                complain);
9381
9382   if (allocated != NULL)
9383     release_tree_vector (allocated);
9384
9385   if ((complain & tf_error)
9386       && (flags & LOOKUP_DELEGATING_CONS)
9387       && name == complete_ctor_identifier)
9388     check_self_delegation (ret);
9389
9390   return ret;
9391 }
9392
9393 /* Return the NAME, as a C string.  The NAME indicates a function that
9394    is a member of TYPE.  *FREE_P is set to true if the caller must
9395    free the memory returned.
9396
9397    Rather than go through all of this, we should simply set the names
9398    of constructors and destructors appropriately, and dispense with
9399    ctor_identifier, dtor_identifier, etc.  */
9400
9401 static char *
9402 name_as_c_string (tree name, tree type, bool *free_p)
9403 {
9404   const char *pretty_name;
9405
9406   /* Assume that we will not allocate memory.  */
9407   *free_p = false;
9408   /* Constructors and destructors are special.  */
9409   if (IDENTIFIER_CDTOR_P (name))
9410     {
9411       pretty_name
9412         = identifier_to_locale (IDENTIFIER_POINTER (constructor_name (type)));
9413       /* For a destructor, add the '~'.  */
9414       if (IDENTIFIER_DTOR_P (name))
9415         {
9416           pretty_name = concat ("~", pretty_name, NULL);
9417           /* Remember that we need to free the memory allocated.  */
9418           *free_p = true;
9419         }
9420     }
9421   else if (IDENTIFIER_CONV_OP_P (name))
9422     {
9423       pretty_name = concat ("operator ",
9424                             type_as_string_translate (TREE_TYPE (name),
9425                                                       TFF_PLAIN_IDENTIFIER),
9426                             NULL);
9427       /* Remember that we need to free the memory allocated.  */
9428       *free_p = true;
9429     }
9430   else
9431     pretty_name = identifier_to_locale (IDENTIFIER_POINTER (name));
9432
9433   return CONST_CAST (char *, pretty_name);
9434 }
9435
9436 /* If CANDIDATES contains exactly one candidate, return it, otherwise
9437    return NULL.  */
9438
9439 static z_candidate *
9440 single_z_candidate (z_candidate *candidates)
9441 {
9442   if (candidates == NULL)
9443     return NULL;
9444
9445   if (candidates->next)
9446     return NULL;
9447
9448   return candidates;
9449 }
9450
9451 /* If CANDIDATE is invalid due to a bad argument type, return the
9452    pertinent conversion_info.
9453
9454    Otherwise, return NULL.  */
9455
9456 static const conversion_info *
9457 maybe_get_bad_conversion_for_unmatched_call (const z_candidate *candidate)
9458 {
9459   /* Must be an rr_arg_conversion or rr_bad_arg_conversion.  */
9460   rejection_reason *r = candidate->reason;
9461
9462   if (r == NULL)
9463     return NULL;
9464
9465   switch (r->code)
9466     {
9467     default:
9468       return NULL;
9469
9470     case rr_arg_conversion:
9471       return &r->u.conversion;
9472
9473     case rr_bad_arg_conversion:
9474       return &r->u.bad_conversion;
9475     }
9476 }
9477
9478 /* Issue an error and note complaining about a bad argument type at a
9479    callsite with a single candidate FNDECL.
9480
9481    ARG_LOC is the location of the argument (or UNKNOWN_LOCATION, in which
9482    case input_location is used).
9483    FROM_TYPE is the type of the actual argument; TO_TYPE is the type of
9484    the formal parameter.  */
9485
9486 void
9487 complain_about_bad_argument (location_t arg_loc,
9488                              tree from_type, tree to_type,
9489                              tree fndecl, int parmnum)
9490 {
9491   auto_diagnostic_group d;
9492   range_label_for_type_mismatch rhs_label (from_type, to_type);
9493   range_label *label = &rhs_label;
9494   if (arg_loc == UNKNOWN_LOCATION)
9495     {
9496       arg_loc = input_location;
9497       label = NULL;
9498     }
9499   gcc_rich_location richloc (arg_loc, label);
9500   error_at (&richloc,
9501             "cannot convert %qH to %qI",
9502             from_type, to_type);
9503   maybe_inform_about_fndecl_for_bogus_argument_init (fndecl,
9504                                                      parmnum);
9505 }
9506
9507 /* Subroutine of build_new_method_call_1, for where there are no viable
9508    candidates for the call.  */
9509
9510 static void
9511 complain_about_no_candidates_for_method_call (tree instance,
9512                                               z_candidate *candidates,
9513                                               tree explicit_targs,
9514                                               tree basetype,
9515                                               tree optype, tree name,
9516                                               bool skip_first_for_error,
9517                                               vec<tree, va_gc> *user_args)
9518 {
9519   auto_diagnostic_group d;
9520   if (!COMPLETE_OR_OPEN_TYPE_P (basetype))
9521     cxx_incomplete_type_error (instance, basetype);
9522   else if (optype)
9523     error ("no matching function for call to %<%T::operator %T(%A)%#V%>",
9524            basetype, optype, build_tree_list_vec (user_args),
9525            TREE_TYPE (instance));
9526   else
9527     {
9528       /* Special-case for when there's a single candidate that's failing
9529          due to a bad argument type.  */
9530       if (z_candidate *candidate = single_z_candidate (candidates))
9531           if (const conversion_info *conv
9532                 = maybe_get_bad_conversion_for_unmatched_call (candidate))
9533             {
9534               complain_about_bad_argument (conv->loc,
9535                                            conv->from, conv->to_type,
9536                                            candidate->fn, conv->n_arg);
9537               return;
9538             }
9539
9540       tree arglist = build_tree_list_vec (user_args);
9541       tree errname = name;
9542       bool twiddle = false;
9543       if (IDENTIFIER_CDTOR_P (errname))
9544         {
9545           twiddle = IDENTIFIER_DTOR_P (errname);
9546           errname = constructor_name (basetype);
9547         }
9548       if (explicit_targs)
9549         errname = lookup_template_function (errname, explicit_targs);
9550       if (skip_first_for_error)
9551         arglist = TREE_CHAIN (arglist);
9552       error ("no matching function for call to %<%T::%s%E(%A)%#V%>",
9553              basetype, &"~"[!twiddle], errname, arglist,
9554              TREE_TYPE (instance));
9555     }
9556   print_z_candidates (location_of (name), candidates);
9557 }
9558
9559 /* Build a call to "INSTANCE.FN (ARGS)".  If FN_P is non-NULL, it will
9560    be set, upon return, to the function called.  ARGS may be NULL.
9561    This may change ARGS.  */
9562
9563 static tree
9564 build_new_method_call_1 (tree instance, tree fns, vec<tree, va_gc> **args,
9565                          tree conversion_path, int flags,
9566                          tree *fn_p, tsubst_flags_t complain)
9567 {
9568   struct z_candidate *candidates = 0, *cand;
9569   tree explicit_targs = NULL_TREE;
9570   tree basetype = NULL_TREE;
9571   tree access_binfo;
9572   tree optype;
9573   tree first_mem_arg = NULL_TREE;
9574   tree name;
9575   bool skip_first_for_error;
9576   vec<tree, va_gc> *user_args;
9577   tree call;
9578   tree fn;
9579   int template_only = 0;
9580   bool any_viable_p;
9581   tree orig_instance;
9582   tree orig_fns;
9583   vec<tree, va_gc> *orig_args = NULL;
9584   void *p;
9585
9586   gcc_assert (instance != NULL_TREE);
9587
9588   /* We don't know what function we're going to call, yet.  */
9589   if (fn_p)
9590     *fn_p = NULL_TREE;
9591
9592   if (error_operand_p (instance)
9593       || !fns || error_operand_p (fns))
9594     return error_mark_node;
9595
9596   if (!BASELINK_P (fns))
9597     {
9598       if (complain & tf_error)
9599         error ("call to non-function %qD", fns);
9600       return error_mark_node;
9601     }
9602
9603   orig_instance = instance;
9604   orig_fns = fns;
9605
9606   /* Dismantle the baselink to collect all the information we need.  */
9607   if (!conversion_path)
9608     conversion_path = BASELINK_BINFO (fns);
9609   access_binfo = BASELINK_ACCESS_BINFO (fns);
9610   optype = BASELINK_OPTYPE (fns);
9611   fns = BASELINK_FUNCTIONS (fns);
9612   if (TREE_CODE (fns) == TEMPLATE_ID_EXPR)
9613     {
9614       explicit_targs = TREE_OPERAND (fns, 1);
9615       fns = TREE_OPERAND (fns, 0);
9616       template_only = 1;
9617     }
9618   gcc_assert (OVL_P (fns));
9619   fn = OVL_FIRST (fns);
9620   name = DECL_NAME (fn);
9621
9622   basetype = TYPE_MAIN_VARIANT (TREE_TYPE (instance));
9623   gcc_assert (CLASS_TYPE_P (basetype));
9624
9625   user_args = args == NULL ? NULL : *args;
9626   /* Under DR 147 A::A() is an invalid constructor call,
9627      not a functional cast.  */
9628   if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (fn))
9629     {
9630       if (! (complain & tf_error))
9631         return error_mark_node;
9632
9633       basetype = DECL_CONTEXT (fn);
9634       name = constructor_name (basetype);
9635       auto_diagnostic_group d;
9636       if (permerror (input_location,
9637                      "cannot call constructor %<%T::%D%> directly",
9638                      basetype, name))
9639         inform (input_location, "for a function-style cast, remove the "
9640                 "redundant %<::%D%>", name);
9641       call = build_functional_cast (basetype, build_tree_list_vec (user_args),
9642                                     complain);
9643       return call;
9644     }
9645
9646   if (processing_template_decl)
9647     {
9648       orig_args = args == NULL ? NULL : make_tree_vector_copy (*args);
9649       instance = build_non_dependent_expr (instance);
9650       if (args != NULL)
9651         make_args_non_dependent (*args);
9652     }
9653
9654   /* Process the argument list.  */
9655   if (args != NULL && *args != NULL)
9656     {
9657       *args = resolve_args (*args, complain);
9658       if (*args == NULL)
9659         return error_mark_node;
9660       user_args = *args;
9661     }
9662
9663   /* Consider the object argument to be used even if we end up selecting a
9664      static member function.  */
9665   instance = mark_type_use (instance);
9666
9667   /* Figure out whether to skip the first argument for the error
9668      message we will display to users if an error occurs.  We don't
9669      want to display any compiler-generated arguments.  The "this"
9670      pointer hasn't been added yet.  However, we must remove the VTT
9671      pointer if this is a call to a base-class constructor or
9672      destructor.  */
9673   skip_first_for_error = false;
9674   if (IDENTIFIER_CDTOR_P (name))
9675     {
9676       /* Callers should explicitly indicate whether they want to ctor
9677          the complete object or just the part without virtual bases.  */
9678       gcc_assert (name != ctor_identifier);
9679
9680       /* Remove the VTT pointer, if present.  */
9681       if ((name == base_ctor_identifier || name == base_dtor_identifier)
9682           && CLASSTYPE_VBASECLASSES (basetype))
9683         skip_first_for_error = true;
9684
9685       /* It's OK to call destructors and constructors on cv-qualified
9686          objects.  Therefore, convert the INSTANCE to the unqualified
9687          type, if necessary.  */
9688       if (!same_type_p (basetype, TREE_TYPE (instance)))
9689         {
9690           instance = build_this (instance);
9691           instance = build_nop (build_pointer_type (basetype), instance);
9692           instance = build_fold_indirect_ref (instance);
9693         }
9694     }
9695   else
9696     gcc_assert (!DECL_DESTRUCTOR_P (fn) && !DECL_CONSTRUCTOR_P (fn));
9697
9698   /* For the overload resolution we need to find the actual `this`
9699      that would be captured if the call turns out to be to a
9700      non-static member function.  Do not actually capture it at this
9701      point.  */
9702   if (DECL_CONSTRUCTOR_P (fn))
9703     /* Constructors don't use the enclosing 'this'.  */
9704     first_mem_arg = instance;
9705   else
9706     first_mem_arg = maybe_resolve_dummy (instance, false);
9707
9708   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
9709   p = conversion_obstack_alloc (0);
9710
9711   /* The number of arguments artificial parms in ARGS; we subtract one because
9712      there's no 'this' in ARGS.  */
9713   unsigned skip = num_artificial_parms_for (fn) - 1;
9714
9715   /* If CONSTRUCTOR_IS_DIRECT_INIT is set, this was a T{ } form
9716      initializer, not T({ }).  */
9717   if (DECL_CONSTRUCTOR_P (fn)
9718       && vec_safe_length (user_args) > skip
9719       && DIRECT_LIST_INIT_P ((*user_args)[skip]))
9720     {
9721       tree init_list = (*user_args)[skip];
9722       tree init = NULL_TREE;
9723
9724       gcc_assert (user_args->length () == skip + 1
9725                   && !(flags & LOOKUP_ONLYCONVERTING));
9726
9727       /* If the initializer list has no elements and T is a class type with
9728          a default constructor, the object is value-initialized.  Handle
9729          this here so we don't need to handle it wherever we use
9730          build_special_member_call.  */
9731       if (CONSTRUCTOR_NELTS (init_list) == 0
9732           && TYPE_HAS_DEFAULT_CONSTRUCTOR (basetype)
9733           /* For a user-provided default constructor, use the normal
9734              mechanisms so that protected access works.  */
9735           && type_has_non_user_provided_default_constructor (basetype)
9736           && !processing_template_decl)
9737         init = build_value_init (basetype, complain);
9738
9739       /* If BASETYPE is an aggregate, we need to do aggregate
9740          initialization.  */
9741       else if (CP_AGGREGATE_TYPE_P (basetype))
9742         {
9743           init = reshape_init (basetype, init_list, complain);
9744           init = digest_init (basetype, init, complain);
9745         }
9746
9747       if (init)
9748         {
9749           if (is_dummy_object (instance))
9750             return get_target_expr_sfinae (init, complain);
9751           init = build2 (INIT_EXPR, TREE_TYPE (instance), instance, init);
9752           TREE_SIDE_EFFECTS (init) = true;
9753           return init;
9754         }
9755
9756       /* Otherwise go ahead with overload resolution.  */
9757       add_list_candidates (fns, first_mem_arg, user_args,
9758                            basetype, explicit_targs, template_only,
9759                            conversion_path, access_binfo, flags,
9760                            &candidates, complain);
9761     }
9762   else
9763     add_candidates (fns, first_mem_arg, user_args, optype,
9764                     explicit_targs, template_only, conversion_path,
9765                     access_binfo, flags, &candidates, complain);
9766
9767   any_viable_p = false;
9768   candidates = splice_viable (candidates, false, &any_viable_p);
9769
9770   if (!any_viable_p)
9771     {
9772       if (complain & tf_error)
9773         complain_about_no_candidates_for_method_call (instance, candidates,
9774                                                       explicit_targs, basetype,
9775                                                       optype, name,
9776                                                       skip_first_for_error,
9777                                                       user_args);
9778       call = error_mark_node;
9779     }
9780   else
9781     {
9782       cand = tourney (candidates, complain);
9783       if (cand == 0)
9784         {
9785           char *pretty_name;
9786           bool free_p;
9787           tree arglist;
9788
9789           if (complain & tf_error)
9790             {
9791               pretty_name = name_as_c_string (name, basetype, &free_p);
9792               arglist = build_tree_list_vec (user_args);
9793               if (skip_first_for_error)
9794                 arglist = TREE_CHAIN (arglist);
9795               auto_diagnostic_group d;
9796               if (!any_strictly_viable (candidates))
9797                 error ("no matching function for call to %<%s(%A)%>",
9798                        pretty_name, arglist);
9799               else
9800                 error ("call of overloaded %<%s(%A)%> is ambiguous",
9801                        pretty_name, arglist);
9802               print_z_candidates (location_of (name), candidates);
9803               if (free_p)
9804                 free (pretty_name);
9805             }
9806           call = error_mark_node;
9807         }
9808       else
9809         {
9810           fn = cand->fn;
9811           call = NULL_TREE;
9812
9813           if (!(flags & LOOKUP_NONVIRTUAL)
9814               && DECL_PURE_VIRTUAL_P (fn)
9815               && instance == current_class_ref
9816               && (complain & tf_warning))
9817             {
9818               /* This is not an error, it is runtime undefined
9819                  behavior.  */
9820               if (!current_function_decl)
9821                 warning (0, "pure virtual %q#D called from "
9822                          "non-static data member initializer", fn);
9823               else if (DECL_CONSTRUCTOR_P (current_function_decl)
9824                        || DECL_DESTRUCTOR_P (current_function_decl))
9825                 warning (0, (DECL_CONSTRUCTOR_P (current_function_decl)
9826                              ? G_("pure virtual %q#D called from constructor")
9827                              : G_("pure virtual %q#D called from destructor")),
9828                          fn);
9829             }
9830
9831           if (TREE_CODE (TREE_TYPE (fn)) == METHOD_TYPE
9832               && !DECL_CONSTRUCTOR_P (fn)
9833               && is_dummy_object (instance))
9834             {
9835               instance = maybe_resolve_dummy (instance, true);
9836               if (instance == error_mark_node)
9837                 call = error_mark_node;
9838               else if (!is_dummy_object (instance))
9839                 {
9840                   /* We captured 'this' in the current lambda now that
9841                      we know we really need it.  */
9842                   cand->first_arg = instance;
9843                 }
9844               else if (any_dependent_bases_p ())
9845                 /* We can't tell until instantiation time whether we can use
9846                    *this as the implicit object argument.  */;
9847               else
9848                 {
9849                   if (complain & tf_error)
9850                     error ("cannot call member function %qD without object",
9851                            fn);
9852                   call = error_mark_node;
9853                 }
9854             }
9855
9856           if (call != error_mark_node)
9857             {
9858               if (explicit_targs)
9859                 flags |= LOOKUP_EXPLICIT_TMPL_ARGS;
9860               /* Now we know what function is being called.  */
9861               if (fn_p)
9862                 *fn_p = fn;
9863               /* Build the actual CALL_EXPR.  */
9864               call = build_over_call (cand, flags, complain);
9865               /* In an expression of the form `a->f()' where `f' turns
9866                  out to be a static member function, `a' is
9867                  none-the-less evaluated.  */
9868               if (TREE_CODE (TREE_TYPE (fn)) != METHOD_TYPE
9869                   && !is_dummy_object (instance)
9870                   && TREE_SIDE_EFFECTS (instance))
9871                 {
9872                   /* But avoid the implicit lvalue-rvalue conversion when 'a'
9873                      is volatile.  */
9874                   tree a = instance;
9875                   if (TREE_THIS_VOLATILE (a))
9876                     a = build_this (a);
9877                   call = build2 (COMPOUND_EXPR, TREE_TYPE (call), a, call);
9878                 }
9879               else if (call != error_mark_node
9880                        && DECL_DESTRUCTOR_P (cand->fn)
9881                        && !VOID_TYPE_P (TREE_TYPE (call)))
9882                 /* An explicit call of the form "x->~X()" has type
9883                    "void".  However, on platforms where destructors
9884                    return "this" (i.e., those where
9885                    targetm.cxx.cdtor_returns_this is true), such calls
9886                    will appear to have a return value of pointer type
9887                    to the low-level call machinery.  We do not want to
9888                    change the low-level machinery, since we want to be
9889                    able to optimize "delete f()" on such platforms as
9890                    "operator delete(~X(f()))" (rather than generating
9891                    "t = f(), ~X(t), operator delete (t)").  */
9892                 call = build_nop (void_type_node, call);
9893             }
9894         }
9895     }
9896
9897   if (processing_template_decl && call != error_mark_node)
9898     {
9899       bool cast_to_void = false;
9900
9901       if (TREE_CODE (call) == COMPOUND_EXPR)
9902         call = TREE_OPERAND (call, 1);
9903       else if (TREE_CODE (call) == NOP_EXPR)
9904         {
9905           cast_to_void = true;
9906           call = TREE_OPERAND (call, 0);
9907         }
9908       if (INDIRECT_REF_P (call))
9909         call = TREE_OPERAND (call, 0);
9910       call = (build_min_non_dep_call_vec
9911               (call,
9912                build_min (COMPONENT_REF, TREE_TYPE (CALL_EXPR_FN (call)),
9913                           orig_instance, orig_fns, NULL_TREE),
9914                orig_args));
9915       SET_EXPR_LOCATION (call, input_location);
9916       call = convert_from_reference (call);
9917       if (cast_to_void)
9918         call = build_nop (void_type_node, call);
9919     }
9920
9921  /* Free all the conversions we allocated.  */
9922   obstack_free (&conversion_obstack, p);
9923
9924   if (orig_args != NULL)
9925     release_tree_vector (orig_args);
9926
9927   return call;
9928 }
9929
9930 /* Wrapper for above.  */
9931
9932 tree
9933 build_new_method_call (tree instance, tree fns, vec<tree, va_gc> **args,
9934                        tree conversion_path, int flags,
9935                        tree *fn_p, tsubst_flags_t complain)
9936 {
9937   tree ret;
9938   bool subtime = timevar_cond_start (TV_OVERLOAD);
9939   ret = build_new_method_call_1 (instance, fns, args, conversion_path, flags,
9940                                  fn_p, complain);
9941   timevar_cond_stop (TV_OVERLOAD, subtime);
9942   return ret;
9943 }
9944
9945 /* Returns true iff standard conversion sequence ICS1 is a proper
9946    subsequence of ICS2.  */
9947
9948 static bool
9949 is_subseq (conversion *ics1, conversion *ics2)
9950 {
9951   /* We can assume that a conversion of the same code
9952      between the same types indicates a subsequence since we only get
9953      here if the types we are converting from are the same.  */
9954
9955   while (ics1->kind == ck_rvalue
9956          || ics1->kind == ck_lvalue)
9957     ics1 = next_conversion (ics1);
9958
9959   while (1)
9960     {
9961       while (ics2->kind == ck_rvalue
9962              || ics2->kind == ck_lvalue)
9963         ics2 = next_conversion (ics2);
9964
9965       if (ics2->kind == ck_user
9966           || ics2->kind == ck_ambig
9967           || ics2->kind == ck_aggr
9968           || ics2->kind == ck_list
9969           || ics2->kind == ck_identity)
9970         /* At this point, ICS1 cannot be a proper subsequence of
9971            ICS2.  We can get a USER_CONV when we are comparing the
9972            second standard conversion sequence of two user conversion
9973            sequences.  */
9974         return false;
9975
9976       ics2 = next_conversion (ics2);
9977
9978       while (ics2->kind == ck_rvalue
9979              || ics2->kind == ck_lvalue)
9980         ics2 = next_conversion (ics2);
9981
9982       if (ics2->kind == ics1->kind
9983           && same_type_p (ics2->type, ics1->type)
9984           && (ics1->kind == ck_identity
9985               || same_type_p (next_conversion (ics2)->type,
9986                               next_conversion (ics1)->type)))
9987         return true;
9988     }
9989 }
9990
9991 /* Returns nonzero iff DERIVED is derived from BASE.  The inputs may
9992    be any _TYPE nodes.  */
9993
9994 bool
9995 is_properly_derived_from (tree derived, tree base)
9996 {
9997   if (!CLASS_TYPE_P (derived) || !CLASS_TYPE_P (base))
9998     return false;
9999
10000   /* We only allow proper derivation here.  The DERIVED_FROM_P macro
10001      considers every class derived from itself.  */
10002   return (!same_type_ignoring_top_level_qualifiers_p (derived, base)
10003           && DERIVED_FROM_P (base, derived));
10004 }
10005
10006 /* We build the ICS for an implicit object parameter as a pointer
10007    conversion sequence.  However, such a sequence should be compared
10008    as if it were a reference conversion sequence.  If ICS is the
10009    implicit conversion sequence for an implicit object parameter,
10010    modify it accordingly.  */
10011
10012 static void
10013 maybe_handle_implicit_object (conversion **ics)
10014 {
10015   if ((*ics)->this_p)
10016     {
10017       /* [over.match.funcs]
10018
10019          For non-static member functions, the type of the
10020          implicit object parameter is "reference to cv X"
10021          where X is the class of which the function is a
10022          member and cv is the cv-qualification on the member
10023          function declaration.  */
10024       conversion *t = *ics;
10025       tree reference_type;
10026
10027       /* The `this' parameter is a pointer to a class type.  Make the
10028          implicit conversion talk about a reference to that same class
10029          type.  */
10030       reference_type = TREE_TYPE (t->type);
10031       reference_type = build_reference_type (reference_type);
10032
10033       if (t->kind == ck_qual)
10034         t = next_conversion (t);
10035       if (t->kind == ck_ptr)
10036         t = next_conversion (t);
10037       t = build_identity_conv (TREE_TYPE (t->type), NULL_TREE);
10038       t = direct_reference_binding (reference_type, t);
10039       t->this_p = 1;
10040       t->rvaluedness_matches_p = 0;
10041       *ics = t;
10042     }
10043 }
10044
10045 /* If *ICS is a REF_BIND set *ICS to the remainder of the conversion,
10046    and return the initial reference binding conversion. Otherwise,
10047    leave *ICS unchanged and return NULL.  */
10048
10049 static conversion *
10050 maybe_handle_ref_bind (conversion **ics)
10051 {
10052   if ((*ics)->kind == ck_ref_bind)
10053     {
10054       conversion *old_ics = *ics;
10055       *ics = next_conversion (old_ics);
10056       (*ics)->user_conv_p = old_ics->user_conv_p;
10057       return old_ics;
10058     }
10059
10060   return NULL;
10061 }
10062
10063 /* Compare two implicit conversion sequences according to the rules set out in
10064    [over.ics.rank].  Return values:
10065
10066       1: ics1 is better than ics2
10067      -1: ics2 is better than ics1
10068       0: ics1 and ics2 are indistinguishable */
10069
10070 static int
10071 compare_ics (conversion *ics1, conversion *ics2)
10072 {
10073   tree from_type1;
10074   tree from_type2;
10075   tree to_type1;
10076   tree to_type2;
10077   tree deref_from_type1 = NULL_TREE;
10078   tree deref_from_type2 = NULL_TREE;
10079   tree deref_to_type1 = NULL_TREE;
10080   tree deref_to_type2 = NULL_TREE;
10081   conversion_rank rank1, rank2;
10082
10083   /* REF_BINDING is nonzero if the result of the conversion sequence
10084      is a reference type.   In that case REF_CONV is the reference
10085      binding conversion. */
10086   conversion *ref_conv1;
10087   conversion *ref_conv2;
10088
10089   /* Compare badness before stripping the reference conversion.  */
10090   if (ics1->bad_p > ics2->bad_p)
10091     return -1;
10092   else if (ics1->bad_p < ics2->bad_p)
10093     return 1;
10094
10095   /* Handle implicit object parameters.  */
10096   maybe_handle_implicit_object (&ics1);
10097   maybe_handle_implicit_object (&ics2);
10098
10099   /* Handle reference parameters.  */
10100   ref_conv1 = maybe_handle_ref_bind (&ics1);
10101   ref_conv2 = maybe_handle_ref_bind (&ics2);
10102
10103   /* List-initialization sequence L1 is a better conversion sequence than
10104      list-initialization sequence L2 if L1 converts to
10105      std::initializer_list<X> for some X and L2 does not.  */
10106   if (ics1->kind == ck_list && ics2->kind != ck_list)
10107     return 1;
10108   if (ics2->kind == ck_list && ics1->kind != ck_list)
10109     return -1;
10110
10111   /* [over.ics.rank]
10112
10113      When  comparing  the  basic forms of implicit conversion sequences (as
10114      defined in _over.best.ics_)
10115
10116      --a standard conversion sequence (_over.ics.scs_) is a better
10117        conversion sequence than a user-defined conversion sequence
10118        or an ellipsis conversion sequence, and
10119
10120      --a user-defined conversion sequence (_over.ics.user_) is a
10121        better conversion sequence than an ellipsis conversion sequence
10122        (_over.ics.ellipsis_).  */
10123   /* Use BAD_CONVERSION_RANK because we already checked for a badness
10124      mismatch.  If both ICS are bad, we try to make a decision based on
10125      what would have happened if they'd been good.  This is not an
10126      extension, we'll still give an error when we build up the call; this
10127      just helps us give a more helpful error message.  */
10128   rank1 = BAD_CONVERSION_RANK (ics1);
10129   rank2 = BAD_CONVERSION_RANK (ics2);
10130
10131   if (rank1 > rank2)
10132     return -1;
10133   else if (rank1 < rank2)
10134     return 1;
10135
10136   if (ics1->ellipsis_p)
10137     /* Both conversions are ellipsis conversions.  */
10138     return 0;
10139
10140   /* User-defined  conversion sequence U1 is a better conversion sequence
10141      than another user-defined conversion sequence U2 if they contain the
10142      same user-defined conversion operator or constructor and if the sec-
10143      ond standard conversion sequence of U1 is  better  than  the  second
10144      standard conversion sequence of U2.  */
10145
10146   /* Handle list-conversion with the same code even though it isn't always
10147      ranked as a user-defined conversion and it doesn't have a second
10148      standard conversion sequence; it will still have the desired effect.
10149      Specifically, we need to do the reference binding comparison at the
10150      end of this function.  */
10151
10152   if (ics1->user_conv_p || ics1->kind == ck_list
10153       || ics1->kind == ck_aggr || ics2->kind == ck_aggr)
10154     {
10155       conversion *t1;
10156       conversion *t2;
10157
10158       for (t1 = ics1; t1 && t1->kind != ck_user; t1 = next_conversion (t1))
10159         if (t1->kind == ck_ambig || t1->kind == ck_aggr
10160             || t1->kind == ck_list)
10161           break;
10162       for (t2 = ics2; t2 && t2->kind != ck_user; t2 = next_conversion (t2))
10163         if (t2->kind == ck_ambig || t2->kind == ck_aggr
10164             || t2->kind == ck_list)
10165           break;
10166
10167       if (!t1 || !t2 || t1->kind != t2->kind)
10168         return 0;
10169       else if (t1->kind == ck_user)
10170         {
10171           tree f1 = t1->cand ? t1->cand->fn : t1->type;
10172           tree f2 = t2->cand ? t2->cand->fn : t2->type;
10173           if (f1 != f2)
10174             return 0;
10175         }
10176       else
10177         {
10178           /* For ambiguous or aggregate conversions, use the target type as
10179              a proxy for the conversion function.  */
10180           if (!same_type_ignoring_top_level_qualifiers_p (t1->type, t2->type))
10181             return 0;
10182         }
10183
10184       /* We can just fall through here, after setting up
10185          FROM_TYPE1 and FROM_TYPE2.  */
10186       from_type1 = t1->type;
10187       from_type2 = t2->type;
10188     }
10189   else
10190     {
10191       conversion *t1;
10192       conversion *t2;
10193
10194       /* We're dealing with two standard conversion sequences.
10195
10196          [over.ics.rank]
10197
10198          Standard conversion sequence S1 is a better conversion
10199          sequence than standard conversion sequence S2 if
10200
10201          --S1 is a proper subsequence of S2 (comparing the conversion
10202            sequences in the canonical form defined by _over.ics.scs_,
10203            excluding any Lvalue Transformation; the identity
10204            conversion sequence is considered to be a subsequence of
10205            any non-identity conversion sequence */
10206
10207       t1 = ics1;
10208       while (t1->kind != ck_identity)
10209         t1 = next_conversion (t1);
10210       from_type1 = t1->type;
10211
10212       t2 = ics2;
10213       while (t2->kind != ck_identity)
10214         t2 = next_conversion (t2);
10215       from_type2 = t2->type;
10216     }
10217
10218   /* One sequence can only be a subsequence of the other if they start with
10219      the same type.  They can start with different types when comparing the
10220      second standard conversion sequence in two user-defined conversion
10221      sequences.  */
10222   if (same_type_p (from_type1, from_type2))
10223     {
10224       if (is_subseq (ics1, ics2))
10225         return 1;
10226       if (is_subseq (ics2, ics1))
10227         return -1;
10228     }
10229
10230   /* [over.ics.rank]
10231
10232      Or, if not that,
10233
10234      --the rank of S1 is better than the rank of S2 (by the rules
10235        defined below):
10236
10237     Standard conversion sequences are ordered by their ranks: an Exact
10238     Match is a better conversion than a Promotion, which is a better
10239     conversion than a Conversion.
10240
10241     Two conversion sequences with the same rank are indistinguishable
10242     unless one of the following rules applies:
10243
10244     --A conversion that does not a convert a pointer, pointer to member,
10245       or std::nullptr_t to bool is better than one that does.
10246
10247     The ICS_STD_RANK automatically handles the pointer-to-bool rule,
10248     so that we do not have to check it explicitly.  */
10249   if (ics1->rank < ics2->rank)
10250     return 1;
10251   else if (ics2->rank < ics1->rank)
10252     return -1;
10253
10254   to_type1 = ics1->type;
10255   to_type2 = ics2->type;
10256
10257   /* A conversion from scalar arithmetic type to complex is worse than a
10258      conversion between scalar arithmetic types.  */
10259   if (same_type_p (from_type1, from_type2)
10260       && ARITHMETIC_TYPE_P (from_type1)
10261       && ARITHMETIC_TYPE_P (to_type1)
10262       && ARITHMETIC_TYPE_P (to_type2)
10263       && ((TREE_CODE (to_type1) == COMPLEX_TYPE)
10264           != (TREE_CODE (to_type2) == COMPLEX_TYPE)))
10265     {
10266       if (TREE_CODE (to_type1) == COMPLEX_TYPE)
10267         return -1;
10268       else
10269         return 1;
10270     }
10271
10272   if (TYPE_PTR_P (from_type1)
10273       && TYPE_PTR_P (from_type2)
10274       && TYPE_PTR_P (to_type1)
10275       && TYPE_PTR_P (to_type2))
10276     {
10277       deref_from_type1 = TREE_TYPE (from_type1);
10278       deref_from_type2 = TREE_TYPE (from_type2);
10279       deref_to_type1 = TREE_TYPE (to_type1);
10280       deref_to_type2 = TREE_TYPE (to_type2);
10281     }
10282   /* The rules for pointers to members A::* are just like the rules
10283      for pointers A*, except opposite: if B is derived from A then
10284      A::* converts to B::*, not vice versa.  For that reason, we
10285      switch the from_ and to_ variables here.  */
10286   else if ((TYPE_PTRDATAMEM_P (from_type1) && TYPE_PTRDATAMEM_P (from_type2)
10287             && TYPE_PTRDATAMEM_P (to_type1) && TYPE_PTRDATAMEM_P (to_type2))
10288            || (TYPE_PTRMEMFUNC_P (from_type1)
10289                && TYPE_PTRMEMFUNC_P (from_type2)
10290                && TYPE_PTRMEMFUNC_P (to_type1)
10291                && TYPE_PTRMEMFUNC_P (to_type2)))
10292     {
10293       deref_to_type1 = TYPE_PTRMEM_CLASS_TYPE (from_type1);
10294       deref_to_type2 = TYPE_PTRMEM_CLASS_TYPE (from_type2);
10295       deref_from_type1 = TYPE_PTRMEM_CLASS_TYPE (to_type1);
10296       deref_from_type2 = TYPE_PTRMEM_CLASS_TYPE (to_type2);
10297     }
10298
10299   if (deref_from_type1 != NULL_TREE
10300       && RECORD_OR_UNION_CODE_P (TREE_CODE (deref_from_type1))
10301       && RECORD_OR_UNION_CODE_P (TREE_CODE (deref_from_type2)))
10302     {
10303       /* This was one of the pointer or pointer-like conversions.
10304
10305          [over.ics.rank]
10306
10307          --If class B is derived directly or indirectly from class A,
10308            conversion of B* to A* is better than conversion of B* to
10309            void*, and conversion of A* to void* is better than
10310            conversion of B* to void*.  */
10311       if (VOID_TYPE_P (deref_to_type1)
10312           && VOID_TYPE_P (deref_to_type2))
10313         {
10314           if (is_properly_derived_from (deref_from_type1,
10315                                         deref_from_type2))
10316             return -1;
10317           else if (is_properly_derived_from (deref_from_type2,
10318                                              deref_from_type1))
10319             return 1;
10320         }
10321       else if (VOID_TYPE_P (deref_to_type1)
10322                || VOID_TYPE_P (deref_to_type2))
10323         {
10324           if (same_type_p (deref_from_type1, deref_from_type2))
10325             {
10326               if (VOID_TYPE_P (deref_to_type2))
10327                 {
10328                   if (is_properly_derived_from (deref_from_type1,
10329                                                 deref_to_type1))
10330                     return 1;
10331                 }
10332               /* We know that DEREF_TO_TYPE1 is `void' here.  */
10333               else if (is_properly_derived_from (deref_from_type1,
10334                                                  deref_to_type2))
10335                 return -1;
10336             }
10337         }
10338       else if (RECORD_OR_UNION_CODE_P (TREE_CODE (deref_to_type1))
10339                && RECORD_OR_UNION_CODE_P (TREE_CODE (deref_to_type2)))
10340         {
10341           /* [over.ics.rank]
10342
10343              --If class B is derived directly or indirectly from class A
10344                and class C is derived directly or indirectly from B,
10345
10346              --conversion of C* to B* is better than conversion of C* to
10347                A*,
10348
10349              --conversion of B* to A* is better than conversion of C* to
10350                A*  */
10351           if (same_type_p (deref_from_type1, deref_from_type2))
10352             {
10353               if (is_properly_derived_from (deref_to_type1,
10354                                             deref_to_type2))
10355                 return 1;
10356               else if (is_properly_derived_from (deref_to_type2,
10357                                                  deref_to_type1))
10358                 return -1;
10359             }
10360           else if (same_type_p (deref_to_type1, deref_to_type2))
10361             {
10362               if (is_properly_derived_from (deref_from_type2,
10363                                             deref_from_type1))
10364                 return 1;
10365               else if (is_properly_derived_from (deref_from_type1,
10366                                                  deref_from_type2))
10367                 return -1;
10368             }
10369         }
10370     }
10371   else if (CLASS_TYPE_P (non_reference (from_type1))
10372            && same_type_p (from_type1, from_type2))
10373     {
10374       tree from = non_reference (from_type1);
10375
10376       /* [over.ics.rank]
10377
10378          --binding of an expression of type C to a reference of type
10379            B& is better than binding an expression of type C to a
10380            reference of type A&
10381
10382          --conversion of C to B is better than conversion of C to A,  */
10383       if (is_properly_derived_from (from, to_type1)
10384           && is_properly_derived_from (from, to_type2))
10385         {
10386           if (is_properly_derived_from (to_type1, to_type2))
10387             return 1;
10388           else if (is_properly_derived_from (to_type2, to_type1))
10389             return -1;
10390         }
10391     }
10392   else if (CLASS_TYPE_P (non_reference (to_type1))
10393            && same_type_p (to_type1, to_type2))
10394     {
10395       tree to = non_reference (to_type1);
10396
10397       /* [over.ics.rank]
10398
10399          --binding of an expression of type B to a reference of type
10400            A& is better than binding an expression of type C to a
10401            reference of type A&,
10402
10403          --conversion of B to A is better than conversion of C to A  */
10404       if (is_properly_derived_from (from_type1, to)
10405           && is_properly_derived_from (from_type2, to))
10406         {
10407           if (is_properly_derived_from (from_type2, from_type1))
10408             return 1;
10409           else if (is_properly_derived_from (from_type1, from_type2))
10410             return -1;
10411         }
10412     }
10413
10414   /* [over.ics.rank]
10415
10416      --S1 and S2 differ only in their qualification conversion and  yield
10417        similar  types  T1 and T2 (_conv.qual_), respectively, and the cv-
10418        qualification signature of type T1 is a proper subset of  the  cv-
10419        qualification signature of type T2  */
10420   if (ics1->kind == ck_qual
10421       && ics2->kind == ck_qual
10422       && same_type_p (from_type1, from_type2))
10423     {
10424       int result = comp_cv_qual_signature (to_type1, to_type2);
10425       if (result != 0)
10426         return result;
10427     }
10428
10429   /* [over.ics.rank]
10430
10431      --S1 and S2 are reference bindings (_dcl.init.ref_) and neither refers
10432      to an implicit object parameter of a non-static member function
10433      declared without a ref-qualifier, and either S1 binds an lvalue
10434      reference to an lvalue and S2 binds an rvalue reference or S1 binds an
10435      rvalue reference to an rvalue and S2 binds an lvalue reference (C++0x
10436      draft standard, 13.3.3.2)
10437
10438      --S1 and S2 are reference bindings (_dcl.init.ref_), and the
10439      types to which the references refer are the same type except for
10440      top-level cv-qualifiers, and the type to which the reference
10441      initialized by S2 refers is more cv-qualified than the type to
10442      which the reference initialized by S1 refers.
10443
10444      DR 1328 [over.match.best]: the context is an initialization by
10445      conversion function for direct reference binding (13.3.1.6) of a
10446      reference to function type, the return type of F1 is the same kind of
10447      reference (i.e. lvalue or rvalue) as the reference being initialized,
10448      and the return type of F2 is not.  */
10449
10450   if (ref_conv1 && ref_conv2)
10451     {
10452       if (!ref_conv1->this_p && !ref_conv2->this_p
10453           && (ref_conv1->rvaluedness_matches_p
10454               != ref_conv2->rvaluedness_matches_p)
10455           && (same_type_p (ref_conv1->type, ref_conv2->type)
10456               || (TYPE_REF_IS_RVALUE (ref_conv1->type)
10457                   != TYPE_REF_IS_RVALUE (ref_conv2->type))))
10458         {
10459           if (ref_conv1->bad_p
10460               && !same_type_p (TREE_TYPE (ref_conv1->type),
10461                                TREE_TYPE (ref_conv2->type)))
10462             /* Don't prefer a bad conversion that drops cv-quals to a bad
10463                conversion with the wrong rvalueness.  */
10464             return 0;
10465           return (ref_conv1->rvaluedness_matches_p
10466                   - ref_conv2->rvaluedness_matches_p);
10467         }
10468
10469       if (same_type_ignoring_top_level_qualifiers_p (to_type1, to_type2))
10470         {
10471           int q1 = cp_type_quals (TREE_TYPE (ref_conv1->type));
10472           int q2 = cp_type_quals (TREE_TYPE (ref_conv2->type));
10473           if (ref_conv1->bad_p)
10474             {
10475               /* Prefer the one that drops fewer cv-quals.  */
10476               tree ftype = next_conversion (ref_conv1)->type;
10477               int fquals = cp_type_quals (ftype);
10478               q1 ^= fquals;
10479               q2 ^= fquals;
10480             }
10481           return comp_cv_qualification (q2, q1);
10482         }
10483     }
10484
10485   /* Neither conversion sequence is better than the other.  */
10486   return 0;
10487 }
10488
10489 /* The source type for this standard conversion sequence.  */
10490
10491 static tree
10492 source_type (conversion *t)
10493 {
10494   for (;; t = next_conversion (t))
10495     {
10496       if (t->kind == ck_user
10497           || t->kind == ck_ambig
10498           || t->kind == ck_identity)
10499         return t->type;
10500     }
10501   gcc_unreachable ();
10502 }
10503
10504 /* Note a warning about preferring WINNER to LOSER.  We do this by storing
10505    a pointer to LOSER and re-running joust to produce the warning if WINNER
10506    is actually used.  */
10507
10508 static void
10509 add_warning (struct z_candidate *winner, struct z_candidate *loser)
10510 {
10511   candidate_warning *cw = (candidate_warning *)
10512     conversion_obstack_alloc (sizeof (candidate_warning));
10513   cw->loser = loser;
10514   cw->next = winner->warnings;
10515   winner->warnings = cw;
10516 }
10517
10518 /* CAND is a constructor candidate in joust in C++17 and up.  If it copies a
10519    prvalue returned from a conversion function, replace CAND with the candidate
10520    for the conversion and return true.  Otherwise, return false.  */
10521
10522 static bool
10523 joust_maybe_elide_copy (z_candidate *&cand)
10524 {
10525   tree fn = cand->fn;
10526   if (!DECL_COPY_CONSTRUCTOR_P (fn) && !DECL_MOVE_CONSTRUCTOR_P (fn))
10527     return false;
10528   conversion *conv = cand->convs[0];
10529   gcc_checking_assert (conv->kind == ck_ref_bind);
10530   conv = next_conversion (conv);
10531   if (conv->kind == ck_user && !TYPE_REF_P (conv->type))
10532     {
10533       gcc_checking_assert (same_type_ignoring_top_level_qualifiers_p
10534                            (conv->type, DECL_CONTEXT (fn)));
10535       z_candidate *uc = conv->cand;
10536       if (DECL_CONV_FN_P (uc->fn))
10537         {
10538           cand = uc;
10539           return true;
10540         }
10541     }
10542   return false;
10543 }
10544
10545 /* Compare two candidates for overloading as described in
10546    [over.match.best].  Return values:
10547
10548       1: cand1 is better than cand2
10549      -1: cand2 is better than cand1
10550       0: cand1 and cand2 are indistinguishable */
10551
10552 static int
10553 joust (struct z_candidate *cand1, struct z_candidate *cand2, bool warn,
10554        tsubst_flags_t complain)
10555 {
10556   int winner = 0;
10557   int off1 = 0, off2 = 0;
10558   size_t i;
10559   size_t len;
10560
10561   /* Candidates that involve bad conversions are always worse than those
10562      that don't.  */
10563   if (cand1->viable > cand2->viable)
10564     return 1;
10565   if (cand1->viable < cand2->viable)
10566     return -1;
10567
10568   /* If we have two pseudo-candidates for conversions to the same type,
10569      or two candidates for the same function, arbitrarily pick one.  */
10570   if (cand1->fn == cand2->fn
10571       && (IS_TYPE_OR_DECL_P (cand1->fn)))
10572     return 1;
10573
10574   /* Prefer a non-deleted function over an implicitly deleted move
10575      constructor or assignment operator.  This differs slightly from the
10576      wording for issue 1402 (which says the move op is ignored by overload
10577      resolution), but this way produces better error messages.  */
10578   if (TREE_CODE (cand1->fn) == FUNCTION_DECL
10579       && TREE_CODE (cand2->fn) == FUNCTION_DECL
10580       && DECL_DELETED_FN (cand1->fn) != DECL_DELETED_FN (cand2->fn))
10581     {
10582       if (DECL_DELETED_FN (cand1->fn) && DECL_DEFAULTED_FN (cand1->fn)
10583           && move_fn_p (cand1->fn))
10584         return -1;
10585       if (DECL_DELETED_FN (cand2->fn) && DECL_DEFAULTED_FN (cand2->fn)
10586           && move_fn_p (cand2->fn))
10587         return 1;
10588     }
10589
10590   /* a viable function F1
10591      is defined to be a better function than another viable function F2  if
10592      for  all arguments i, ICSi(F1) is not a worse conversion sequence than
10593      ICSi(F2), and then */
10594
10595   /* for some argument j, ICSj(F1) is a better conversion  sequence  than
10596      ICSj(F2) */
10597
10598   /* For comparing static and non-static member functions, we ignore
10599      the implicit object parameter of the non-static function.  The
10600      standard says to pretend that the static function has an object
10601      parm, but that won't work with operator overloading.  */
10602   len = cand1->num_convs;
10603   if (len != cand2->num_convs)
10604     {
10605       int static_1 = DECL_STATIC_FUNCTION_P (cand1->fn);
10606       int static_2 = DECL_STATIC_FUNCTION_P (cand2->fn);
10607
10608       if (DECL_CONSTRUCTOR_P (cand1->fn)
10609           && is_list_ctor (cand1->fn) != is_list_ctor (cand2->fn))
10610         /* We're comparing a near-match list constructor and a near-match
10611            non-list constructor.  Just treat them as unordered.  */
10612         return 0;
10613
10614       gcc_assert (static_1 != static_2);
10615
10616       if (static_1)
10617         off2 = 1;
10618       else
10619         {
10620           off1 = 1;
10621           --len;
10622         }
10623     }
10624
10625   /* Handle C++17 copy elision in [over.match.ctor] (direct-init) context.  The
10626      standard currently says that only constructors are candidates, but if one
10627      copies a prvalue returned by a conversion function we want to treat the
10628      conversion as the candidate instead.
10629
10630      Clang does something similar, as discussed at
10631      http://lists.isocpp.org/core/2017/10/3166.php
10632      http://lists.isocpp.org/core/2019/03/5721.php  */
10633   int elided_tiebreaker = 0;
10634   if (len == 1 && cxx_dialect >= cxx17
10635       && DECL_P (cand1->fn)
10636       && DECL_COMPLETE_CONSTRUCTOR_P (cand1->fn)
10637       && !(cand1->flags & LOOKUP_ONLYCONVERTING))
10638     {
10639       bool elided1 = joust_maybe_elide_copy (cand1);
10640       bool elided2 = joust_maybe_elide_copy (cand2);
10641       /* As a tiebreaker below we will prefer a constructor to a conversion
10642          operator exposed this way.  */
10643       elided_tiebreaker = elided2 - elided1;
10644     }
10645
10646   for (i = 0; i < len; ++i)
10647     {
10648       conversion *t1 = cand1->convs[i + off1];
10649       conversion *t2 = cand2->convs[i + off2];
10650       int comp = compare_ics (t1, t2);
10651
10652       if (comp != 0)
10653         {
10654           if ((complain & tf_warning)
10655               && warn_sign_promo
10656               && (CONVERSION_RANK (t1) + CONVERSION_RANK (t2)
10657                   == cr_std + cr_promotion)
10658               && t1->kind == ck_std
10659               && t2->kind == ck_std
10660               && TREE_CODE (t1->type) == INTEGER_TYPE
10661               && TREE_CODE (t2->type) == INTEGER_TYPE
10662               && (TYPE_PRECISION (t1->type)
10663                   == TYPE_PRECISION (t2->type))
10664               && (TYPE_UNSIGNED (next_conversion (t1)->type)
10665                   || (TREE_CODE (next_conversion (t1)->type)
10666                       == ENUMERAL_TYPE)))
10667             {
10668               tree type = next_conversion (t1)->type;
10669               tree type1, type2;
10670               struct z_candidate *w, *l;
10671               if (comp > 0)
10672                 type1 = t1->type, type2 = t2->type,
10673                   w = cand1, l = cand2;
10674               else
10675                 type1 = t2->type, type2 = t1->type,
10676                   w = cand2, l = cand1;
10677
10678               if (warn)
10679                 {
10680                   warning (OPT_Wsign_promo, "passing %qT chooses %qT over %qT",
10681                            type, type1, type2);
10682                   warning (OPT_Wsign_promo, "  in call to %qD", w->fn);
10683                 }
10684               else
10685                 add_warning (w, l);
10686             }
10687
10688           if (winner && comp != winner)
10689             {
10690               winner = 0;
10691               goto tweak;
10692             }
10693           winner = comp;
10694         }
10695     }
10696
10697   /* warn about confusing overload resolution for user-defined conversions,
10698      either between a constructor and a conversion op, or between two
10699      conversion ops.  */
10700   if ((complain & tf_warning)
10701       && winner && warn_conversion && cand1->second_conv
10702       && (!DECL_CONSTRUCTOR_P (cand1->fn) || !DECL_CONSTRUCTOR_P (cand2->fn))
10703       && winner != compare_ics (cand1->second_conv, cand2->second_conv))
10704     {
10705       struct z_candidate *w, *l;
10706       bool give_warning = false;
10707
10708       if (winner == 1)
10709         w = cand1, l = cand2;
10710       else
10711         w = cand2, l = cand1;
10712
10713       /* We don't want to complain about `X::operator T1 ()'
10714          beating `X::operator T2 () const', when T2 is a no less
10715          cv-qualified version of T1.  */
10716       if (DECL_CONTEXT (w->fn) == DECL_CONTEXT (l->fn)
10717           && !DECL_CONSTRUCTOR_P (w->fn) && !DECL_CONSTRUCTOR_P (l->fn))
10718         {
10719           tree t = TREE_TYPE (TREE_TYPE (l->fn));
10720           tree f = TREE_TYPE (TREE_TYPE (w->fn));
10721
10722           if (TREE_CODE (t) == TREE_CODE (f) && INDIRECT_TYPE_P (t))
10723             {
10724               t = TREE_TYPE (t);
10725               f = TREE_TYPE (f);
10726             }
10727           if (!comp_ptr_ttypes (t, f))
10728             give_warning = true;
10729         }
10730       else
10731         give_warning = true;
10732
10733       if (!give_warning)
10734         /*NOP*/;
10735       else if (warn)
10736         {
10737           tree source = source_type (w->convs[0]);
10738           if (INDIRECT_TYPE_P (source))
10739             source = TREE_TYPE (source);
10740           auto_diagnostic_group d;
10741           if (warning (OPT_Wconversion, "choosing %qD over %qD", w->fn, l->fn)
10742               && warning (OPT_Wconversion, "  for conversion from %qH to %qI",
10743                           source, w->second_conv->type)) 
10744             {
10745               inform (input_location, "  because conversion sequence "
10746                       "for the argument is better");
10747             }
10748         }
10749       else
10750         add_warning (w, l);
10751     }
10752
10753   if (winner)
10754     return winner;
10755
10756   /* Put this tiebreaker first, so that we don't try to look at second_conv of
10757      a constructor candidate that doesn't have one.  */
10758   if (elided_tiebreaker)
10759     return elided_tiebreaker;
10760
10761   /* DR 495 moved this tiebreaker above the template ones.  */
10762   /* or, if not that,
10763      the  context  is  an  initialization by user-defined conversion (see
10764      _dcl.init_  and  _over.match.user_)  and  the  standard   conversion
10765      sequence  from  the return type of F1 to the destination type (i.e.,
10766      the type of the entity being initialized)  is  a  better  conversion
10767      sequence  than the standard conversion sequence from the return type
10768      of F2 to the destination type.  */
10769
10770   if (cand1->second_conv)
10771     {
10772       winner = compare_ics (cand1->second_conv, cand2->second_conv);
10773       if (winner)
10774         return winner;
10775     }
10776
10777   /* or, if not that,
10778      F1 is a non-template function and F2 is a template function
10779      specialization.  */
10780
10781   if (!cand1->template_decl && cand2->template_decl)
10782     return 1;
10783   else if (cand1->template_decl && !cand2->template_decl)
10784     return -1;
10785
10786   /* or, if not that,
10787      F1 and F2 are template functions and the function template for F1 is
10788      more specialized than the template for F2 according to the partial
10789      ordering rules.  */
10790
10791   if (cand1->template_decl && cand2->template_decl)
10792     {
10793       winner = more_specialized_fn
10794         (TI_TEMPLATE (cand1->template_decl),
10795          TI_TEMPLATE (cand2->template_decl),
10796          /* [temp.func.order]: The presence of unused ellipsis and default
10797             arguments has no effect on the partial ordering of function
10798             templates.   add_function_candidate() will not have
10799             counted the "this" argument for constructors.  */
10800          cand1->num_convs + DECL_CONSTRUCTOR_P (cand1->fn));
10801       if (winner)
10802         return winner;
10803     }
10804
10805   // C++ Concepts
10806   // or, if not that, F1 is more constrained than F2.
10807   if (flag_concepts && DECL_P (cand1->fn) && DECL_P (cand2->fn))
10808     {
10809       winner = more_constrained (cand1->fn, cand2->fn);
10810       if (winner)
10811         return winner;
10812     }
10813
10814   /* F1 is generated from a deduction-guide (13.3.1.8) and F2 is not */
10815   if (deduction_guide_p (cand1->fn))
10816     {
10817       gcc_assert (deduction_guide_p (cand2->fn));
10818       /* We distinguish between candidates from an explicit deduction guide and
10819          candidates built from a constructor based on DECL_ARTIFICIAL.  */
10820       int art1 = DECL_ARTIFICIAL (cand1->fn);
10821       int art2 = DECL_ARTIFICIAL (cand2->fn);
10822       if (art1 != art2)
10823         return art2 - art1;
10824
10825       if (art1)
10826         {
10827           /* Prefer the special copy guide over a declared copy/move
10828              constructor.  */
10829           if (copy_guide_p (cand1->fn))
10830             return 1;
10831           if (copy_guide_p (cand2->fn))
10832             return -1;
10833
10834           /* Prefer a candidate generated from a non-template constructor.  */
10835           int tg1 = template_guide_p (cand1->fn);
10836           int tg2 = template_guide_p (cand2->fn);
10837           if (tg1 != tg2)
10838             return tg2 - tg1;
10839         }
10840     }
10841
10842   /* F1 is a member of a class D, F2 is a member of a base class B of D, and
10843      for all arguments the corresponding parameters of F1 and F2 have the same
10844      type (CWG 2273/2277). */
10845   if (DECL_P (cand1->fn) && DECL_CLASS_SCOPE_P (cand1->fn)
10846       && !DECL_CONV_FN_P (cand1->fn)
10847       && DECL_P (cand2->fn) && DECL_CLASS_SCOPE_P (cand2->fn)
10848       && !DECL_CONV_FN_P (cand2->fn))
10849     {
10850       tree base1 = DECL_CONTEXT (strip_inheriting_ctors (cand1->fn));
10851       tree base2 = DECL_CONTEXT (strip_inheriting_ctors (cand2->fn));
10852
10853       bool used1 = false;
10854       bool used2 = false;
10855       if (base1 == base2)
10856         /* No difference.  */;
10857       else if (DERIVED_FROM_P (base1, base2))
10858         used1 = true;
10859       else if (DERIVED_FROM_P (base2, base1))
10860         used2 = true;
10861
10862       if (int diff = used2 - used1)
10863         {
10864           for (i = 0; i < len; ++i)
10865             {
10866               conversion *t1 = cand1->convs[i + off1];
10867               conversion *t2 = cand2->convs[i + off2];
10868               if (!same_type_p (t1->type, t2->type))
10869                 break;
10870             }
10871           if (i == len)
10872             return diff;
10873         }
10874     }
10875
10876   /* Check whether we can discard a builtin candidate, either because we
10877      have two identical ones or matching builtin and non-builtin candidates.
10878
10879      (Pedantically in the latter case the builtin which matched the user
10880      function should not be added to the overload set, but we spot it here.
10881
10882      [over.match.oper]
10883      ... the builtin candidates include ...
10884      - do not have the same parameter type list as any non-template
10885        non-member candidate.  */
10886
10887   if (identifier_p (cand1->fn) || identifier_p (cand2->fn))
10888     {
10889       for (i = 0; i < len; ++i)
10890         if (!same_type_p (cand1->convs[i]->type,
10891                           cand2->convs[i]->type))
10892           break;
10893       if (i == cand1->num_convs)
10894         {
10895           if (cand1->fn == cand2->fn)
10896             /* Two built-in candidates; arbitrarily pick one.  */
10897             return 1;
10898           else if (identifier_p (cand1->fn))
10899             /* cand1 is built-in; prefer cand2.  */
10900             return -1;
10901           else
10902             /* cand2 is built-in; prefer cand1.  */
10903             return 1;
10904         }
10905     }
10906
10907   /* For candidates of a multi-versioned function,  make the version with
10908      the highest priority win.  This version will be checked for dispatching
10909      first.  If this version can be inlined into the caller, the front-end
10910      will simply make a direct call to this function.  */
10911
10912   if (TREE_CODE (cand1->fn) == FUNCTION_DECL
10913       && DECL_FUNCTION_VERSIONED (cand1->fn)
10914       && TREE_CODE (cand2->fn) == FUNCTION_DECL
10915       && DECL_FUNCTION_VERSIONED (cand2->fn))
10916     {
10917       tree f1 = TREE_TYPE (cand1->fn);
10918       tree f2 = TREE_TYPE (cand2->fn);
10919       tree p1 = TYPE_ARG_TYPES (f1);
10920       tree p2 = TYPE_ARG_TYPES (f2);
10921      
10922       /* Check if cand1->fn and cand2->fn are versions of the same function.  It
10923          is possible that cand1->fn and cand2->fn are function versions but of
10924          different functions.  Check types to see if they are versions of the same
10925          function.  */
10926       if (compparms (p1, p2)
10927           && same_type_p (TREE_TYPE (f1), TREE_TYPE (f2)))
10928         {
10929           /* Always make the version with the higher priority, more
10930              specialized, win.  */
10931           gcc_assert (targetm.compare_version_priority);
10932           if (targetm.compare_version_priority (cand1->fn, cand2->fn) >= 0)
10933             return 1;
10934           else
10935             return -1;
10936         }
10937     }
10938
10939   /* If the two function declarations represent the same function (this can
10940      happen with declarations in multiple scopes and arg-dependent lookup),
10941      arbitrarily choose one.  But first make sure the default args we're
10942      using match.  */
10943   if (DECL_P (cand1->fn) && DECL_P (cand2->fn)
10944       && equal_functions (cand1->fn, cand2->fn))
10945     {
10946       tree parms1 = TYPE_ARG_TYPES (TREE_TYPE (cand1->fn));
10947       tree parms2 = TYPE_ARG_TYPES (TREE_TYPE (cand2->fn));
10948
10949       gcc_assert (!DECL_CONSTRUCTOR_P (cand1->fn));
10950
10951       for (i = 0; i < len; ++i)
10952         {
10953           /* Don't crash if the fn is variadic.  */
10954           if (!parms1)
10955             break;
10956           parms1 = TREE_CHAIN (parms1);
10957           parms2 = TREE_CHAIN (parms2);
10958         }
10959
10960       if (off1)
10961         parms1 = TREE_CHAIN (parms1);
10962       else if (off2)
10963         parms2 = TREE_CHAIN (parms2);
10964
10965       for (; parms1; ++i)
10966         {
10967           if (!cp_tree_equal (TREE_PURPOSE (parms1),
10968                               TREE_PURPOSE (parms2)))
10969             {
10970               if (warn)
10971                 {
10972                   if (complain & tf_error)
10973                     {
10974                       auto_diagnostic_group d;
10975                       if (permerror (input_location,
10976                                      "default argument mismatch in "
10977                                      "overload resolution"))
10978                         {
10979                           inform (DECL_SOURCE_LOCATION (cand1->fn),
10980                                   " candidate 1: %q#F", cand1->fn);
10981                           inform (DECL_SOURCE_LOCATION (cand2->fn),
10982                                   " candidate 2: %q#F", cand2->fn);
10983                         }
10984                     }
10985                   else
10986                     return 0;
10987                 }
10988               else
10989                 add_warning (cand1, cand2);
10990               break;
10991             }
10992           parms1 = TREE_CHAIN (parms1);
10993           parms2 = TREE_CHAIN (parms2);
10994         }
10995
10996       return 1;
10997     }
10998
10999 tweak:
11000
11001   /* Extension: If the worst conversion for one candidate is better than the
11002      worst conversion for the other, take the first.  */
11003   if (!pedantic && (complain & tf_warning_or_error))
11004     {
11005       conversion_rank rank1 = cr_identity, rank2 = cr_identity;
11006       struct z_candidate *w = 0, *l = 0;
11007
11008       for (i = 0; i < len; ++i)
11009         {
11010           if (CONVERSION_RANK (cand1->convs[i+off1]) > rank1)
11011             rank1 = CONVERSION_RANK (cand1->convs[i+off1]);
11012           if (CONVERSION_RANK (cand2->convs[i + off2]) > rank2)
11013             rank2 = CONVERSION_RANK (cand2->convs[i + off2]);
11014         }
11015       if (rank1 < rank2)
11016         winner = 1, w = cand1, l = cand2;
11017       if (rank1 > rank2)
11018         winner = -1, w = cand2, l = cand1;
11019       if (winner)
11020         {
11021           /* Don't choose a deleted function over ambiguity.  */
11022           if (DECL_P (w->fn) && DECL_DELETED_FN (w->fn))
11023             return 0;
11024           if (warn)
11025             {
11026               auto_diagnostic_group d;
11027               if (pedwarn (input_location, 0,
11028                            "ISO C++ says that these are ambiguous, even "
11029                            "though the worst conversion for the first is "
11030                            "better than the worst conversion for the second:"))
11031                 {
11032                   print_z_candidate (input_location, N_("candidate 1:"), w);
11033                   print_z_candidate (input_location, N_("candidate 2:"), l);
11034                 }
11035             }
11036           else
11037             add_warning (w, l);
11038           return winner;
11039         }
11040     }
11041
11042   gcc_assert (!winner);
11043   return 0;
11044 }
11045
11046 /* Given a list of candidates for overloading, find the best one, if any.
11047    This algorithm has a worst case of O(2n) (winner is last), and a best
11048    case of O(n/2) (totally ambiguous); much better than a sorting
11049    algorithm.  */
11050
11051 static struct z_candidate *
11052 tourney (struct z_candidate *candidates, tsubst_flags_t complain)
11053 {
11054   struct z_candidate *champ = candidates, *challenger;
11055   int fate;
11056   int champ_compared_to_predecessor = 0;
11057
11058   /* Walk through the list once, comparing each current champ to the next
11059      candidate, knocking out a candidate or two with each comparison.  */
11060
11061   for (challenger = champ->next; challenger; )
11062     {
11063       fate = joust (champ, challenger, 0, complain);
11064       if (fate == 1)
11065         challenger = challenger->next;
11066       else
11067         {
11068           if (fate == 0)
11069             {
11070               champ = challenger->next;
11071               if (champ == 0)
11072                 return NULL;
11073               champ_compared_to_predecessor = 0;
11074             }
11075           else
11076             {
11077               champ = challenger;
11078               champ_compared_to_predecessor = 1;
11079             }
11080
11081           challenger = champ->next;
11082         }
11083     }
11084
11085   /* Make sure the champ is better than all the candidates it hasn't yet
11086      been compared to.  */
11087
11088   for (challenger = candidates;
11089        challenger != champ
11090          && !(champ_compared_to_predecessor && challenger->next == champ);
11091        challenger = challenger->next)
11092     {
11093       fate = joust (champ, challenger, 0, complain);
11094       if (fate != 1)
11095         return NULL;
11096     }
11097
11098   return champ;
11099 }
11100
11101 /* Returns nonzero if things of type FROM can be converted to TO.  */
11102
11103 bool
11104 can_convert (tree to, tree from, tsubst_flags_t complain)
11105 {
11106   tree arg = NULL_TREE;
11107   /* implicit_conversion only considers user-defined conversions
11108      if it has an expression for the call argument list.  */
11109   if (CLASS_TYPE_P (from) || CLASS_TYPE_P (to))
11110     arg = build1 (CAST_EXPR, from, NULL_TREE);
11111   return can_convert_arg (to, from, arg, LOOKUP_IMPLICIT, complain);
11112 }
11113
11114 /* Returns nonzero if things of type FROM can be converted to TO with a
11115    standard conversion.  */
11116
11117 bool
11118 can_convert_standard (tree to, tree from, tsubst_flags_t complain)
11119 {
11120   return can_convert_arg (to, from, NULL_TREE, LOOKUP_IMPLICIT, complain);
11121 }
11122
11123 /* Returns nonzero if ARG (of type FROM) can be converted to TO.  */
11124
11125 bool
11126 can_convert_arg (tree to, tree from, tree arg, int flags,
11127                  tsubst_flags_t complain)
11128 {
11129   conversion *t;
11130   void *p;
11131   bool ok_p;
11132
11133   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
11134   p = conversion_obstack_alloc (0);
11135   /* We want to discard any access checks done for this test,
11136      as we might not be in the appropriate access context and
11137      we'll do the check again when we actually perform the
11138      conversion.  */
11139   push_deferring_access_checks (dk_deferred);
11140
11141   t  = implicit_conversion (to, from, arg, /*c_cast_p=*/false,
11142                             flags, complain);
11143   ok_p = (t && !t->bad_p);
11144
11145   /* Discard the access checks now.  */
11146   pop_deferring_access_checks ();
11147   /* Free all the conversions we allocated.  */
11148   obstack_free (&conversion_obstack, p);
11149
11150   return ok_p;
11151 }
11152
11153 /* Like can_convert_arg, but allows dubious conversions as well.  */
11154
11155 bool
11156 can_convert_arg_bad (tree to, tree from, tree arg, int flags,
11157                      tsubst_flags_t complain)
11158 {
11159   conversion *t;
11160   void *p;
11161
11162   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
11163   p = conversion_obstack_alloc (0);
11164   /* Try to perform the conversion.  */
11165   t  = implicit_conversion (to, from, arg, /*c_cast_p=*/false,
11166                             flags, complain);
11167   /* Free all the conversions we allocated.  */
11168   obstack_free (&conversion_obstack, p);
11169
11170   return t != NULL;
11171 }
11172
11173 /* Convert EXPR to TYPE.  Return the converted expression.
11174
11175    Note that we allow bad conversions here because by the time we get to
11176    this point we are committed to doing the conversion.  If we end up
11177    doing a bad conversion, convert_like will complain.  */
11178
11179 tree
11180 perform_implicit_conversion_flags (tree type, tree expr,
11181                                    tsubst_flags_t complain, int flags)
11182 {
11183   conversion *conv;
11184   void *p;
11185   location_t loc = cp_expr_loc_or_input_loc (expr);
11186
11187   if (TYPE_REF_P (type))
11188     expr = mark_lvalue_use (expr);
11189   else
11190     expr = mark_rvalue_use (expr);
11191
11192   if (error_operand_p (expr))
11193     return error_mark_node;
11194
11195   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
11196   p = conversion_obstack_alloc (0);
11197
11198   conv = implicit_conversion (type, TREE_TYPE (expr), expr,
11199                               /*c_cast_p=*/false,
11200                               flags, complain);
11201
11202   if (!conv)
11203     {
11204       if (complain & tf_error)
11205         {
11206           /* If expr has unknown type, then it is an overloaded function.
11207              Call instantiate_type to get good error messages.  */
11208           if (TREE_TYPE (expr) == unknown_type_node)
11209             instantiate_type (type, expr, complain);
11210           else if (invalid_nonstatic_memfn_p (loc, expr, complain))
11211             /* We gave an error.  */;
11212           else
11213             {
11214               range_label_for_type_mismatch label (TREE_TYPE (expr), type);
11215               gcc_rich_location rich_loc (loc, &label);
11216               error_at (&rich_loc, "could not convert %qE from %qH to %qI",
11217                         expr, TREE_TYPE (expr), type);
11218             }
11219         }
11220       expr = error_mark_node;
11221     }
11222   else if (processing_template_decl && conv->kind != ck_identity)
11223     {
11224       /* In a template, we are only concerned about determining the
11225          type of non-dependent expressions, so we do not have to
11226          perform the actual conversion.  But for initializers, we
11227          need to be able to perform it at instantiation
11228          (or instantiate_non_dependent_expr) time.  */
11229       expr = build1 (IMPLICIT_CONV_EXPR, type, expr);
11230       if (!(flags & LOOKUP_ONLYCONVERTING))
11231         IMPLICIT_CONV_EXPR_DIRECT_INIT (expr) = true;
11232       if (flags & LOOKUP_NO_NARROWING)
11233         IMPLICIT_CONV_EXPR_BRACED_INIT (expr) = true;
11234     }
11235   else
11236     expr = convert_like (conv, expr, complain);
11237
11238   /* Free all the conversions we allocated.  */
11239   obstack_free (&conversion_obstack, p);
11240
11241   return expr;
11242 }
11243
11244 tree
11245 perform_implicit_conversion (tree type, tree expr, tsubst_flags_t complain)
11246 {
11247   return perform_implicit_conversion_flags (type, expr, complain,
11248                                             LOOKUP_IMPLICIT);
11249 }
11250
11251 /* Convert EXPR to TYPE (as a direct-initialization) if that is
11252    permitted.  If the conversion is valid, the converted expression is
11253    returned.  Otherwise, NULL_TREE is returned, except in the case
11254    that TYPE is a class type; in that case, an error is issued.  If
11255    C_CAST_P is true, then this direct-initialization is taking
11256    place as part of a static_cast being attempted as part of a C-style
11257    cast.  */
11258
11259 tree
11260 perform_direct_initialization_if_possible (tree type,
11261                                            tree expr,
11262                                            bool c_cast_p,
11263                                            tsubst_flags_t complain)
11264 {
11265   conversion *conv;
11266   void *p;
11267
11268   if (type == error_mark_node || error_operand_p (expr))
11269     return error_mark_node;
11270   /* [dcl.init]
11271
11272      If the destination type is a (possibly cv-qualified) class type:
11273
11274      -- If the initialization is direct-initialization ...,
11275      constructors are considered. ... If no constructor applies, or
11276      the overload resolution is ambiguous, the initialization is
11277      ill-formed.  */
11278   if (CLASS_TYPE_P (type))
11279     {
11280       releasing_vec args (make_tree_vector_single (expr));
11281       expr = build_special_member_call (NULL_TREE, complete_ctor_identifier,
11282                                         &args, type, LOOKUP_NORMAL, complain);
11283       return build_cplus_new (type, expr, complain);
11284     }
11285
11286   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
11287   p = conversion_obstack_alloc (0);
11288
11289   conv = implicit_conversion (type, TREE_TYPE (expr), expr,
11290                               c_cast_p,
11291                               LOOKUP_NORMAL, complain);
11292   if (!conv || conv->bad_p)
11293     expr = NULL_TREE;
11294   else if (processing_template_decl && conv->kind != ck_identity)
11295     {
11296       /* In a template, we are only concerned about determining the
11297          type of non-dependent expressions, so we do not have to
11298          perform the actual conversion.  But for initializers, we
11299          need to be able to perform it at instantiation
11300          (or instantiate_non_dependent_expr) time.  */
11301       expr = build1 (IMPLICIT_CONV_EXPR, type, expr);
11302       IMPLICIT_CONV_EXPR_DIRECT_INIT (expr) = true;
11303     }
11304   else
11305     expr = convert_like_real (conv, expr, NULL_TREE, 0,
11306                               /*issue_conversion_warnings=*/false,
11307                               c_cast_p,
11308                               complain);
11309
11310   /* Free all the conversions we allocated.  */
11311   obstack_free (&conversion_obstack, p);
11312
11313   return expr;
11314 }
11315
11316 /* When initializing a reference that lasts longer than a full-expression,
11317    this special rule applies:
11318
11319      [class.temporary]
11320
11321      The temporary to which the reference is bound or the temporary
11322      that is the complete object to which the reference is bound
11323      persists for the lifetime of the reference.
11324
11325      The temporaries created during the evaluation of the expression
11326      initializing the reference, except the temporary to which the
11327      reference is bound, are destroyed at the end of the
11328      full-expression in which they are created.
11329
11330    In that case, we store the converted expression into a new
11331    VAR_DECL in a new scope.
11332
11333    However, we want to be careful not to create temporaries when
11334    they are not required.  For example, given:
11335
11336      struct B {};
11337      struct D : public B {};
11338      D f();
11339      const B& b = f();
11340
11341    there is no need to copy the return value from "f"; we can just
11342    extend its lifetime.  Similarly, given:
11343
11344      struct S {};
11345      struct T { operator S(); };
11346      T t;
11347      const S& s = t;
11348
11349   we can extend the lifetime of the return value of the conversion
11350   operator.
11351
11352   The next several functions are involved in this lifetime extension.  */
11353
11354 /* DECL is a VAR_DECL or FIELD_DECL whose type is a REFERENCE_TYPE.  The
11355    reference is being bound to a temporary.  Create and return a new
11356    VAR_DECL with the indicated TYPE; this variable will store the value to
11357    which the reference is bound.  */
11358
11359 tree
11360 make_temporary_var_for_ref_to_temp (tree decl, tree type)
11361 {
11362   tree var = create_temporary_var (type);
11363
11364   /* Register the variable.  */
11365   if (VAR_P (decl)
11366       && (TREE_STATIC (decl) || CP_DECL_THREAD_LOCAL_P (decl)))
11367     {
11368       /* Namespace-scope or local static; give it a mangled name.  */
11369
11370       /* If an initializer is visible to multiple translation units, those
11371          translation units must agree on the addresses of the
11372          temporaries. Therefore the temporaries must be given a consistent name
11373          and vague linkage. The mangled name of a temporary is the name of the
11374          non-temporary object in whose initializer they appear, prefixed with
11375          GR and suffixed with a sequence number mangled using the usual rules
11376          for a seq-id. Temporaries are numbered with a pre-order, depth-first,
11377          left-to-right walk of the complete initializer.  */
11378
11379       TREE_STATIC (var) = TREE_STATIC (decl);
11380       TREE_PUBLIC (var) = TREE_PUBLIC (decl);
11381       if (vague_linkage_p (decl))
11382         comdat_linkage (var);
11383
11384       CP_DECL_THREAD_LOCAL_P (var) = CP_DECL_THREAD_LOCAL_P (decl);
11385       set_decl_tls_model (var, DECL_TLS_MODEL (decl));
11386
11387       tree name = mangle_ref_init_variable (decl);
11388       DECL_NAME (var) = name;
11389       SET_DECL_ASSEMBLER_NAME (var, name);
11390     }
11391   else
11392     /* Create a new cleanup level if necessary.  */
11393     maybe_push_cleanup_level (type);
11394
11395   return pushdecl (var);
11396 }
11397
11398 /* EXPR is the initializer for a variable DECL of reference or
11399    std::initializer_list type.  Create, push and return a new VAR_DECL
11400    for the initializer so that it will live as long as DECL.  Any
11401    cleanup for the new variable is returned through CLEANUP, and the
11402    code to initialize the new variable is returned through INITP.  */
11403
11404 static tree
11405 set_up_extended_ref_temp (tree decl, tree expr, vec<tree, va_gc> **cleanups,
11406                           tree *initp)
11407 {
11408   tree init;
11409   tree type;
11410   tree var;
11411
11412   /* Create the temporary variable.  */
11413   type = TREE_TYPE (expr);
11414   var = make_temporary_var_for_ref_to_temp (decl, type);
11415   layout_decl (var, 0);
11416   /* If the rvalue is the result of a function call it will be
11417      a TARGET_EXPR.  If it is some other construct (such as a
11418      member access expression where the underlying object is
11419      itself the result of a function call), turn it into a
11420      TARGET_EXPR here.  It is important that EXPR be a
11421      TARGET_EXPR below since otherwise the INIT_EXPR will
11422      attempt to make a bitwise copy of EXPR to initialize
11423      VAR.  */
11424   if (TREE_CODE (expr) != TARGET_EXPR)
11425     expr = get_target_expr (expr);
11426
11427   if (TREE_CODE (decl) == FIELD_DECL
11428       && extra_warnings && !TREE_NO_WARNING (decl))
11429     {
11430       warning (OPT_Wextra, "a temporary bound to %qD only persists "
11431                "until the constructor exits", decl);
11432       TREE_NO_WARNING (decl) = true;
11433     }
11434
11435   /* Recursively extend temps in this initializer.  */
11436   TARGET_EXPR_INITIAL (expr)
11437     = extend_ref_init_temps (decl, TARGET_EXPR_INITIAL (expr), cleanups);
11438
11439   /* Any reference temp has a non-trivial initializer.  */
11440   DECL_NONTRIVIALLY_INITIALIZED_P (var) = true;
11441
11442   /* If the initializer is constant, put it in DECL_INITIAL so we get
11443      static initialization and use in constant expressions.  */
11444   init = maybe_constant_init (expr);
11445   /* As in store_init_value.  */
11446   init = cp_fully_fold (init);
11447   if (TREE_CONSTANT (init))
11448     {
11449       if (literal_type_p (type) && CP_TYPE_CONST_NON_VOLATILE_P (type))
11450         {
11451           /* 5.19 says that a constant expression can include an
11452              lvalue-rvalue conversion applied to "a glvalue of literal type
11453              that refers to a non-volatile temporary object initialized
11454              with a constant expression".  Rather than try to communicate
11455              that this VAR_DECL is a temporary, just mark it constexpr.  */
11456           DECL_DECLARED_CONSTEXPR_P (var) = true;
11457           DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (var) = true;
11458           TREE_CONSTANT (var) = true;
11459           TREE_READONLY (var) = true;
11460         }
11461       DECL_INITIAL (var) = init;
11462       init = NULL_TREE;
11463     }
11464   else
11465     /* Create the INIT_EXPR that will initialize the temporary
11466        variable.  */
11467     init = split_nonconstant_init (var, expr);
11468   if (at_function_scope_p ())
11469     {
11470       add_decl_expr (var);
11471
11472       if (TREE_STATIC (var))
11473         init = add_stmt_to_compound (init, register_dtor_fn (var));
11474       else
11475         {
11476           tree cleanup = cxx_maybe_build_cleanup (var, tf_warning_or_error);
11477           if (cleanup)
11478             vec_safe_push (*cleanups, cleanup);
11479         }
11480
11481       /* We must be careful to destroy the temporary only
11482          after its initialization has taken place.  If the
11483          initialization throws an exception, then the
11484          destructor should not be run.  We cannot simply
11485          transform INIT into something like:
11486
11487          (INIT, ({ CLEANUP_STMT; }))
11488
11489          because emit_local_var always treats the
11490          initializer as a full-expression.  Thus, the
11491          destructor would run too early; it would run at the
11492          end of initializing the reference variable, rather
11493          than at the end of the block enclosing the
11494          reference variable.
11495
11496          The solution is to pass back a cleanup expression
11497          which the caller is responsible for attaching to
11498          the statement tree.  */
11499     }
11500   else
11501     {
11502       rest_of_decl_compilation (var, /*toplev=*/1, at_eof);
11503       if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
11504         {
11505           if (CP_DECL_THREAD_LOCAL_P (var))
11506             tls_aggregates = tree_cons (NULL_TREE, var,
11507                                         tls_aggregates);
11508           else
11509             static_aggregates = tree_cons (NULL_TREE, var,
11510                                            static_aggregates);
11511         }
11512       else
11513         /* Check whether the dtor is callable.  */
11514         cxx_maybe_build_cleanup (var, tf_warning_or_error);
11515     }
11516   /* Avoid -Wunused-variable warning (c++/38958).  */
11517   if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type)
11518       && VAR_P (decl))
11519     TREE_USED (decl) = DECL_READ_P (decl) = true;
11520
11521   *initp = init;
11522   return var;
11523 }
11524
11525 /* Convert EXPR to the indicated reference TYPE, in a way suitable for
11526    initializing a variable of that TYPE.  */
11527
11528 tree
11529 initialize_reference (tree type, tree expr,
11530                       int flags, tsubst_flags_t complain)
11531 {
11532   conversion *conv;
11533   void *p;
11534   location_t loc = cp_expr_loc_or_input_loc (expr);
11535
11536   if (type == error_mark_node || error_operand_p (expr))
11537     return error_mark_node;
11538
11539   /* Get the high-water mark for the CONVERSION_OBSTACK.  */
11540   p = conversion_obstack_alloc (0);
11541
11542   conv = reference_binding (type, TREE_TYPE (expr), expr, /*c_cast_p=*/false,
11543                             flags, complain);
11544   if (!conv || conv->bad_p)
11545     {
11546       if (complain & tf_error)
11547         {
11548           if (conv)
11549             convert_like (conv, expr, complain);
11550           else if (!CP_TYPE_CONST_P (TREE_TYPE (type))
11551                    && !TYPE_REF_IS_RVALUE (type)
11552                    && !lvalue_p (expr))
11553             error_at (loc, "invalid initialization of non-const reference of "
11554                       "type %qH from an rvalue of type %qI",
11555                       type, TREE_TYPE (expr));
11556           else
11557             error_at (loc, "invalid initialization of reference of type "
11558                       "%qH from expression of type %qI", type,
11559                       TREE_TYPE (expr));
11560         }
11561       return error_mark_node;
11562     }
11563
11564   if (conv->kind == ck_ref_bind)
11565     /* Perform the conversion.  */
11566     expr = convert_like (conv, expr, complain);
11567   else if (conv->kind == ck_ambig)
11568     /* We gave an error in build_user_type_conversion_1.  */
11569     expr = error_mark_node;
11570   else
11571     gcc_unreachable ();
11572
11573   /* Free all the conversions we allocated.  */
11574   obstack_free (&conversion_obstack, p);
11575
11576   return expr;
11577 }
11578
11579 /* Subroutine of extend_ref_init_temps.  Possibly extend one initializer,
11580    which is bound either to a reference or a std::initializer_list.  */
11581
11582 static tree
11583 extend_ref_init_temps_1 (tree decl, tree init, vec<tree, va_gc> **cleanups)
11584 {
11585   tree sub = init;
11586   tree *p;
11587   STRIP_NOPS (sub);
11588   if (TREE_CODE (sub) == COMPOUND_EXPR)
11589     {
11590       TREE_OPERAND (sub, 1)
11591         = extend_ref_init_temps_1 (decl, TREE_OPERAND (sub, 1), cleanups);
11592       return init;
11593     }
11594   if (TREE_CODE (sub) != ADDR_EXPR)
11595     return init;
11596   /* Deal with binding to a subobject.  */
11597   for (p = &TREE_OPERAND (sub, 0);
11598        (TREE_CODE (*p) == COMPONENT_REF
11599         || TREE_CODE (*p) == ARRAY_REF); )
11600     p = &TREE_OPERAND (*p, 0);
11601   if (TREE_CODE (*p) == TARGET_EXPR)
11602     {
11603       tree subinit = NULL_TREE;
11604       *p = set_up_extended_ref_temp (decl, *p, cleanups, &subinit);
11605       recompute_tree_invariant_for_addr_expr (sub);
11606       if (init != sub)
11607         init = fold_convert (TREE_TYPE (init), sub);
11608       if (subinit)
11609         init = build2 (COMPOUND_EXPR, TREE_TYPE (init), subinit, init);
11610     }
11611   return init;
11612 }
11613
11614 /* INIT is part of the initializer for DECL.  If there are any
11615    reference or initializer lists being initialized, extend their
11616    lifetime to match that of DECL.  */
11617
11618 tree
11619 extend_ref_init_temps (tree decl, tree init, vec<tree, va_gc> **cleanups)
11620 {
11621   tree type = TREE_TYPE (init);
11622   if (processing_template_decl)
11623     return init;
11624   if (TYPE_REF_P (type))
11625     init = extend_ref_init_temps_1 (decl, init, cleanups);
11626   else
11627     {
11628       tree ctor = init;
11629       if (TREE_CODE (ctor) == TARGET_EXPR)
11630         ctor = TARGET_EXPR_INITIAL (ctor);
11631       if (TREE_CODE (ctor) == CONSTRUCTOR)
11632         {
11633           if (is_std_init_list (type))
11634             {
11635               /* The temporary array underlying a std::initializer_list
11636                  is handled like a reference temporary.  */
11637               tree array = CONSTRUCTOR_ELT (ctor, 0)->value;
11638               array = extend_ref_init_temps_1 (decl, array, cleanups);
11639               CONSTRUCTOR_ELT (ctor, 0)->value = array;
11640             }
11641           else
11642             {
11643               unsigned i;
11644               constructor_elt *p;
11645               vec<constructor_elt, va_gc> *elts = CONSTRUCTOR_ELTS (ctor);
11646               FOR_EACH_VEC_SAFE_ELT (elts, i, p)
11647                 p->value = extend_ref_init_temps (decl, p->value, cleanups);
11648             }
11649           recompute_constructor_flags (ctor);
11650           if (decl_maybe_constant_var_p (decl) && TREE_CONSTANT (ctor))
11651             DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (decl) = true;
11652         }
11653     }
11654
11655   return init;
11656 }
11657
11658 /* Returns true iff an initializer for TYPE could contain temporaries that
11659    need to be extended because they are bound to references or
11660    std::initializer_list.  */
11661
11662 bool
11663 type_has_extended_temps (tree type)
11664 {
11665   type = strip_array_types (type);
11666   if (TYPE_REF_P (type))
11667     return true;
11668   if (CLASS_TYPE_P (type))
11669     {
11670       if (is_std_init_list (type))
11671         return true;
11672       for (tree f = next_initializable_field (TYPE_FIELDS (type));
11673            f; f = next_initializable_field (DECL_CHAIN (f)))
11674         if (type_has_extended_temps (TREE_TYPE (f)))
11675           return true;
11676     }
11677   return false;
11678 }
11679
11680 /* Returns true iff TYPE is some variant of std::initializer_list.  */
11681
11682 bool
11683 is_std_init_list (tree type)
11684 {
11685   if (!TYPE_P (type))
11686     return false;
11687   if (cxx_dialect == cxx98)
11688     return false;
11689   /* Look through typedefs.  */
11690   type = TYPE_MAIN_VARIANT (type);
11691   return (CLASS_TYPE_P (type)
11692           && CP_TYPE_CONTEXT (type) == std_node
11693           && init_list_identifier == DECL_NAME (TYPE_NAME (type)));
11694 }
11695
11696 /* Returns true iff DECL is a list constructor: i.e. a constructor which
11697    will accept an argument list of a single std::initializer_list<T>.  */
11698
11699 bool
11700 is_list_ctor (tree decl)
11701 {
11702   tree args = FUNCTION_FIRST_USER_PARMTYPE (decl);
11703   tree arg;
11704
11705   if (!args || args == void_list_node)
11706     return false;
11707
11708   arg = non_reference (TREE_VALUE (args));
11709   if (!is_std_init_list (arg))
11710     return false;
11711
11712   args = TREE_CHAIN (args);
11713
11714   if (args && args != void_list_node && !TREE_PURPOSE (args))
11715     /* There are more non-defaulted parms.  */
11716     return false;
11717
11718   return true;
11719 }
11720
11721 #include "gt-cp-call.h"