// Copyright (C) 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /* ********************************************************************** * Copyright (C) 2001-2006, International Business Machines * Corporation and others. All Rights Reserved. ********************************************************************** */ #include "cstring.h" #include "ustrfmt.h" /*** * Fills in a UChar* string with the radix-based representation of a * uint32_t number padded with zeroes to minwidth. The result * will be null terminated if there is room. * * @param buffer UChar buffer to receive result * @param capacity capacity of buffer * @param i the unsigned number to be formatted * @param radix the radix from 2..36 * @param minwidth the minimum width. If the result is narrower than * this, '0's will be added on the left. Must be <= * capacity. * @return the length of the result, not including any terminating * null */ U_CAPI int32_t U_EXPORT2 uprv_itou (UChar * buffer, int32_t capacity, uint32_t i, uint32_t radix, int32_t minwidth) { int32_t length = 0; int digit; int32_t j; UChar temp; do{ digit = (int)(i % radix); buffer[length++]=(UChar)(digit<=9?(0x0030+digit):(0x0030+digit+7)); i=i/radix; } while(i && length<capacity); while (length < minwidth){ buffer[length++] = (UChar) 0x0030;/*zero padding */ } /* null terminate the buffer */ if(length<capacity){ buffer[length] = (UChar) 0x0000; } /* Reverses the string */ for (j = 0; j < (length / 2); j++){ temp = buffer[(length-1) - j]; buffer[(length-1) - j] = buffer[j]; buffer[j] = temp; } return length; }