17c804472Sopenharmony_ci/* 27c804472Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd. 37c804472Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 47c804472Sopenharmony_ci * you may not use this file except in compliance with the License. 57c804472Sopenharmony_ci * You may obtain a copy of the License at 67c804472Sopenharmony_ci * 77c804472Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 87c804472Sopenharmony_ci * 97c804472Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 107c804472Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 117c804472Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 127c804472Sopenharmony_ci * See the License for the specific language governing permissions and 137c804472Sopenharmony_ci * limitations under the License. 147c804472Sopenharmony_ci */ 157c804472Sopenharmony_ci 167c804472Sopenharmony_ci#include "PublicMethods.h" 177c804472Sopenharmony_ci 187c804472Sopenharmony_ciuint32_t PublicMethods::Ulltoa(uintptr_t value, int8_t (&rstStr)[MAX_ITOA_BIT]) 197c804472Sopenharmony_ci{ 207c804472Sopenharmony_ci const int32_t RADIX_HEXADECIMAL = 16; 217c804472Sopenharmony_ci const int32_t dividendLength = 10; 227c804472Sopenharmony_ci 237c804472Sopenharmony_ci auto remainder = value; 247c804472Sopenharmony_ci int8_t strSpace[MAX_ITOA_BIT] = {0}; 257c804472Sopenharmony_ci int8_t* curPoint = strSpace; 267c804472Sopenharmony_ci int64_t dividend = 0; 277c804472Sopenharmony_ci uint32_t rstLength = 0; 287c804472Sopenharmony_ci while (remainder || curPoint == strSpace) { 297c804472Sopenharmony_ci rstLength++; 307c804472Sopenharmony_ci dividend = remainder % RADIX_HEXADECIMAL; 317c804472Sopenharmony_ci remainder = remainder / RADIX_HEXADECIMAL; 327c804472Sopenharmony_ci if (dividend < dividendLength) { // Converted to hexadecimal 337c804472Sopenharmony_ci *curPoint++ = dividend + '0'; 347c804472Sopenharmony_ci } else { 357c804472Sopenharmony_ci *curPoint++ = dividend + 'a' - dividendLength; 367c804472Sopenharmony_ci } 377c804472Sopenharmony_ci } 387c804472Sopenharmony_ci int8_t* tmpRstStr = rstStr; 397c804472Sopenharmony_ci while (curPoint > strSpace) { 407c804472Sopenharmony_ci *tmpRstStr++ = *--curPoint; 417c804472Sopenharmony_ci } 427c804472Sopenharmony_ci *tmpRstStr = 0; 437c804472Sopenharmony_ci return rstLength; 447c804472Sopenharmony_ci} 45