From 5058dcb497254b4188415d8b02e3f0eedd12b560 Mon Sep 17 00:00:00 2001 From: Juli Mallett Date: Sat, 22 Jun 2002 12:58:42 +0000 Subject: Check for results of repeated calls to strnsubst(), as well as for the behaviour with NULL match string, as that has changed over time. --- usr.bin/xargs/strnsubst.c | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) (limited to 'usr.bin/xargs') diff --git a/usr.bin/xargs/strnsubst.c b/usr.bin/xargs/strnsubst.c index b6668b7071b3..fc00ea0db321 100644 --- a/usr.bin/xargs/strnsubst.c +++ b/usr.bin/xargs/strnsubst.c @@ -73,14 +73,25 @@ done: int main(void) { - char *x, *y; + char *x, *y, *z, *za; - y = x = "{}{}{}"; - strnsubst(&x, "{}", "v ybir whyv! ", 12); - if (strcmp(x, "v ybir whyv! ") == 0) - printf("strnsubst() seems to work as expected.\n"); - printf("x: %s\ny: %s\n", x, y); + x = "{}%$"; + strnsubst(&x, "%$", "{} enpury!", 255); + y = x; + strnsubst(&y, "}{}", "ybir", 255); + z = y; + strnsubst(&z, "{", "v ", 255); + za = z; + strnsubst(&z, NULL, za, 255); + if (strcmp(z, "v ybir enpury!") == 0) + printf("strnsubst() seems to work!\n"); + else + printf("strnsubst() is broken.\n"); + printf("%s\n", z); free(x); + free(y); + free(z); + free(za); return 0; } #endif -- cgit v1.2.3