- This patch proposes to add !getdagarg and !getdagnames bang operators as the inverse operation of !dag. They allow us to examine arguments of a given dag.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
It's not quite clear whether you mean this patch to be an alternative to D151457, or to go together with it. The two changes would clearly conflict, but one of your comments in the other change (https://reviews.llvm.org/D151457#4374848) made it sound as if you meant to do both?
If they're alternatives, then I prefer this one, because I love the extra feature of looking up a dag argument by its name instead of its index. I can see that being really useful.
llvm/lib/TableGen/Record.cpp | ||
---|---|---|
1301 | This error message schema leads to the slightly weird error seen in your test: error: !getdagarg index is out of range 0...3: 3 I'd normally interpret the notation "0...3" as being inclusive at both ends, so it's confusing to be told that 3 is not in the range 0...3. To avoid this wording difficulty, perhaps it's better to break up the error so that a negative index gets its own message (it's illegal no matter how many arguments the dag has), and a positive one gets a message like "!getdagarg index 3 out of range (dag has 3 arguments)"? | |
llvm/lib/TableGen/TGLexer.h | ||
53 | It isn't clear why this section had to be reformatted at all in this patch, but if you are going to put each enum entry on its own line, you could at least break up the comments in the same way so that each one has a comment with its own symbol. | |
llvm/test/TableGen/getsetop.td | ||
99 | Needs some more tests:
|
Originally, I thought to provide this element access functionality as complementary to the !getdagargs. But, I realized later that the element accessor is more convenient to be used. Also, !getdagargs could be implemented through !getdagarg with the help of !forall and !size, even though a little bit verbose. That makes the D151457 redundant. I prefer this one and want to check your comment and suggestion. I will cancel D151457 once we all agree on that.
llvm/lib/TableGen/TGLexer.h | ||
---|---|---|
53 | The pre-merge check fails now once clang-format generates different changes from my original change cause we add XDagGetArg and XDagGetName. I could revert that part of change or make such formatting NFC change in advance before this patch. |
Thanks for the updates. I only have two nitpicks left now.
llvm/lib/TableGen/Record.cpp | ||
---|---|---|
1301 | I see that you've done a simpler thing than I suggested, by just writing 0...(n-1) in place of 0...n. But this leads to a bad error message when n=0. Remember that a dag node need not have any arguments at all: <stdin>:1:14: error: !getdagarg index is out of range 0...4294967295: 0 def foo; def test { dag x = (foo); int y = !getdagarg<int>(x, 0); } ^ | |
llvm/lib/TableGen/TGLexer.h | ||
53 | I don't mind whether you do it in this commit, or separately, or not at all. But if you do it, please convert line pairs like this minus, plus, // - + into a form where the comments make sense: minus, // - plus, // + |
This error message schema leads to the slightly weird error seen in your test:
I'd normally interpret the notation "0...3" as being inclusive at both ends, so it's confusing to be told that 3 is not in the range 0...3.
To avoid this wording difficulty, perhaps it's better to break up the error so that a negative index gets its own message (it's illegal no matter how many arguments the dag has), and a positive one gets a message like "!getdagarg index 3 out of range (dag has 3 arguments)"?