from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
import re
def get_file_len(f):
i = -1
for i, l in enumerate(f):
pass
return i + 1
def get_include_count(f):
include_count = 0
for line in f:
if re.match(r'\s*#\s*include', line):
include_count += 1
return include_count
def get_function_lines(f):
REGEXP_CONFUSE_TERMS = {"MOCK_IMPL", "MOCK_DECL", "HANDLE_DECL",
"ENABLE_GCC_WARNINGS", "ENABLE_GCC_WARNING",
"DUMMY_TYPECHECK_INSTANCE",
"DISABLE_GCC_WARNING", "DISABLE_GCC_WARNINGS"}
in_function = False
found_openbrace = False
for lineno, line in enumerate(f):
if not in_function:
m = re.match(r'^([a-zA-Z_][a-zA-Z_0-9]*),?\(', line)
if m:
func_name = m.group(1)
if func_name in REGEXP_CONFUSE_TERMS:
continue
func_start = lineno
in_function = True
elif not found_openbrace and line.startswith("{"):
found_openbrace = True
func_start = lineno
else:
if line.startswith("}"):
n_lines = lineno - func_start + 1
in_function = False
found_openbrace = False
yield (func_name, n_lines)