# This file is part of ltrace.
# Copyright (C) 2012 Petr Machata, Red Hat Inc.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation; either version 2 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
# 02110-1301 USA

set testfile "branch_func"
set srcfile ${testfile}.c
set binfile ${testfile}

if [get_compiler_info $binfile] {
  return -1
}

verbose "compiling source file now....."
if { [ltrace_compile $srcdir/$subdir/$srcfile $objdir/$subdir/$binfile executable {debug} ] != "" } {
     send_user "Testcase compile failed, so all tests in this file will automatically fail\n."
}

# set options for ltrace.
ltrace_options "-x" "func1" "-x" "func2" "-x" "func3"

# Run PUT for ltarce.
set exec_output [ltrace_runtest $objdir/$subdir $objdir/$subdir/$binfile]

# Check the output of this program.
verbose "ltrace runtest output: $exec_output\n"
if [regexp {ELF from incompatible architecture} $exec_output] {
	fail "32-bit ltrace can not perform on 64-bit PUTs and rebuild ltrace in 64 bit mode!"
	return 
} elseif [ regexp {Couldn't get .hash data} $exec_output ] {
	fail "Couldn't get .hash data!"
	return
}

set pattern "func1(.*unfinished"
ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100
set pattern "func2(.*unfinished"
ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100
set pattern "func3(.*)"
ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100
set pattern "func2.resumed"
ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100
set pattern "func1.resumed"
ltrace_verify_output ${objdir}/${subdir}/${testfile}.ltrace $pattern 100