diff options
| author | Simon Martin <simartin@users.sourceforge.net> | 2006-11-20 21:15:44 +0000 |
|---|---|---|
| committer | Mark Mitchell <mmitchel@gcc.gnu.org> | 2006-11-20 21:15:44 +0000 |
| commit | 02022f3a706d462cdb2da30e2d8cfd79901d78ab (patch) | |
| tree | 49ec524753ca756a93eb724fe929b9e30035943c /gcc/cp/class.c | |
| parent | 903ff2758bdad932eee6ae84539361c18e6c45e9 (diff) | |
| download | gcc-02022f3a706d462cdb2da30e2d8cfd79901d78ab.zip gcc-02022f3a706d462cdb2da30e2d8cfd79901d78ab.tar.gz gcc-02022f3a706d462cdb2da30e2d8cfd79901d78ab.tar.bz2 | |
re PR c++/29475 (incomplete template diagnostics.)
PR c++/29475
* cp-tree.h (enforce_access, perform_or_defer_access_check): Added an
extra argument that represents the declaration to use to print
potential error messages.
* init.c (build_offset_ref): Adjusted the call to
perform_or_defer_access_check.
* class.c (alter_access, resolve_address_of_overloaded_function):
Likewise.
* decl.c (make_typename_type, make_unbound_class_template): Likewise.
* search.c (lookup_member): Likewise.
* friend.c (add_friend): Likewise.
* parser.c (cp_parser_template_id,
cp_parser_pre_parsed_nested_name_specifier): Likewise.
* semantics.c (finish_non_static_data_member,
check_accessibility_of_qualified_id, finish_id_expression): Likewise.
(pop_to_parent_deferring_access_checks, perform_access_checks,
perform_or_defer_access_check): Adjusted the call to enforce_access.
* call.c (enforce_access): Use the new extra argument to build the
error message.
(build_op_delete_call): Adjusted the call to
perform_or_defer_access_check.
(build_over_call): Likewise.
PR c++/29475
* g++.dg/template/access19.C: New test.
* g++.old-deja/g++.other/access11.C: Adjusted the line where the
error is reported.
From-SVN: r119027
Diffstat (limited to 'gcc/cp/class.c')
| -rw-r--r-- | gcc/cp/class.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/gcc/cp/class.c b/gcc/cp/class.c index 75d56be..3e569f5 100644 --- a/gcc/cp/class.c +++ b/gcc/cp/class.c @@ -1129,7 +1129,7 @@ alter_access (tree t, tree fdecl, tree access) } else { - perform_or_defer_access_check (TYPE_BINFO (t), fdecl); + perform_or_defer_access_check (TYPE_BINFO (t), fdecl, fdecl); DECL_ACCESS (fdecl) = tree_cons (t, access, DECL_ACCESS (fdecl)); return 1; } @@ -5958,7 +5958,7 @@ resolve_address_of_overloaded_function (tree target_type, if (DECL_FUNCTION_MEMBER_P (fn)) { gcc_assert (access_path); - perform_or_defer_access_check (access_path, fn); + perform_or_defer_access_check (access_path, fn, fn); } } |
