99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
#!/usr/bin/env python
 | 
						|
#
 | 
						|
# Common lint functions applicable to multiple types of files.
 | 
						|
 | 
						|
from __future__ import print_function
 | 
						|
import re
 | 
						|
 | 
						|
def VerifyLineLength(filename, lines, max_length):
 | 
						|
  """Checks to make sure the file has no lines with lines exceeding the length
 | 
						|
  limit.
 | 
						|
 | 
						|
  Args:
 | 
						|
    filename: the file under consideration as string
 | 
						|
    lines: contents of the file as string array
 | 
						|
    max_length: maximum acceptable line length as number
 | 
						|
 | 
						|
  Returns:
 | 
						|
    A list of tuples with format [(filename, line number, msg), ...] with any
 | 
						|
    violations found.
 | 
						|
  """
 | 
						|
  lint = []
 | 
						|
  line_num = 1
 | 
						|
  for line in lines:
 | 
						|
    length = len(line.rstrip('\n'))
 | 
						|
    if length > max_length:
 | 
						|
      lint.append((filename, line_num,
 | 
						|
                   'Line exceeds %d chars (%d)' % (max_length, length)))
 | 
						|
    line_num += 1
 | 
						|
  return lint
 | 
						|
 | 
						|
def VerifyTabs(filename, lines):
 | 
						|
  """Checks to make sure the file has no tab characters.
 | 
						|
 | 
						|
  Args:
 | 
						|
    filename: the file under consideration as string
 | 
						|
    lines: contents of the file as string array
 | 
						|
 | 
						|
  Returns:
 | 
						|
    A list of tuples with format [(line_number, msg), ...] with any violations
 | 
						|
    found.
 | 
						|
  """
 | 
						|
  lint = []
 | 
						|
  tab_re = re.compile(r'\t')
 | 
						|
  line_num = 1
 | 
						|
  for line in lines:
 | 
						|
    if tab_re.match(line.rstrip('\n')):
 | 
						|
      lint.append((filename, line_num, 'Tab found instead of whitespace'))
 | 
						|
    line_num += 1
 | 
						|
  return lint
 | 
						|
 | 
						|
 | 
						|
def VerifyTrailingWhitespace(filename, lines):
 | 
						|
  """Checks to make sure the file has no lines with trailing whitespace.
 | 
						|
 | 
						|
  Args:
 | 
						|
    filename: the file under consideration as string
 | 
						|
    lines: contents of the file as string array
 | 
						|
 | 
						|
  Returns:
 | 
						|
    A list of tuples with format [(filename, line number, msg), ...] with any
 | 
						|
    violations found.
 | 
						|
  """
 | 
						|
  lint = []
 | 
						|
  trailing_whitespace_re = re.compile(r'\s+$')
 | 
						|
  line_num = 1
 | 
						|
  for line in lines:
 | 
						|
    if trailing_whitespace_re.match(line.rstrip('\n')):
 | 
						|
      lint.append((filename, line_num, 'Trailing whitespace'))
 | 
						|
    line_num += 1
 | 
						|
  return lint
 | 
						|
 | 
						|
 | 
						|
class BaseLint:
 | 
						|
  def RunOnFile(filename, lines):
 | 
						|
    raise Exception('RunOnFile() unimplemented')
 | 
						|
 | 
						|
 | 
						|
def RunLintOverAllFiles(linter, filenames):
 | 
						|
  """Runs linter over the contents of all files.
 | 
						|
 | 
						|
  Args:
 | 
						|
    lint: subclass of BaseLint, implementing RunOnFile()
 | 
						|
    filenames: list of all files whose contents will be linted
 | 
						|
 | 
						|
  Returns:
 | 
						|
    A list of tuples with format [(filename, line number, msg), ...] with any
 | 
						|
    violations found.
 | 
						|
  """
 | 
						|
  lint = []
 | 
						|
  for filename in filenames:
 | 
						|
    file = open(filename, 'r')
 | 
						|
    if not file:
 | 
						|
      print('Cound not open %s' % filename)
 | 
						|
      continue
 | 
						|
    lines = file.readlines()
 | 
						|
    lint.extend(linter.RunOnFile(filename, lines))
 | 
						|
 | 
						|
  return lint
 |