1 /* $MirOS: src/usr.bin/make/regress.c,v 1.2 2005/11/24 19:16:12 tg Exp $ */
2 /* $OpenBSD: regress.c,v 1.5 2004/04/07 13:11:36 espie Exp $ */
3 
4 /*
5  * Copyright (c) 1999 Marc Espie.
6  *
7  * Code written for the OpenBSD project.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  * 2. Redistributions in binary form must reproduce the above copyright
15  *    notice, this list of conditions and the following disclaimer in the
16  *    documentation and/or other materials provided with the distribution.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE OPENBSD PROJECT AND CONTRIBUTORS
19  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21  * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OPENBSD
22  * PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  */
30 
31 /* regression tests */
32 #include <stdio.h>
33 #include <stdlib.h>
34 #include <string.h>
35 #include "defines.h"
36 #include "str.h"
37 
38 int main(void);
39 #define CHECK(s)		\
40 do {				\
41     printf("%-65s", #s);	\
42     if (s)			\
43 	printf("ok\n"); 	\
44     else {			\
45 	printf("failed\n");	\
46 	errors++;		\
47     }				\
48 } while (0);
49 
50 int
main(void)51 main(void)
52 {
53     unsigned int errors = 0;
54 
55     CHECK(Str_Match("string", "string") == true);
56     CHECK(Str_Match("string", "string2") == false);
57     CHECK(Str_Match("string", "string*") == true);
58     CHECK(Str_Match("Long string", "Lo*ng") == true);
59     CHECK(Str_Match("Long string", "Lo*ng ") == false);
60     CHECK(Str_Match("Long string", "Lo*ng *") == true);
61     CHECK(Str_Match("string", "stri?g") == true);
62     CHECK(Str_Match("str?ng", "str\\?ng") == true);
63     CHECK(Str_Match("striiiing", "str?*ng") == true);
64     CHECK(Str_Match("Very long string just to see", "******a****") == false);
65     CHECK(Str_Match("d[abc?", "d\\[abc\\?") == true);
66     CHECK(Str_Match("d[abc!", "d\\[abc\\?") == false);
67     CHECK(Str_Match("dwabc?", "d\\[abc\\?") == false);
68     CHECK(Str_Match("da0", "d[bcda]0") == true);
69     CHECK(Str_Match("da0", "d[z-a]0") == true);
70     CHECK(Str_Match("d-0", "d[-a-z]0") == true);
71     CHECK(Str_Match("dy0", "d[a\\-z]0") == false);
72     CHECK(Str_Match("d-0", "d[a\\-z]0") == true);
73     CHECK(Str_Match("dz0", "d[a\\]z]0") == true);
74 
75     if (errors != 0)
76 	printf("Errors: %d\n", errors);
77     exit(0);
78 }
79 
80 
81