| """ |
| Parses the id of the process that ran with ASAN from the output logs. |
| """ |
| import sys, argparse, re |
| |
| def main(): |
| parser = argparse.ArgumentParser() |
| parser.add_argument('--infile', nargs='?', type=argparse.FileType('r'), default=sys.stdin, help='The sanitizer output to get the pid from') |
| parser.add_argument('--outfile', nargs='?', type=argparse.FileType('r'), default=sys.stdout, help='Where to write the result') |
| args = parser.parse_args() |
| |
| pid = process_file(args.infile) |
| args.outfile.write(pid) |
| args.infile.close() |
| args.outfile.close() |
| |
| |
| |
| def process_file(infile): |
| # check first line is just ==== divider |
| first_line_pattern = re.compile(r'=*') |
| assert first_line_pattern.match(infile.readline()) |
| |
| # parse out pid from 2nd line |
| # `==PID==ERROR: SanitizerName: error-type on address...` |
| pid_pattern = re.compile(r'==([0-9]*)==ERROR:') |
| pid = pid_pattern.search(infile.readline()).group(1) |
| |
| # ignore the rest |
| |
| assert pid and pid.isdigit() |
| |
| return pid |
| |
| if __name__ == '__main__': |
| main() |