Andreas Schwab <schwab <at> linux-m68k.org> writes: > Vadim Zeitlin <vz-git <at> zeitlins.org> writes: > > > "!^[ \t]*[A-Za-z_][A-Za-z_0-9]+[ \t]*:([^:]|$)\n" > > That would fail to match single-character identifiers.
Oops, yes, you're right, of course, sorry. I have no idea why did I write that we needed to change this "*" to "+", the only explanation I see is that it was simply too late at night when I did it. So the final version of the exclusion regex is "!^[ \t]*[A-Za-z_][A-Za-z_0-9]*[ \t]*:([^:]|$)\n" But I feel like I'm still missing something about what is going on here. Because after looking carefully at the (positive) regex for matching function and method names, which is "^([A-Za-z_][A-Za-z_0-9]*([ \t*]+[A-Za-z_][A-Za-z_0-9]*" "([ \t]*::[ \t]*[^[:space:]]+)?){1,}[ \t]*\\([^;]*)$\n" (split over 2 lines for readability), I actually don't understand how does it manage to match my declaration. Yet match it does, I do get @@ -438,6 +438,10 @@ firebird_statement_backend::execute(int number) in my diff. But how is this possible? The "[ \t*]+" part has nowhere to match but between "int" and "number" but it can't match there because there must be only alphanumeric characters before it. Yet, not only it does match but if I test with GNU grep -E, it matches too (after replacing "\\(" with just "\(" and removing "\n"). However if I test with perl or "sed -r", it does *not* match. Can anyone see what's going on here? FWIW I've started looking into this because I thought that the current regex wouldn't detect something like foo::nested_type foo::method() as a start of a method. However it does detect this just fine as well which I can't understand at all. I'm out of lame excuses (it's not too late here yet...) so I just hope that I'm missing something about the way Git creates hunk headers and not some obvious problem with the regex itself because I've been staring at it for half an hour but still can't see how does it manage to match here. Could anyone who does see it please explain? Thanks in advance, VZ -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html