diff options
| author | Ramsay Jones <ramsay@ramsay1.demon.co.uk> | 2012-09-01 18:46:54 +0100 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2012-09-02 18:57:21 -0700 | 
| commit | c91841594c2f08bec0c8b2d46da27add18fb4854 (patch) | |
| tree | 6fe9bead7c13729dcdfc12c54c79ccf31f62bf7a /test-regex.c | |
| parent | d0f1ea6003d97e63110fa7d50bb07f546a909b6e (diff) | |
| download | git-c91841594c2f08bec0c8b2d46da27add18fb4854.tar.gz | |
test-regex: Add a test to check for a bug in the regex routines
Signed-off-by: Ramsay Jones <ramsay@ramsay1.demon.co.uk>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'test-regex.c')
| -rw-r--r-- | test-regex.c | 20 | 
1 files changed, 20 insertions, 0 deletions
| diff --git a/test-regex.c b/test-regex.c new file mode 100644 index 0000000000..b5bfd54139 --- /dev/null +++ b/test-regex.c @@ -0,0 +1,20 @@ +#include <git-compat-util.h> + +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 */ +		die("regex bug confirmed: re-build git with NO_REGEX=1"); + +	exit(0); +} | 
