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