diff options
author | David Malcolm <dmalcolm@redhat.com> | 2016-07-20 14:03:03 +0000 |
---|---|---|
committer | David Malcolm <dmalcolm@gcc.gnu.org> | 2016-07-20 14:03:03 +0000 |
commit | 7c8f7eaa75d53ca642203178fb2c6bbe800bc2ea (patch) | |
tree | 4295610e81aed46c2605b630ee7f4d3963766ac1 /gcc/c | |
parent | 7419f4417a33ff9143317794aa985f7681d1e2a0 (diff) | |
download | gcc-7c8f7eaa75d53ca642203178fb2c6bbe800bc2ea.tar.gz |
Enabling work for C++ handling of misspelled identifiers and typenames
gcc/c/ChangeLog:
* c-decl.c (struct edit_distance_traits<cpp_hashnode *>): Move to
spellcheck-tree.h
(best_macro_match): Likewise, converting from a typedef to a
subclass.
(find_closest_macro_cpp_cb): Move to spellcheck-tree.c.
(lookup_name_fuzzy): Update for change of best_macro_match to a
subclass with a ctor that calls cpp_forall_identifiers.
gcc/ChangeLog:
* diagnostic-show-locus.c (diagnostic_show_locus): If this is the
same location as last time, don't skip if we have fix-it hints.
Clarify the skipping logic by converting it from one "if" clause
to repeated "if" clauses.
* spellcheck-tree.c: Include "cpplib.h".
(find_closest_macro_cpp_cb): Move here from c/c-decl.c.
(best_macro_match::best_macro_match): New constructor.
* spellcheck-tree.h (struct edit_distance_traits<cpp_hashnode *>):
Move here from c/c-decl.c.
(class best_macro_match): Move here from c/c-decl.c, converting
from a typedef to a subclass, gaining a ctor.
From-SVN: r238522
Diffstat (limited to 'gcc/c')
-rw-r--r-- | gcc/c/ChangeLog | 10 | ||||
-rw-r--r-- | gcc/c/c-decl.c | 42 |
2 files changed, 11 insertions, 41 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog index d322761e87b..397bbf8ad5b 100644 --- a/gcc/c/ChangeLog +++ b/gcc/c/ChangeLog @@ -1,5 +1,15 @@ 2016-07-20 David Malcolm <dmalcolm@redhat.com> + * c-decl.c (struct edit_distance_traits<cpp_hashnode *>): Move to + spellcheck-tree.h + (best_macro_match): Likewise, converting from a typedef to a + subclass. + (find_closest_macro_cpp_cb): Move to spellcheck-tree.c. + (lookup_name_fuzzy): Update for change of best_macro_match to a + subclass with a ctor that calls cpp_forall_identifiers. + +2016-07-20 David Malcolm <dmalcolm@redhat.com> + * c-decl.c (implicit_decl_warning): Update for conversion of return type of lookup_name_fuzzy to const char *. (undeclared_variable): Likewise. diff --git a/gcc/c/c-decl.c b/gcc/c/c-decl.c index d9f2dd752da..41aabeb2972 100644 --- a/gcc/c/c-decl.c +++ b/gcc/c/c-decl.c @@ -3955,45 +3955,6 @@ lookup_name_in_scope (tree name, struct c_scope *scope) return NULL_TREE; } -/* Specialization of edit_distance_traits for preprocessor macros. */ - -template <> -struct edit_distance_traits<cpp_hashnode *> -{ - static size_t get_length (cpp_hashnode *hashnode) - { - return hashnode->ident.len; - } - - static const char *get_string (cpp_hashnode *hashnode) - { - return (const char *)hashnode->ident.str; - } -}; - -/* Specialization of best_match<> for finding the closest preprocessor - macro to a given identifier. */ - -typedef best_match<tree, cpp_hashnode *> best_macro_match; - -/* A callback for cpp_forall_identifiers, for use by lookup_name_fuzzy. - Process HASHNODE and update the best_macro_match instance pointed to be - USER_DATA. */ - -static int -find_closest_macro_cpp_cb (cpp_reader *, cpp_hashnode *hashnode, - void *user_data) -{ - if (hashnode->type != NT_MACRO) - return 1; - - best_macro_match *bmm = (best_macro_match *)user_data; - bmm->consider (hashnode); - - /* Keep iterating. */ - return 1; -} - /* Look for the closest match for NAME within the currently valid scopes. @@ -4068,8 +4029,7 @@ lookup_name_fuzzy (tree name, enum lookup_name_fuzzy_kind kind) non-NULL result for best_macro_match if it's better than any of the identifiers already checked, which avoids needless creation of identifiers for macro hashnodes. */ - best_macro_match bmm (name, bm.get_best_distance ()); - cpp_forall_identifiers (parse_in, find_closest_macro_cpp_cb, &bmm); + best_macro_match bmm (name, bm.get_best_distance (), parse_in); cpp_hashnode *best_macro = bmm.get_best_meaningful_candidate (); /* If a macro is the closest so far to NAME, use it, creating an identifier tree node for it. */ |