From: Elena Zannoni <ezannoni@redhat.com>
To: Keith Seitz <keiths@redhat.com>
Cc: gdb-patches@sources.redhat.com
Subject: Re: [RFA/MI testsuite] mi_run_to_main/mi_next/mi_step
Date: Mon, 09 Sep 2002 19:22:00 -0000 [thread overview]
Message-ID: <15741.22284.95937.520608@localhost.redhat.com> (raw)
In-Reply-To: <Pine.LNX.4.44.0209041340380.1392-100000@valrhona.uglyboxes.com>
Keith Seitz writes:
> Hi,
>
> The following patch fixes several shortcomings in the mi support for
> running to main, stepping and nexting.
>
> For mi_run_to_main, it removes the assumption that main has no arguments.
> It also adds an ignore pattern to the beginning of the "000*stopped"
> regexp. This is needed, for example, to ignore async output which could
> show up when running threaded applications under MI.
>
> It also fixes mi_next and mi_step, which, as far as I can tell, never
> worked. The regexp pattern is wrong.
>
Hmmm how does this interact with the mi_next_to, etc, functions that
were added back in November?
the original patch was here:
http://sources.redhat.com/ml/gdb-patches/2001-10/msg00336.html
Elena
> Keith
>
> ChangeLog
> 2002-09-04 Keith Seitz <keiths@redhat.com>
>
> * lib/mi-support.exp (mi_run_to_main): Allow anything to precede
> regexp for stopping at main. Could have multiple event notifications.
> Don't assume that main was declared with no parameters.
> (mi_step_next_helper): New procedure to do step/next.
> (mi_next): Use mi_step_next_helper.
> (mi_step): Ditto.
>
> Patch
> Index: testsuite/lib/mi-support.exp
> ===================================================================
> RCS file: /cvs/src/src/gdb/testsuite/lib/mi-support.exp,v
> retrieving revision 1.14
> diff -p -r1.14 mi-support.exp
> *** testsuite/lib/mi-support.exp 29 Aug 2002 16:10:13 -0000 1.14
> --- testsuite/lib/mi-support.exp 4 Sep 2002 20:36:10 -0000
> ***************
> *** 1,4 ****
> ! # Copyright 1999, 2000 Free Software Foundation, 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
> --- 1,4 ----
> ! # Copyright 1999, 2000, 2002 Free Software Foundation, 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
> *************** proc mi_run_to_main { } {
> *** 640,646 ****
>
> mi_run_cmd
> gdb_expect {
> ! -re "000\\*stopped,reason=\"breakpoint-hit\",bkptno=\"1\",thread-id=\"$decimal\",frame=\{addr=\"$hex\",func=\"main\",args=\(\\\[\\\]\|\{\}\),file=\".*\",line=\"\[0-9\]*\"\}\r\n$mi_gdb_prompt$" {
> pass "$test"
> return 0
> }
> --- 640,646 ----
>
> mi_run_cmd
> gdb_expect {
> ! -re ".*000\\*stopped,reason=\"breakpoint-hit\",bkptno=\"\[0-9\]+\",thread-id=\"$decimal\",frame=\{addr=\"$hex\",func=\"main\",args=\(\\\[.*\\\]\|\{.*\}\),file=\".*\",line=\"\[0-9\]*\"\}\r\n$mi_gdb_prompt$" {
> pass "$test"
> return 0
> }
> *************** proc mi_run_to_main { } {
> *** 655,701 ****
> }
>
>
> # Next to the next statement
>
> proc mi_next { test } {
> ! global suppress_flag
> ! if { $suppress_flag } {
> ! return -1
> ! }
> ! global mi_gdb_prompt
> ! send_gdb "220-exec-next\n"
> ! gdb_expect {
> ! -re "220\\^running\r\n${mi_gdb_prompt}220\\*stopped,reason=\"end-stepping-range\",thread-id=\"$decimal\",frame=\{addr=\"$hex\",func=\".*\",args=\[\\\[\{].*[\\\]\}\],file=\".*\",line=\"\[0-9\]*\"\}\r\n$mi_gdb_prompt$" {
> ! pass "$test"
> ! return 0
> ! }
> ! timeout {
> ! fail "$test"
> ! return -1
> ! }
> ! }
> }
>
>
> # Step to the next statement
>
> proc mi_step { test } {
> ! global suppress_flag
> ! if { $suppress_flag } {
> ! return -1
> ! }
> ! global mi_gdb_prompt
> ! send_gdb "220-exec-step\n"
> ! gdb_expect {
> ! -re "220\\^running\r\n${mi_gdb_prompt}220\\*stopped,reason=\"end-stepping-range\",thread-id=\"$decimal\",frame=\{addr=\"$hex\",func=\".*\",args=\[\\\[\{\].*\[\\\]\}\],file=\".*\",line=\"\[0-9\]*\"\}\r\n$mi_gdb_prompt$" {
> ! pass "$test"
> ! return 0
> ! }
> ! timeout {
> ! fail "$test"
> ! return -1
> ! }
> ! }
> }
>
> # cmd should not include the number or newline (i.e. "exec-step 3", not
> --- 655,699 ----
> }
>
>
> + # Helper function for mi_next and mi_step
> + # CMD is either "step" or "next"
> + # TEST is the name of the test (passed to dejagnu's pass/fail)
> + # Returns:
> + # 0 if passed
> + # 1 if failed/timeout
> + proc mi_step_next_helper {cmd test} {
> + global suppress_flag
> + if { $suppress_flag } {
> + return 1
> + }
> +
> + global mi_gdb_prompt decimal hex
> + send_gdb "220-exec-$cmd\n"
> + gdb_expect {
> + -re ".*220\\^running\r\n$mi_gdb_prompt.*220\\*stopped,reason=\"end-stepping-range\",thread-id=\"$decimal\",frame=\{addr=\"$hex\",func=\".*\",args=\(\\\[.*\\\]\|\{.*\}\),file=\".*\",line=\"$decimal\"\}\r\n$mi_gdb_prompt$" {
> + pass "$test"
> + return 0
> + }
> + timeout {
> + fail "$test"
> + return 1
> + }
> + }
> + }
> +
> # Next to the next statement
> + # For return values, see mi_step_next_helper
>
> proc mi_next { test } {
> ! return [mi_step_next_helper next $test]
> }
>
>
> # Step to the next statement
> + # For return values, see mi_step_next_helper
>
> proc mi_step { test } {
> ! return [mi_step_next_helper step $test]
> }
>
> # cmd should not include the number or newline (i.e. "exec-step 3", not
next prev parent reply other threads:[~2002-09-10 2:22 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2002-09-04 13:43 Keith Seitz
2002-09-09 19:22 ` Elena Zannoni [this message]
2002-09-10 7:25 ` Keith Seitz
2002-09-10 9:32 ` Keith Seitz
2002-09-10 14:58 ` Elena Zannoni
2002-09-10 15:08 ` Keith Seitz
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=15741.22284.95937.520608@localhost.redhat.com \
--to=ezannoni@redhat.com \
--cc=gdb-patches@sources.redhat.com \
--cc=keiths@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox