summaryrefslogtreecommitdiffstats
path: root/contrib/sendmail/libsm/strrevcmp.c
blob: 2490927099f6884fa082ed54f594853755bb0c7a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*
 * Copyright (c) 2001 Sendmail, Inc. and its suppliers.
 *	All rights reserved.
 *
 * By using this file, you agree to the terms and conditions set
 * forth in the LICENSE file which can be found at the top level of
 * the sendmail distribution.
 *
 */

#include <sm/gen.h>
SM_RCSID("@(#)$Id: strrevcmp.c,v 1.1.1.1 2002/02/17 21:56:43 gshapiro Exp $")

#include <sm/config.h>
#include <sm/string.h>
#include <string.h>

/* strcasecmp.c */
extern const unsigned char charmap[];

/*
**  SM_STRREVCASECMP -- compare two strings starting at the end (ignore case)
**
**	Parameters:
**		s1 -- first string.
**		s2 -- second string.
**
**	Returns:
**		strcasecmp(reverse(s1), reverse(s2))
*/

int
sm_strrevcasecmp(s1, s2)
	const char *s1, *s2;
{
	register int i1, i2;

	i1 = strlen(s1) - 1;
	i2 = strlen(s2) - 1;
	while (i1 >= 0 && i2 >= 0 &&
	       charmap[(unsigned char) s1[i1]] ==
	       charmap[(unsigned char) s2[i2]])
	{
		--i1;
		--i2;
	}
	if (i1 < 0)
	{
		if (i2 < 0)
			return 0;
		else
			return -1;
	}
	else
	{
		if (i2 < 0)
			return 1;
		else
			return (charmap[(unsigned char) s1[i1]] -
				charmap[(unsigned char) s2[i2]]);
	}
}
/*
**  SM_STRREVCMP -- compare two strings starting at the end
**
**	Parameters:
**		s1 -- first string.
**		s2 -- second string.
**
**	Returns:
**		strcmp(reverse(s1), reverse(s2))
*/

int
sm_strrevcmp(s1, s2)
	const char *s1, *s2;
{
	register int i1, i2;

	i1 = strlen(s1) - 1;
	i2 = strlen(s2) - 1;
	while (i1 >= 0 && i2 >= 0 && s1[i1] == s2[i2])
	{
		--i1;
		--i2;
	}
	if (i1 < 0)
	{
		if (i2 < 0)
			return 0;
		else
			return -1;
	}
	else
	{
		if (i2 < 0)
			return 1;
		else
			return s1[i1] - s2[i2];
	}
}
OpenPOWER on IntegriCloud