[PATCH] D60386: FileCheck [6/12]: Introduce numeric variable definition

Thomas Preud'homme via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed Jun 5 08:39:32 PDT 2019


thopre added inline comments.


================
Comment at: llvm/include/llvm/Support/FileCheck.h:350
   /// VariableDefs will map "bar" to 2 corresponding to the second definition
   /// of "bar".
   ///
----------------
probinson wrote:
> thopre wrote:
> > probinson wrote:
> > > I think what this is trying to say is:
> > > the pattern "foo[[bar:.*]]baz[[bar]]quux[[bar:.*]]"
> > > is translated into some regex with parentheses,
> > > the second set of parentheses corresponds to the last definition of "bar" on the line,
> > > hence VariableDefs will map "bar" to 2.
> > > 
> > > Is that right? The translation of check-line-with-square-brackets-with-regex into parenthesized-regex-passed-to-regex-library is not obvious in this comment as written.
> > Indeed. The comment was already unclear before this patch series, I think the reason is in most cases the CHECK directive does not contain parenthesis so the square bracket definition maps directly to the parenthesis group number. Hopefully the comment is now clearer.
> It looks odd that the translated expression has nothing for the use of `[[bar]]` in the original, but the comment is much better now, thanks!
Indeed, it should contain a backreference to the first definition. When it refers to a definition on a different line the value gets inserted in the regex just before match. I've updated the pattern to show both cases, using <quux value> to represent the value captured on a previous line of QUUX.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D60386/new/

https://reviews.llvm.org/D60386





More information about the llvm-commits mailing list