From affa168104304095148ad88393c68657be53f93a Mon Sep 17 00:00:00 2001 From: Alexandre Rames Date: Wed, 21 Sep 2016 11:03:34 +0100 Subject: [PATCH] Fix the `build/endif_comment` check. - The check needs to be run before we remove comments, otherwise valid lines will be found as invalid. - A single character different from `/` after the spaces is enough to indicate an error. - Also catch errors when only one `/` is present. (For example `#endif / MY_FILE_H`.) --- cpplint/cpplint.py | 9 +++++---- cpplint/cpplint_unittest.py | 29 +++++++++++++++++++++++++---- 2 files changed, 30 insertions(+), 8 deletions(-) diff --git a/cpplint/cpplint.py b/cpplint/cpplint.py index 796a4a4..2b6c5c8 100755 --- a/cpplint/cpplint.py +++ b/cpplint/cpplint.py @@ -2683,6 +2683,11 @@ def CheckForNonStandardConstructs(filename, clean_lines, linenum, filename, line number, error level, and message """ + line = clean_lines.lines_without_raw_strings[linenum] + if Match(r'\s*#\s*endif\s*([^/\s]|/[^/]|$)', line): + error(filename, linenum, 'build/endif_comment', 5, + 'Uncommented text after #endif is non-standard. Use a comment.') + # Remove comments from the line, but leave in strings for now. line = clean_lines.lines[linenum] @@ -2713,10 +2718,6 @@ def CheckForNonStandardConstructs(filename, clean_lines, linenum, 'Storage-class specifier (static, extern, typedef, etc) should be ' 'at the beginning of the declaration.') - if Match(r'\s*#\s*endif\s*[^/\s]+', line): - error(filename, linenum, 'build/endif_comment', 5, - 'Uncommented text after #endif is non-standard. Use a comment.') - if Match(r'\s*class\s+(\w+\s*::\s*)+\w+\s*;', line): error(filename, linenum, 'build/forward_decl', 5, 'Inner-style forward declarations are invalid. Remove this line.') diff --git a/cpplint/cpplint_unittest.py b/cpplint/cpplint_unittest.py index 0ae62f4..d738d99 100755 --- a/cpplint/cpplint_unittest.py +++ b/cpplint/cpplint_unittest.py @@ -3754,7 +3754,7 @@ class CpplintTest(CpplintTestBase): #else baz; qux; - #endif""", + #endif // foo""", '') self.TestMultiLineLint( """void F() { @@ -3910,7 +3910,7 @@ class CpplintTest(CpplintTestBase): '#include "path/unique.h"', '#else', '#include "path/unique.h"', - '#endif', + '#endif // MACRO', ''], error_collector) self.assertEquals( @@ -3959,7 +3959,7 @@ class CpplintTest(CpplintTestBase): struct Foo : public Goo { #else struct Foo : public Hoo { - #endif + #endif // DERIVE_FROM_GOO };""", '') self.TestMultiLineLint( @@ -3969,7 +3969,7 @@ class CpplintTest(CpplintTestBase): : public Goo { #else : public Hoo { - #endif + #endif // DERIVE_FROM_GOO };""", '') # Test incomplete class @@ -3987,6 +3987,27 @@ class CpplintTest(CpplintTestBase): 'Uncommented text after #endif is non-standard. Use a comment.' ' [build/endif_comment] [5]') + correct_lines = [ + '#endif // text', + '#endif //' + ] + + for line in correct_lines: + self.TestLint(line, '') + + incorrect_lines = [ + '#endif', + '#endif Not a comment', + '#endif / One `/` is not enough to start a comment' + ] + + for line in incorrect_lines: + self.TestLint( + line, + 'Uncommented text after #endif is non-standard. Use a comment.' + ' [build/endif_comment] [5]') + + def testBuildForwardDecl(self): # The crosstool compiler we currently use will fail to compile the # code in this test, so we might consider removing the lint check.