• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
uprv_itou(UChar * buffer,int32_t capacity,uint32_t i,uint32_t radix,int32_t minwidth)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 }
58