From: Pedro Alves <pedro@palves.net>
To: Simon Marchi <simon.marchi@polymtl.ca>,
Tiezhu Yang <yangtiezhu@loongson.cn>,
gdb-patches@sourceware.org
Subject: Re: [PATCH v3 2/4] gdb: testsuite: add new gdb_attach to check "attach" command
Date: Thu, 17 Mar 2022 17:31:26 +0000 [thread overview]
Message-ID: <25e1d92c-6b7e-9df3-640e-92227cf9e8ae@palves.net> (raw)
In-Reply-To: <c6a33f8a-d994-ae84-f37a-975712e6a752@polymtl.ca>
On 2022-03-17 17:04, Simon Marchi via Gdb-patches wrote:
> On 2022-03-17 12:50, Pedro Alves wrote:
>> That looks odd to me -- it's not obvious that "pattern" is the option name.
>>
>> If we instead use parse_args, the option would be specified with "-pattern" (leading dash),
>> and we'd use the magic TCL args array, so we wouldn't need to wrap the options in a list.
>> Like so (on top of the whole series):
>
> I used parse_options because back when doing the rnglists support in the
> DWARF assembler, I had used parse_args and Tom Tromey mentioned he
> didn't really like that use of `args`, because it didn't make it clear
> what positional arguments were expected.. Unlike what you've done
> below, it was something like:
>
> proc rnglists { args } {
> # call parse_args, and then use the remaining args as positional
> # arguments
> }
OK. I'd be fine with that pattern myself, FWIW, as I'd assume the real arguments would
be described in a comment, which you always have to look at anyhow, even if you have
positional arguments:
# Usage: func FOO BAR [-opt OPT]
#
proc func { args } {
Maybe we could instead come up with a proc alternative that would
let you specify the options in the args list directly, like:
proc_with_opts func { foo bar } { {opt1 "default1"}
{opt2 "default2"} } {
...
}
... and we'd make it support users passing options before or after
positional args.
Maybe that's going a bit too far, dunno.
> The way you did it here has the advantage that it's clear which
> positional arguments are expected. The downside is that flag arguments
> can't be put before positional arguments (like you usually can with
> shell or some tcl / expect procs). But I think that's an acceptable
> tradeoff, I'm fine with it.
Yeah, it's what we do with gdb_test_multiple too, for example, even
thought we don't use parse_args there for some reason.
# gdb_test_multiple COMMAND MESSAGE [ -prompt PROMPT_REGEXP] [ -lbl ]
# EXPECT_ARGUMENTS
...
proc gdb_test_multiple { command message args } {
...
>
> Could we add a way to tell parse_args that unexpected arguments are not
> allowed, so it could throw the error itself (and therefore be re-used
> elsewhere)?
I'd guess we could. I wouldn't make that a requirement for this patch, though.
next prev parent reply other threads:[~2022-03-17 17:31 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-03-17 14:00 [PATCH v3 0/4] gdb: add gdb_attach to fix failed testcases Tiezhu Yang
2022-03-17 14:00 ` [PATCH v3 1/4] gdb: testsuite: remove attach test from can_spawn_for_attach Tiezhu Yang
2022-03-17 14:00 ` [PATCH v3 2/4] gdb: testsuite: add new gdb_attach to check "attach" command Tiezhu Yang
2022-03-17 16:50 ` Pedro Alves
2022-03-17 17:04 ` Simon Marchi
2022-03-17 17:31 ` Pedro Alves [this message]
2022-03-18 1:56 ` Tiezhu Yang
2022-03-18 18:23 ` Simon Marchi
2022-03-17 14:01 ` [PATCH v3 3/4] gdb: testsuite: use gdb_attach to fix attach-pie-noexec.exp Tiezhu Yang
2022-03-17 16:51 ` Pedro Alves
2022-03-17 14:01 ` [PATCH v3 4/4] gdb: testsuite: use gdb_attach to fix jit-elf.exp Tiezhu Yang
2022-03-17 16:55 ` [PATCH v3 0/4] gdb: add gdb_attach to fix failed testcases Pedro Alves
2022-03-18 1:53 ` Tiezhu Yang
2022-03-18 18:33 ` Pedro Alves
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=25e1d92c-6b7e-9df3-640e-92227cf9e8ae@palves.net \
--to=pedro@palves.net \
--cc=gdb-patches@sourceware.org \
--cc=simon.marchi@polymtl.ca \
--cc=yangtiezhu@loongson.cn \
/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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).