aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/iresolve.c
diff options
context:
space:
mode:
authorNathan Sidwell <nathan@acm.org>2020-08-13 10:59:00 -0700
committerGiuliano Belinassi <giuliano.belinassi@usp.br>2020-08-17 15:08:10 -0300
commitc491a6e17b94f42c9b5ef3b3840a0d7c2ffb7102 (patch)
treed8d2c4228b60e2bebdb111dbb1fb776f1c4e90d6 /gcc/fortran/iresolve.c
parent27aeb71c04eaa1a2125777d230057fbd0508af15 (diff)
downloadgcc-c491a6e17b94f42c9b5ef3b3840a0d7c2ffb7102.zip
gcc-c491a6e17b94f42c9b5ef3b3840a0d7c2ffb7102.tar.gz
gcc-c491a6e17b94f42c9b5ef3b3840a0d7c2ffb7102.tar.bz2
[c++]: Unconfuse lookup_name_real API a bit
The API for lookup_name_real is really confusing. This addresses the part where we have NONCLASS to say DON'T search class scopes, and BLOCK_P to say DO search block scopes. I've added a single bitmask to explicitly say which scopes to search. I used an enum class so one can't accidentally misorder it. It's also reordered so we don't mix it up with the parameters that say what kind of thing we're looking for. gcc/cp/ * name-lookup.h (enum class LOOK_where): New. (operator|, operator&): Overloads for it. (lookup_name_real): Replace NONCLASS & BLOCK_P parms with WHERE. * name-lookup.c (identifier_type_value_w): Adjust lookup_name_real call. (lookup_name_real_1): Replace NONCLASS and BLOCK_P parameters with WHERE bitmask. Don't search namespaces if not asked to. (lookup_name_real): Adjust lookup_name_real_1 call. (lookup_name_nonclass, lookup_name) (lookup_name_prefer_type): Likewise. * call.c (build_operator_new_call) (add_operator_candidates): Adjust lookup_name_real calls. * parser.c (cp_parser_lookup_name): Likewise. * pt.c (tsubst_friend_class, lookup_init_capture_pack) (tsubst_expr): Likewise. * semantics.c (capture_decltype): Likewise. libcc1/ * libcp1plugin.cc (plugin_build_dependent_expr): Likewise.
Diffstat (limited to 'gcc/fortran/iresolve.c')
0 files changed, 0 insertions, 0 deletions