summaryrefslogtreecommitdiffstats
path: root/private/crt32/mbstring/mbsnbcnt.c
blob: 196eb02c7e35bd8976dcac92cfa619a2f0b1ba8e (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
/*** 
*mbsnbcnt.c - Returns byte count of MBCS string
*
*	Copyright (c) 1987-1992, Microsoft Corporation.  All rights reserved.
*
*Purpose:
*	Returns byte count of MBCS string
*
*Revision History:
*	11-19-92  KRS	Ported from 16-bit sources.
*
*******************************************************************************/

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


/*** 
* _mbsnbcnt - Returns byte count of MBCS string
*
*Purpose:
*	Returns the number of bytes between the start of the supplied
*	string and the char count supplied.  That is, this routine
*	indicates how many bytes are in the first "ccnt" characters
*	of the string.
*
*Entry:
*	unsigned char *string = pointer to string
*	unsigned int ccnt = number of characters to scan
*
*Exit:
*	Returns number of bytes between string and ccnt.
*
*	If the end of the string is encountered before ccnt chars were
*	scanned, then the length of the string in bytes is returned.
*
*Exceptions:
*
*******************************************************************************/

size_t _CRTAPI1 _mbsnbcnt(string, ccnt)
const unsigned char *string;
size_t ccnt;
{
        unsigned char *p;

	for (p = (char *)string; (ccnt-- && *p); p++) {

		if (_ISLEADBYTE(*p)) {
                        if (*++p == '\0') {
                                --p;
                                break;
                        }
                }
        }

	return ((size_t) ((char *)p - (char *)string));
}
#endif	/* _MBCS */