blob: a6b6137c1cd2b709f999539dafa712c809f55726 [file] [log] [blame]
Devang Patelc7183ba2010-09-13 20:42:15 +00001#!/usr/bin/perl
2#
3# This script tests debugging information generated by a compiler.
4# Input arguments
5# - Input source program. Usually this source file is decorated using
6# special comments to communicate debugger commands.
7# - Executable file. This file is generated by the compiler.
8#
9# This perl script extracts debugger commands from input source program
10# comments in a script. A debugger is used to load the executable file
11# and run the script generated from source program comments. Finally,
12# the debugger output is checked, using FileCheck, to validate
13# debugging information.
Adrian Prantl4f1e5fb2013-09-06 18:12:01 +000014#
15# On Darwin the default is to use the llgdb.py wrapper script which
16# translates gdb commands into their lldb equivalents.
Devang Patelc7183ba2010-09-13 20:42:15 +000017
18use File::Basename;
Adrian Prantl4f1e5fb2013-09-06 18:12:01 +000019use Config;
20use Cwd;
Devang Patelc7183ba2010-09-13 20:42:15 +000021
22my $testcase_file = $ARGV[0];
23my $executable_file = $ARGV[1];
24
25my $input_filename = basename $testcase_file;
26my $output_dir = dirname $executable_file;
27
Devang Patel12b01792010-09-13 21:23:17 +000028my $debugger_script_file = "$output_dir/$input_filename.debugger.script";
Devang Patelc7183ba2010-09-13 20:42:15 +000029my $output_file = "$output_dir/$input_filename.gdb.output";
30
Adrian Prantl4f1e5fb2013-09-06 18:12:01 +000031my %cmd_map = ();
32# Assume lldb to be the debugger on Darwin.
33my $use_lldb = 0;
34$use_lldb = 1 if ($Config{osname} eq "darwin");
35
Devang Patelc7183ba2010-09-13 20:42:15 +000036# Extract debugger commands from testcase. They are marked with DEBUGGER:
Eric Christopherdb1714e2012-06-26 00:28:15 +000037# at the beginning of a comment line.
Devang Patelc7183ba2010-09-13 20:42:15 +000038open(INPUT, $testcase_file);
39open(OUTPUT, ">$debugger_script_file");
40while(<INPUT>) {
41 my($line) = $_;
42 $i = index($line, "DEBUGGER:");
43 if ( $i >= 0) {
44 $l = length("DEBUGGER:");
45 $s = substr($line, $i + $l);
46 print OUTPUT "$s";
47 }
48}
49print OUTPUT "\n";
50print OUTPUT "quit\n";
51close(INPUT);
52close(OUTPUT);
53
54# setup debugger and debugger options to run a script.
55my $my_debugger = $ENV{'DEBUGGER'};
56if (!$my_debugger) {
Adrian Prantl4f1e5fb2013-09-06 18:12:01 +000057 if ($use_lldb) {
58 my $path = dirname(Cwd::abs_path($0));
59 $my_debugger = "/usr/bin/env python $path/../tools/clang/test/debuginfo-tests/llgdb.py";
60 } else {
61 $my_debugger = "gdb";
62 }
Devang Patelc7183ba2010-09-13 20:42:15 +000063}
Adrian Prantl4f1e5fb2013-09-06 18:12:01 +000064
65# quiet / exit after cmdline / no init file / execute script
Devang Patelc7183ba2010-09-13 20:42:15 +000066my $debugger_options = "-q -batch -n -x";
67
68# run debugger and capture output.
Eric Christopher581a7392012-07-23 20:54:17 +000069system("$my_debugger $debugger_options $debugger_script_file $executable_file > $output_file 2>&1");
Devang Patelc7183ba2010-09-13 20:42:15 +000070
71# validate output.
72system("FileCheck", "-input-file", "$output_file", "$testcase_file");
73if ($?>>8 == 1) {
74 exit 1;
75}
76else {
77 exit 0;
78}