Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
Thanks for the patch. Don't forget to add reviewers in the future though! I don't have time to look at this today (probably), so I'll come back to it tomorrow, I hope.
One of the suggestions for D79936 requires equality support and since it also makes the div-by-zero test nicer I've added it to this patch.
Oh, I thought when we were talking about operators, we were talking about the front end FileCheck ability to use them, like we have with addition and subtraction already! That would be useful too (particularly multiplication to allow for something like N*sizeof(struct) in the check patterns, but I'm okay waiting for it.
llvm/lib/Support/FileCheck.cpp | ||
---|---|---|
254 | We've tended to use static_cast rather than C-style casts in this code. Doesn't this check also assume 2's complement? I'd expect to see something involving the min of int64_t explicitly. The operator- code has some example dancing around that you could adapt to achive this, I think. | |
286 | Same comment as above - I think this assumes 2's complement, which we shouldn't be assuming. | |
llvm/unittests/Support/FileCheckTest.cpp | ||
482 | I think you can delete the "with negative/positive result" bit of the comments, since it's obvious this is the case. | |
487–490 | Again, this makes the assumption of 2's complement. | |
511 | Maybe worth testing multiplication by zero, with both ends of the range (MaxUint64/MinInt64). | |
518 | Same as above - 2's complement assumption. | |
530–531 | Perhaps also worth test cases showing the result of 0/0, 0/10, and 0/-10. | |
540 | Replace these with EXPECT_TRUE/EXPECT_FALSE. | |
543 | Also test two values that are identical except for positive/negative, e.g. 1 and -1. | |
549 | For completeness, you probably also want to compare values that are different, e.g. 3 and 7. Same for the positive case. |
I originally tried this via D79885 but as the operators all have the same precedence there was a worry that it might lead to confusion.
llvm/lib/Support/FileCheck.cpp | ||
---|---|---|
286 | FYI: APInt already assumes 2 complement, see for example the negate method: /// Negate this APInt in place. void negate() { flipAllBits(); ++(*this); } The reason I still tried to deal with other integer representation is that I didn't want to put more 2-complement representation and using only APInt/CheckedArithmetics was more complicated IIRW. |
llvm/unittests/Support/FileCheckTest.cpp | ||
---|---|---|
518 | I'm not sure what to do here. With the current design of ExpressionValue the overflow scenarios change depending on whether you're 1s or 2s complement. I started going down the path of making overflow reporting consistent (essentially making ExpressionValue a 65bit 1s complement number) but I'm worried this might not be what you want. I could just not have tests for the cases where 1s complement differs from 2s complement, but that seems wrong, hence the request for guidance. |
llvm/unittests/Support/FileCheckTest.cpp | ||
---|---|---|
518 | Sorry for the confusion. I don't think we should change the implementation to enable consistent testing depending on the underlying numeric representation. It's probably best to simply not bother testing the edge cases so precisely, since we can't control it sensibly. My suggestion would be to allow a bit of leeway. For example, you could show that MaxInt64 \ -1 is equal to -MaxInt64. That should be representable under the permitted numeric representations. |
llvm/lib/Support/FileCheck.cpp | ||
---|---|---|
254 | The largest positive signed number can always be represented as an unsigned integer (even if you use some other representation). |
I'm now doing the negation via ExpressionValue so the problematic overflow cases are handled by operator-.
I've added the requested tests and replaced the 2s complement specific one.
I've added the hooks required so the operators can be used by FileCheck.
llvm/unittests/Support/FileCheckTest.cpp | ||
---|---|---|
540 | This was fixed via https://reviews.llvm.org/D81094. | |
543 | This was fixed via https://reviews.llvm.org/D81094. | |
549 | This was fixed via https://reviews.llvm.org/D81094. |
LGTM, with one nit.
llvm/unittests/Support/FileCheckTest.cpp | ||
---|---|---|
1253–1254 | Is there any particular reason you've moved the sub case later. It would help blame history if it was where it was before, and the new div case here. |
llvm/unittests/Support/FileCheckTest.cpp | ||
---|---|---|
1253–1254 | This fixes a mistake in my call patch as in general I've tried to keep references to FileCheck's predefined functions in alphabetical order. |
llvm/unittests/Support/FileCheckTest.cpp | ||
---|---|---|
1253–1254 | Okay, that's fine with me. |
clang-format not found in user's PATH; not linting file.