]>
Commit | Line | Data |
---|---|---|
f3c0d7a5 A |
1 | // © 2016 and later: Unicode, Inc. and others. |
2 | // License & terms of use: http://www.unicode.org/copyright.html | |
b75a7d8f A |
3 | /* |
4 | ********************************************************************** | |
73c04bcf | 5 | * Copyright (C) 2001-2006, International Business Machines |
b75a7d8f A |
6 | * Corporation and others. All Rights Reserved. |
7 | ********************************************************************** | |
8 | */ | |
9 | ||
10 | #include "cstring.h" | |
11 | #include "ustrfmt.h" | |
b75a7d8f | 12 | |
b75a7d8f A |
13 | |
14 | /*** | |
15 | * Fills in a UChar* string with the radix-based representation of a | |
16 | * uint32_t number padded with zeroes to minwidth. The result | |
17 | * will be null terminated if there is room. | |
18 | * | |
19 | * @param buffer UChar buffer to receive result | |
20 | * @param capacity capacity of buffer | |
21 | * @param i the unsigned number to be formatted | |
22 | * @param radix the radix from 2..36 | |
23 | * @param minwidth the minimum width. If the result is narrower than | |
24 | * this, '0's will be added on the left. Must be <= | |
25 | * capacity. | |
26 | * @return the length of the result, not including any terminating | |
27 | * null | |
28 | */ | |
29 | U_CAPI int32_t U_EXPORT2 | |
30 | uprv_itou (UChar * buffer, int32_t capacity, | |
31 | uint32_t i, uint32_t radix, int32_t minwidth) | |
32 | { | |
33 | int32_t length = 0; | |
34 | int digit; | |
35 | int32_t j; | |
36 | UChar temp; | |
37 | ||
38 | do{ | |
39 | digit = (int)(i % radix); | |
40 | buffer[length++]=(UChar)(digit<=9?(0x0030+digit):(0x0030+digit+7)); | |
41 | i=i/radix; | |
42 | } while(i && length<capacity); | |
43 | ||
44 | while (length < minwidth){ | |
45 | buffer[length++] = (UChar) 0x0030;/*zero padding */ | |
46 | } | |
47 | /* null terminate the buffer */ | |
48 | if(length<capacity){ | |
49 | buffer[length] = (UChar) 0x0000; | |
50 | } | |
51 | ||
52 | /* Reverses the string */ | |
53 | for (j = 0; j < (length / 2); j++){ | |
54 | temp = buffer[(length-1) - j]; | |
55 | buffer[(length-1) - j] = buffer[j]; | |
56 | buffer[j] = temp; | |
57 | } | |
58 | return length; | |
59 | } |