import glob import os paths = ['src/*.cpp', 'src/kademlia/*.cpp', 'include/libtorrent/*.hpp', 'include/libtorrent/kademlia/*.hpp', 'include/libtorrent/aux_/*.hpp', 'include/libtorrent/extensions/*.hpp'] os.system('ctags %s 2>/dev/null' % ' '.join(paths)) files = [] for p in paths: files.extend(glob.glob(p)) items = [] # keeps 20 non-comment lines, used to get more context around # todo-items context = [] priority_count = [0, 0, 0, 0] def html_sanitize(s): ret = '' for i in s: if i == '<': ret += '<' elif i == '>': ret += '>' elif i == '&': ret += '&' else: ret += i return ret for f in files: h = open(f) state = '' line_no = 0 context_lines = 0 for l in h: line_no += 1 line = l.strip() if 'TODO:' in line and line.startswith('//'): line = line.split('TODO:')[1].strip() state = 'todo' items.append({}) items[-1]['location'] = '%s:%d' % (f, line_no) items[-1]['priority'] = 0 if line[0] in '0123456789': items[-1]['priority'] = int(line[0]) line = line[1:].strip() items[-1]['todo'] = line prio = items[-1]['priority'] if prio >= 0 and prio <= 3: priority_count[prio] += 1 continue if state == '': context.append(html_sanitize(l)) if len(context) > 20: context.pop(0) continue if state == 'todo': if line.strip().startswith('//'): items[-1]['todo'] += '\n' items[-1]['todo'] += line[2:].strip() else: state = 'context' items[-1]['context'] = ''.join(context) + '
relevance %d | %s | %s |