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