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