276 lines
4.7 KiB
C
276 lines
4.7 KiB
C
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
|
|
static void reverse(char* buf, int len)
|
|
{
|
|
int start = 0;
|
|
int end = len - 1;
|
|
while (start < end) {
|
|
char tmp = buf[start];
|
|
buf[start] = buf[end];
|
|
buf[end] = tmp;
|
|
end--;
|
|
start++;
|
|
}
|
|
}
|
|
|
|
char* s64toa(int64_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
bool neg = false;
|
|
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
if (num < 0 && base == 10) { // only handle negative on base10
|
|
neg = true;
|
|
num = -num;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
if (neg) // lets reapply the negative sign
|
|
buf[i++] = '-';
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* u64toa(uint64_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* s32toa(int32_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
bool neg = false;
|
|
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
if (num < 0 && base == 10) { // only handle negative on base10
|
|
neg = true;
|
|
num = -num;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
if (neg) // lets reapply the negative sign
|
|
buf[i++] = '-';
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* u32toa(uint32_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* s16toa(int16_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
bool neg = false;
|
|
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
if (num < 0 && base == 10) { // only handle negative on base10
|
|
neg = true;
|
|
num = -num;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
if (neg) // lets reapply the negative sign
|
|
buf[i++] = '-';
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* u16toa(uint16_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* s8toa(int8_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
bool neg = false;
|
|
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
if (num < 0 && base == 10) { // only handle negative on base10
|
|
neg = true;
|
|
num = -num;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
if (neg) // lets reapply the negative sign
|
|
buf[i++] = '-';
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* u8toa(uint8_t num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* itoa(int num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
bool neg = false;
|
|
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
if (num < 0 && base == 10) { // only handle negative on base10
|
|
neg = true;
|
|
num = -num;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
if (neg) // lets reapply the negative sign
|
|
buf[i++] = '-';
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|
|
|
|
char* utoa(unsigned int num, char* buf, int base)
|
|
{
|
|
int i = 0;
|
|
if (num == 0) { // Handle zero explicitly
|
|
buf[i++] = '0';
|
|
buf[i] = '\0';
|
|
return buf;
|
|
}
|
|
|
|
while (num != 0) {
|
|
int rem = num % base;
|
|
buf[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
|
|
num = num / base;
|
|
}
|
|
|
|
buf[i] = '\0';
|
|
|
|
reverse(buf, i); // reverse, since we did it backwards!
|
|
return buf;
|
|
}
|