summaryrefslogtreecommitdiffstats
path: root/private/crt32/mbstring/mbsnbcmp.c
blob: f9aa9521a0282e3aee56856faa985908c583f8bf (plain) (blame)
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
/*** 
*mbsnbcmp.c - Compare n bytes of two MBCS strings
*
*	Copyright (c) 1985-1992, Microsoft Corporation.  All rights reserved.
*
*Purpose:
*	Compare n bytes of two MBCS strings
*
*Revision History:
*	08-03-93  KRS	Ported from 16-bit sources.
*
*******************************************************************************/

#ifdef _MBCS
#include <cruntime.h>
#include <mbdata.h>
#include <mbctype.h>
#include <mbstring.h>

/*** 
*int mbsnbcmp(s1, s2, n) - Compare n bytes of two MBCS strings
*
*Purpose:
*	Compares up to n bytes of two strings for lexical order.
*	Strings are compared on a character basis, not a byte basis.
*
*Entry:
*	unsigned char *s1, *s2 = strings to compare
*	size_t n = maximum number of bytes to compare
*
*Exit:
*       returns <0 if s1 < s2
*	returns  0 if s1 == s2
*       returns >0 if s1 > s2
*
*Exceptions:
*
*******************************************************************************/

int _CRTAPI1 _mbsnbcmp( s1, s2, n )
const unsigned char *s1;
const unsigned char *s2;
size_t n;
{
        unsigned short c1, c2;

	if (n==0)
		return(0);

	while (n--) {

		c1 = *s1++;
		if (_ISLEADBYTE(c1)) {
			if (n==0)
				break;
			c1 = ( (*s1 == '\0') ? 0 : ((c1<<8) | *s1++) );
		}

		c2 = *s2++;
		if (_ISLEADBYTE(c2)) {
			if (n--==0)
				break;
			c2 = ( (*s2 == '\0') ? 0 : ((c2<<8) | *s2++) );
		}

		if (c1 != c2)
			return( (c1 > c2) ? 1 : -1);

		if (c1 == 0)
			return(0);
	}

	return(0);
}
#endif	/* _MBCS */