diff options
| author | vladlosev <vladlosev@861a406c-534a-0410-8894-cb66d6ee9925> | 2012-08-14 15:20:01 +0000 | 
|---|---|---|
| committer | vladlosev <vladlosev@861a406c-534a-0410-8894-cb66d6ee9925> | 2012-08-14 15:20:01 +0000 | 
| commit | 1f7bb45e072959a062a8f0e6a4854fe9316161f9 (patch) | |
| tree | 59521a89a24f82e7e355f6a2e36d9ba5655cf704 | |
| parent | 4c97512141023985ea849887101d046edb590300 (diff) | |
| download | googletest-1f7bb45e072959a062a8f0e6a4854fe9316161f9.tar.gz googletest-1f7bb45e072959a062a8f0e6a4854fe9316161f9.tar.bz2 googletest-1f7bb45e072959a062a8f0e6a4854fe9316161f9.zip | |
Prevents pump.py from splitting long IWYU pragma lines.
| -rwxr-xr-x | scripts/pump.py | 38 | 
1 files changed, 23 insertions, 15 deletions
| diff --git a/scripts/pump.py b/scripts/pump.py index 8afe8081..5efb653c 100755 --- a/scripts/pump.py +++ b/scripts/pump.py @@ -704,14 +704,14 @@ def RunCode(env, code_node, output):      RunAtomicCode(env, atomic_code, output) -def IsComment(cur_line): +def IsSingleLineComment(cur_line):    return '//' in cur_line -def IsInPreprocessorDirevative(prev_lines, cur_line): +def IsInPreprocessorDirective(prev_lines, cur_line):    if cur_line.lstrip().startswith('#'):      return True -  return prev_lines != [] and prev_lines[-1].endswith('\\') +  return prev_lines and prev_lines[-1].endswith('\\')  def WrapComment(line, output): @@ -768,7 +768,7 @@ def WrapCode(line, line_concat, output):      output.append(prefix + cur_line.strip()) -def WrapPreprocessorDirevative(line, output): +def WrapPreprocessorDirective(line, output):    WrapCode(line, ' \\', output) @@ -776,29 +776,37 @@ def WrapPlainCode(line, output):    WrapCode(line, '', output) -def IsHeaderGuardOrInclude(line): +def IsMultiLineIWYUPragma(line): +  return re.search(r'/\* IWYU pragma: ', line) + + +def IsHeaderGuardIncludeOrOneLineIWYUPragma(line):    return (re.match(r'^#(ifndef|define|endif\s*//)\s*[\w_]+\s*$', line) or -          re.match(r'^#include\s', line)) +          re.match(r'^#include\s', line) or +          # Don't break IWYU pragmas, either; that causes iwyu.py problems. +          re.search(r'// IWYU pragma: ', line))  def WrapLongLine(line, output):    line = line.rstrip()    if len(line) <= 80:      output.append(line) -  elif IsComment(line): -    if IsHeaderGuardOrInclude(line): -      # The style guide made an exception to allow long header guard lines -      # and includes. +  elif IsSingleLineComment(line): +    if IsHeaderGuardIncludeOrOneLineIWYUPragma(line): +      # The style guide made an exception to allow long header guard lines, +      # includes and IWYU pragmas.        output.append(line)      else:        WrapComment(line, output) -  elif IsInPreprocessorDirevative(output, line): -    if IsHeaderGuardOrInclude(line): -      # The style guide made an exception to allow long header guard lines -      # and includes. +  elif IsInPreprocessorDirective(output, line): +    if IsHeaderGuardIncludeOrOneLineIWYUPragma(line): +      # The style guide made an exception to allow long header guard lines, +      # includes and IWYU pragmas.        output.append(line)      else: -      WrapPreprocessorDirevative(line, output) +      WrapPreprocessorDirective(line, output) +  elif IsMultiLineIWYUPragma(line): +    output.append(line)    else:      WrapPlainCode(line, output) | 
