From a0695db3e4688cf73eb29a462841830730f76e9e Mon Sep 17 00:00:00 2001 From: Rich Trott Date: Tue, 6 Oct 2020 05:40:38 -0700 Subject: [PATCH 1/2] tools: edit cpplint.py * Remove unnecessary setting of classinfo where it is set again before it is used. * Change whitelisted_functions to allowed_functions. --- tools/cpplint.py | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/tools/cpplint.py b/tools/cpplint.py index 4ea91c0dc04a54..abfd830b655371 100755 --- a/tools/cpplint.py +++ b/tools/cpplint.py @@ -4119,8 +4119,8 @@ def CheckTrailingSemicolon(filename, clean_lines, linenum, error): # Block bodies should not be followed by a semicolon. Due to C++11 # brace initialization, there are more places where semicolons are - # required than not, so we use a whitelist approach to check these - # rather than a blacklist. These are the places where "};" should + # required than not, so we use an allowed list approach to check these + # rather than a disallowed list. These are the places where "};" should # be replaced by just "}": # 1. Some flavor of block following closing parenthesis: # for (;;) {}; @@ -4177,11 +4177,11 @@ def CheckTrailingSemicolon(filename, clean_lines, linenum, error): # - INTERFACE_DEF # - EXCLUSIVE_LOCKS_REQUIRED, SHARED_LOCKS_REQUIRED, LOCKS_EXCLUDED: # - # We implement a whitelist of safe macros instead of a blacklist of + # We implement a list of allowed safe macros instead of a list of disallowed # unsafe macros, even though the latter appears less frequently in # google code and would have been easier to implement. This is because - # the downside for getting the whitelist wrong means some extra - # semicolons, while the downside for getting the blacklist wrong + # the downside for getting the allowed list wrong means some extra + # semicolons, while the downside for getting the disallowed list wrong # would result in compile errors. # # In addition to macros, we also don't want to warn on @@ -4668,7 +4668,6 @@ def CheckStyle(filename, clean_lines, linenum, file_extension, nesting_state, # if(match(prev, " +for \\(")) complain = 0; # if(prevodd && match(prevprev, " +for \\(")) complain = 0; scope_or_label_pattern = r'\s*\w+\s*:\s*\\?$' - classinfo = nesting_state.InnermostClass() initial_spaces = 0 cleansed_line = clean_lines.elided[linenum] while initial_spaces < len(line) and line[initial_spaces] == ' ': @@ -5468,19 +5467,19 @@ def CheckForNonConstReference(filename, clean_lines, linenum, # # We also accept & in static_assert, which looks like a function but # it's actually a declaration expression. - whitelisted_functions = (r'(?:[sS]wap(?:<\w:+>)?|' + allowed_functions = (r'(?:[sS]wap(?:<\w:+>)?|' r'operator\s*[<>][<>]|' r'static_assert|COMPILE_ASSERT' r')\s*\(') - if Search(whitelisted_functions, line): + if Search(allowed_functions, line): return elif not Search(r'\S+\([^)]*$', line): - # Don't see a whitelisted function on this line. Actually we + # Don't see an allowed listed function on this line. Actually we # didn't see any function name on this line, so this is likely a # multi-line parameter list. Try a bit harder to catch this case. for i in xrange(2): if (linenum > i and - Search(whitelisted_functions, clean_lines.elided[linenum - i - 1])): + Search(allowed_functions, clean_lines.elided[linenum - i - 1])): return decls = ReplaceAll(r'{[^}]*}', ' ', line) # exclude function body From 4c5d4c576faef66394adda1fa90b556b73cca418 Mon Sep 17 00:00:00 2001 From: Rich Trott Date: Tue, 6 Oct 2020 05:54:51 -0700 Subject: [PATCH 2/2] Update tools/cpplint.py --- tools/cpplint.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/cpplint.py b/tools/cpplint.py index abfd830b655371..69c9437ad28ebf 100755 --- a/tools/cpplint.py +++ b/tools/cpplint.py @@ -5474,7 +5474,7 @@ def CheckForNonConstReference(filename, clean_lines, linenum, if Search(allowed_functions, line): return elif not Search(r'\S+\([^)]*$', line): - # Don't see an allowed listed function on this line. Actually we + # Don't see an allowed function on this line. Actually we # didn't see any function name on this line, so this is likely a # multi-line parameter list. Try a bit harder to catch this case. for i in xrange(2):