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