Ramsay Jones <[email protected]> writes:
> Yes, there was a net increase in the line count when I introduced
> die(), but the main program flow was less cluttered by error handling.
> The net result looked much better, so I thought it was worth it.
>
> What may not be too obvious, however, is that test-regex.c was written
> to be independent of git.
That part I was very aware of actually; it it is a bit tricky to
tell what the right thing to do, though. Your test itself needs to
be pretty much portable without the portability help you would get
git-compat-util.h, but the point of this kind of test is to tell if
you want to define preprocessor macros that may affect the behaviour
of such compatibility layer ;-)
> Given that I'm now building it as part of git, I should have simply
> #included <git-compat-util.h> and used the die() routine from libgit.a
> (since I'm now *relying* on test-regex being linked with libgit.a).
OK.
>>> +int main(int argc, char **argv)
>>> +{
>>> + char *pat = "[^={} \t]+";
>>> + char *str = "={}\nfred";
>>> + regex_t r;
>>> + regmatch_t m[1];
>>> +
>>> + if (regcomp(&r, pat, REG_EXTENDED | REG_NEWLINE))
>>> + die("failed regcomp() for pattern '%s'", pat);
>>> + if (regexec(&r, str, 1, m, 0))
>>> + die("no match of pattern '%s' to string '%s'", pat, str);
>>> +
>>> + /* http://sourceware.org/bugzilla/show_bug.cgi?id=3957 */
>>> + if (m[0].rm_so == 3) /* matches '\n' when it should not */
>>> + exit(1);
>>
>> This could be the third call site of die() that tells the user to
>> build with NO_REGEX=1. Then "cd t && sh t0070-fundamental.sh -i -v" would
>> give that message directly to the user.
>
> Hmm, even without "-i -v", it's *very* clear what is going on, but sure
> it wouldn't hurt either. (Also, I wanted to be able to distinguish an exit
> via die() from a "test failed" error return).
OK.
Thanks.
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html