diff options
author | hcpp <hcpp@ydb.tech> | 2023-11-08 12:09:41 +0300 |
---|---|---|
committer | hcpp <hcpp@ydb.tech> | 2023-11-08 12:56:14 +0300 |
commit | a361f5b98b98b44ea510d274f6769164640dd5e1 (patch) | |
tree | c47c80962c6e2e7b06798238752fd3da0191a3f6 /contrib/libs/libmysql_r/strings/longlong2str.cc | |
parent | 9478806fde1f4d40bd5a45e7cbe77237dab613e9 (diff) | |
download | ydb-a361f5b98b98b44ea510d274f6769164640dd5e1.tar.gz |
metrics have been added
Diffstat (limited to 'contrib/libs/libmysql_r/strings/longlong2str.cc')
-rw-r--r-- | contrib/libs/libmysql_r/strings/longlong2str.cc | 145 |
1 files changed, 145 insertions, 0 deletions
diff --git a/contrib/libs/libmysql_r/strings/longlong2str.cc b/contrib/libs/libmysql_r/strings/longlong2str.cc new file mode 100644 index 0000000000..fe5d2c43f8 --- /dev/null +++ b/contrib/libs/libmysql_r/strings/longlong2str.cc @@ -0,0 +1,145 @@ +/* Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License, version 2.0, + as published by the Free Software Foundation. + + This program is also distributed with certain software (including + but not limited to OpenSSL) that is licensed under separate terms, + as designated in a particular file or component or in included license + documentation. The authors of MySQL hereby grant you an additional + permission to link the program and your derivative works with the + separately licensed software that they have included with MySQL. + + Without limiting anything contained in the foregoing, this file, + which is part of C Driver for MySQL (Connector/C), is also subject to the + Universal FOSS Exception, version 1.0, a copy of which can be found at + http://oss.oracle.com/licenses/universal-foss-exception. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License, version 2.0, for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ + +/* + Defines: longlong2str(); + + longlong2str(dst, radix, val) + converts the (longlong) integer "val" to character form and moves it to + the destination string "dst" followed by a terminating NUL. The + result is normally a pointer to this NUL character, but if the radix + is dud the result will be NullS and nothing will be changed. + + If radix is -2..-36, val is taken to be SIGNED. + If radix is 2.. 36, val is taken to be UNSIGNED. + That is, val is signed if and only if radix is. You will normally + use radix -10 only through itoa and ltoa, for radix 2, 8, or 16 + unsigned is what you generally want. + + _dig_vec is public just in case someone has a use for it. + The definitions of itoa and ltoa are actually macros in m_string.h, + but this is where the code is. + + Note: The standard itoa() returns a pointer to the argument, when int2str + returns the pointer to the end-null. + itoa assumes that 10 -base numbers are allways signed and other arn't. +*/ + +#include "m_string.h" + +#include <limits.h> + +#ifndef ll2str + +/* + This assumes that longlong multiplication is faster than longlong division. +*/ + +char *ll2str(longlong val, char *dst, int radix, int upcase) { + char buffer[65]; + char *p; + long long_val; + char *dig_vec = upcase ? _dig_vec_upper : _dig_vec_lower; + ulonglong uval = (ulonglong)val; + + if (radix < 0) { + if (radix < -36 || radix > -2) return (char *)0; + if (val < 0) { + *dst++ = '-'; + /* Avoid integer overflow in (-val) for LLONG_MIN (BUG#31799). */ + uval = (ulonglong)0 - uval; + } + radix = -radix; + } else { + if (radix > 36 || radix < 2) return (char *)0; + } + if (uval == 0) { + *dst++ = '0'; + *dst = '\0'; + return dst; + } + p = &buffer[sizeof(buffer) - 1]; + *p = '\0'; + + while (uval > (ulonglong)LONG_MAX) { + ulonglong quo = uval / (uint)radix; + uint rem = (uint)(uval - quo * (uint)radix); + *--p = dig_vec[rem]; + uval = quo; + } + long_val = (long)uval; + while (long_val != 0) { + long quo = long_val / radix; + *--p = dig_vec[(uchar)(long_val - quo * radix)]; + long_val = quo; + } + while ((*dst++ = *p++) != 0) + ; + return dst - 1; +} +#endif + +#ifndef longlong10_to_str +char *longlong10_to_str(longlong val, char *dst, int radix) { + char buffer[65]; + char *p; + long long_val; + ulonglong uval = (ulonglong)val; + + if (radix < 0) { + if (val < 0) { + *dst++ = '-'; + /* Avoid integer overflow in (-val) for LLONG_MIN (BUG#31799). */ + uval = (ulonglong)0 - uval; + } + } + + if (uval == 0) { + *dst++ = '0'; + *dst = '\0'; + return dst; + } + p = &buffer[sizeof(buffer) - 1]; + *p = '\0'; + + while (uval > (ulonglong)LONG_MAX) { + ulonglong quo = uval / (uint)10; + uint rem = (uint)(uval - quo * (uint)10); + *--p = _dig_vec_upper[rem]; + uval = quo; + } + long_val = (long)uval; + while (long_val != 0) { + long quo = long_val / 10; + *--p = _dig_vec_upper[(uchar)(long_val - quo * 10)]; + long_val = quo; + } + while ((*dst++ = *p++) != 0) + ; + return dst - 1; +} +#endif |