use more ad-hoc list handling function, and avoid to muck with ->next
[apps/madmutt.git] / lib-lib / ascii.c
1 /*
2  *  This program is free software; you can redistribute it and/or modify
3  *  it under the terms of the GNU General Public License as published by
4  *  the Free Software Foundation; either version 2 of the License, or (at
5  *  your option) any later version.
6  *
7  *  This program is distributed in the hope that it will be useful, but
8  *  WITHOUT ANY WARRANTY; without even the implied warranty of
9  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
10  *  General Public License for more details.
11  *
12  *  You should have received a copy of the GNU General Public License
13  *  along with this program; if not, write to the Free Software
14  *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
15  *  MA 02110-1301, USA.
16  *
17  *  Copyright © 2006 Pierre Habouzit
18  */
19 /*
20  * Copyright notice from original mutt:
21  * Copyright (C) 2001 Thomas Roessler <roessler@does-not-exist.org>
22  */
23
24 /*
25  * Versions of the string comparison functions which are locale-insensitive.
26  */
27
28 #include <stdio.h>
29 #include <stdlib.h>
30 #include "ascii.h"
31
32 int ascii_strcasecmp(const char *a, const char *b)
33 {
34     int i;
35
36     if (a == b)
37         return 0;
38     if (a == NULL && b)
39         return -1;
40     if (b == NULL && a)
41         return 1;
42
43     for (; *a || *b; a++, b++) {
44         if ((i = ascii_tolower(*a) - ascii_tolower(*b)))
45             return i;
46     }
47
48     return 0;
49 }
50
51 int ascii_strncasecmp (const char *a, const char *b, int n)
52 {
53     int i, j;
54
55     if (a == b)
56         return 0;
57     if (a == NULL && b)
58         return -1;
59     if (b == NULL && a)
60         return 1;
61
62     for (j = 0; (*a || *b) && j < n; a++, b++, j++) {
63         if ((i = ascii_tolower(*a) - ascii_tolower(*b)))
64             return i;
65     }
66
67     return 0;
68 }