From: Bob Rossi <bob@brasko.net>
To: Jim Ingham <jingham@apple.com>
Cc: gdb@sources.redhat.com
Subject: Re: MI rules
Date: Sat, 25 Sep 2004 01:05:00 -0000 [thread overview]
Message-ID: <20040925010519.GB3379@white> (raw)
In-Reply-To: <A48C5E98-0D8D-11D9-AA4E-000A958F4C44@apple.com>
On Thu, Sep 23, 2004 at 11:23:18AM -0700, Jim Ingham wrote:
> Sorry for being so late in chiming in, but I guess I am not clear on
> exactly what the problem is here.
Don't be, thanks for responding.
> Xcode uses the command tokens through-out, so it always is able to
> match up the command & it's result. We had to do some work to make
> sure that if a command like -exec-run gets the target going, and you
> come along and issue another command, you still get a running & a
> stopped that have the correct numbers.
>
> But I don't think this would be a real problem for the FSF gdb right
> now, since there are very few real (any)asynchronous targets in actual
> use. If there are, you can look at what we had to change to get this
> working. It was tricky IIRC, but not that bad.
OK, I understand that it is possible to use the tokens to be able to
tell what MI output commands is coming out of GDB when it is issuing
syncronous commands.
>
> Anyway, you almost always will need more information than just "what
> was the name of the MI command that I issued", right? You can issue a
> whole bunch of "-var-create" commands, for instance, and just knowing
> that you issued -var-create isn't going to help you at all. You need
> to tie each one to the particular variable the varobj was representing.
> So issuing & keeping track of the tokens is pretty much mandatory
> anyway, and once you are doing that, you pretty much know how to
> interpreter each return value.
This is a good point. I haven't got this far in my implementation.
> Other that that, there are the asynchronous notifications that come
> from gdb when something interesting happens, but those should already
> all have some unique tag after the "=" that tells you what the data is.
>
> I don't have any big problem with adding the command name after the
> command token or something similar, but I don't see that it really adds
> much in practical terms. It also looks to me like this will be a
> backwards-incompatible change to the mi, no? If so you should bump the
> MI version if you add this.
Please take a look at
http://sources.redhat.com/ml/gdb/2004-09/msg00200.html
I have summarized the two issues better there. One of the issues is more
important, and that deals with MI outuput commands and backwards
compatibility.
Finally, I personally think that every MI output command should self
document what type of command it is. This tells the front end easily
what kind of MI output command walker should be used to understand the
data. I understand the front end could use the tokens to figure it out,
but I think it's something that should be self evident from having the
MI output command.
Finally, for instances like -var-create I would suggest adding a new
field to the -var-create that gives it a unique id ( like tokens ).
Then, whenever a -var- response from GDB it should tell you that it is
issuing a -var-create response and it is tied to the unique id. That way
the front end can match it up.
Personally, I think all of these things can be done easily at the GDB
level and can avoid unnecessary confusion in the front ends.
Does it sound unreasonable for a MI output command, either syncronous or
asyncronous to say what kind of command it is?
Input is greatly appreciated since I've already made it passed the
parsing stage of the MI output commands and want to start interpretting
the data. Basically, I hope that the bison parser that I have will be
usable by other front end developers one day. I also think that for each
MI output command that they get, they should be able to understand how
to interpret the data, without having to do lookups to figure out what
type of command it is, or wihtout having to look at the data to figure
out what kind of command it is.
Thanks,
Bob Rossi
next prev parent reply other threads:[~2004-09-25 1:05 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <1095954341.19418.ezmlm@sources.redhat.com>
2004-09-23 18:23 ` Jim Ingham
2004-09-25 1:05 ` Bob Rossi [this message]
2004-09-25 19:01 ` Jim Ingham
2004-09-25 20:12 ` Bob Rossi
2004-09-27 17:39 ` Jim Ingham
2004-09-29 3:00 ` Bob Rossi
2004-09-29 16:13 ` Jim Ingham
2004-09-29 17:27 ` Bob Rossi
2004-09-30 13:26 ` Eli Zaretskii
2004-09-30 16:21 ` Bob Rossi
2004-09-30 16:36 ` Andrew Cagney
2004-09-30 20:42 ` Bob Rossi
[not found] <5733AD9C-0CF7-11D9-8325-000A9569836A@brasko.net>
2004-09-23 0:31 ` Jason Molenda
2004-09-22 13:40 Fabian Cenedese
2004-09-22 13:48 ` Bob Rossi
2004-09-22 14:10 ` Fabian Cenedese
2004-09-22 14:43 ` Bob Rossi
2004-09-22 15:01 ` Fabian Cenedese
2004-09-22 14:58 ` Alain Magloire
2004-09-22 16:18 ` Bob Rossi
2004-09-22 16:59 ` Alain Magloire
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=20040925010519.GB3379@white \
--to=bob@brasko.net \
--cc=gdb@sources.redhat.com \
--cc=jingham@apple.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