From: Pedro Alves <palves@redhat.com>
To: Jan Kratochvil <jan.kratochvil@redhat.com>
Cc: gdb-patches@sourceware.org
Subject: Re: [PATCH] [RFC] Automatically append 'gdb/testsuite/boards' to DejaGnu's boards dir list.
Date: Sat, 31 Mar 2012 10:31:00 -0000 [thread overview]
Message-ID: <4F76DCD9.6070105@redhat.com> (raw)
In-Reply-To: <20120331072912.GA15237@host2.jankratochvil.net>
On 03/31/2012 08:29 AM, Jan Kratochvil wrote:
> On Sat, 31 Mar 2012 05:02:21 +0200, Pedro Alves wrote:
>> +++ b/gdb/testsuite/append_gdb_boards_dir
>
> It should be in testsuite/lib/ , shouldn't it?
Yeah, a series of different approaches made me miss that.
Appended an .exp suffix as well.
>
>
>> +proc append_gdb_boards_dir { name1 name2 op } {
>> + global srcdir
>> + global boards_dir
>> +
>> + # The "boards/../boards" contortion accounts for the odd chance of
>> + # someone wanting to point at GDB's boards dir in the global
>> + # config before some other board dir, in which case we should not
>> + # push it to the end of the list.
>> + set gdb_boards_dir "${srcdir}/boards/../boards"
>> +
>> + # Keep our board dir last in the list.
>> + set idx [lsearch $boards_dir "$gdb_boards_dir"]
>
> lsearch -exact
Indeed.
>
>
>> + set boards_dir [lreplace $boards_dir $idx $idx]
>
> lreplace X -1 -1 seems not to modify X but according to the doc it seems to be
> undefined. Suggesting one 'if' conditional, ale for the code documentation
> purposes.
Done.
>
>
>> + lappend boards_dir "${gdb_boards_dir}"
>> +}
>> +trace add variable "boards_dir" write append_gdb_boards_dir
>
> There were some complaints on the list for features not compatible with
> tcl-8.3, 'trace add' is not listed in tcl-8.3 doc:
> http://www.tcl.tk/man/tcl8.3/TclCmd/trace.htm
>
Interesting. I knew it wasn't supported on older tcls, but since we're
already using "trace add" in gdb.exp I wasn't worrying (it
wasn't a new problem). But that url points at alternative (older) syntax
we can use to the same effect, so I switched to it. I don't see any
"trace add execution" there though; the gdb.exp bits should be
perhaps skipped somehow on older tcls.
I also updated the comments a bit.
Below's the updated patch.
Thanks.
testsuite/
2012-03-31 Pedro Alves <palves@redhat.com>
* Makefile.in (site.exp): Make site.exp source
$srcdir/lib/append_gdb_boards_dir.exp.
* lib/append_gdb_boards_dir.exp: New file.
---
gdb/testsuite/Makefile.in | 1 +
gdb/testsuite/lib/append_gdb_boards_dir.exp | 48 +++++++++++++++++++++++++++
2 files changed, 49 insertions(+), 0 deletions(-)
create mode 100644 gdb/testsuite/lib/append_gdb_boards_dir.exp
diff --git a/gdb/testsuite/Makefile.in b/gdb/testsuite/Makefile.in
index b06c382..6711930 100644
--- a/gdb/testsuite/Makefile.in
+++ b/gdb/testsuite/Makefile.in
@@ -120,6 +120,7 @@ $(abs_builddir)/site.exp site.exp: ./config.status Makefile
@echo "set build_triplet ${build_canonical}" >> ./tmp0
@echo "set srcdir ${srcdir}" >> ./tmp0
@echo "set tool gdb" >> ./tmp0
+ @echo 'source $${srcdir}/lib/append_gdb_boards_dir.exp' >> ./tmp0
@echo "## All variables above are generated by configure. Do Not Edit ##" >> ./tmp0
@cat ./tmp0 > site.exp
@cat site.bak | sed \
diff --git a/gdb/testsuite/lib/append_gdb_boards_dir.exp b/gdb/testsuite/lib/append_gdb_boards_dir.exp
new file mode 100644
index 0000000..4b01f2b
--- /dev/null
+++ b/gdb/testsuite/lib/append_gdb_boards_dir.exp
@@ -0,0 +1,48 @@
+# Copyright 2012 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
+# the Free Software Foundation; either version 3 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, see <http://www.gnu.org/licenses/>.
+
+# Make the boards under testsuite/boards automatically available to
+# DejaGnu. This is sourced by the `site.exp' file generated in the
+# root of the testsuite's build directory.
+
+# Append GDB's boards dir to DejaGnu's board dir list, making sure
+# that that is the last boards dir in the list, so that boards found
+# in directories appended to the list by either the global config
+# site.exp, or in `$(dirname $DEJAGNU)/boards' override GDB's boards.
+# Unfortunately, there's no standard way to get that behavior. To
+# make it happen, we trace all writes to the $boards_dirs global, and
+# make sure our dir is always the last in the list. This relies on
+# the fact that DejaGnu always writes to this variable, even if just
+# to set it to the empty list, which it does.
+#
+proc append_gdb_boards_dir { name1 name2 op } {
+ global srcdir
+ global boards_dir
+
+ # In case someone wants to point at GDB's boards dir in the global
+ # config before some other board dir, in which case we should not
+ # push it to the end of the list, use an unlikely path to GDB's
+ # boards, so it compares different to other simpler but equivalent
+ # paths.
+ set gdb_boards_dir "${srcdir}/boards/../boards"
+
+ # Keep our board dir last in the list.
+ set idx [lsearch -exact $boards_dir "$gdb_boards_dir"]
+ if { $idx >= 0 } {
+ set boards_dir [lreplace $boards_dir $idx $idx]
+ }
+ lappend boards_dir "${gdb_boards_dir}"
+}
+trace variable "boards_dir" w append_gdb_boards_dir
next prev parent reply other threads:[~2012-03-31 10:31 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-31 3:02 Pedro Alves
2012-03-31 7:29 ` Jan Kratochvil
2012-03-31 10:31 ` Pedro Alves [this message]
2012-04-17 17:52 ` [commit] " Pedro Alves
[not found] ` <CADPb22RuQ6=QQf=+9tCKn4WLDsyWDEV79kF_=Yx3nsDSEbfKoA@mail.gmail.com>
2012-04-02 8:57 ` Pedro Alves
2012-04-02 13:06 ` Joel Brobecker
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=4F76DCD9.6070105@redhat.com \
--to=palves@redhat.com \
--cc=gdb-patches@sourceware.org \
--cc=jan.kratochvil@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