public inbox for gdb-patches@sourceware.org
 help / color / mirror / Atom feed
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.

  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).