2015-08-20 23:39:08 -04:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Jared Boone, ShareBrained Technology, Inc.
|
|
|
|
*
|
|
|
|
* This file is part of PortaPack.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
* any later version.
|
|
|
|
*
|
|
|
|
* 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 for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; see the file COPYING. If not, write to
|
|
|
|
* the Free Software Foundation, Inc., 51 Franklin Street,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2016-01-31 03:34:24 -05:00
|
|
|
#ifndef __STRING_FORMAT_H__
|
|
|
|
#define __STRING_FORMAT_H__
|
2015-08-20 23:39:08 -04:00
|
|
|
|
2016-01-31 03:34:24 -05:00
|
|
|
#include <cstdint>
|
2023-06-11 16:35:45 -04:00
|
|
|
#include <array>
|
2016-01-31 03:34:24 -05:00
|
|
|
#include <string>
|
2023-06-15 16:15:26 -04:00
|
|
|
#include <string_view>
|
2015-08-20 23:39:08 -04:00
|
|
|
|
2018-01-09 16:12:19 -05:00
|
|
|
#include "file.hpp"
|
|
|
|
|
2016-01-31 03:34:24 -05:00
|
|
|
// BARF! rtc::RTC is leaking everywhere.
|
2015-08-20 23:39:08 -04:00
|
|
|
#include "lpc43xx_cpp.hpp"
|
|
|
|
using namespace lpc43xx;
|
|
|
|
|
2017-08-17 07:56:47 -04:00
|
|
|
enum TimeFormat {
|
2023-05-18 16:16:05 -04:00
|
|
|
YMDHMS = 0,
|
|
|
|
HMS = 1,
|
|
|
|
HM = 2
|
2017-08-17 07:56:47 -04:00
|
|
|
};
|
|
|
|
|
2023-05-18 16:16:05 -04:00
|
|
|
const char unit_prefix[7]{'n', 'u', 'm', 0, 'k', 'M', 'G'};
|
2017-11-02 13:11:26 -04:00
|
|
|
|
2023-07-11 16:48:36 -04:00
|
|
|
using StringFormatBuffer = std::array<char, 24>;
|
2023-06-11 16:35:45 -04:00
|
|
|
|
2023-08-18 15:35:41 -04:00
|
|
|
/* Integer conversion without memory allocations. */
|
|
|
|
char* to_string_dec_int(int64_t n, StringFormatBuffer& buffer, size_t& length);
|
|
|
|
char* to_string_dec_uint(uint64_t n, StringFormatBuffer& buffer, size_t& length);
|
2023-07-11 16:48:36 -04:00
|
|
|
|
2023-08-18 15:35:41 -04:00
|
|
|
std::string to_string_dec_int(int64_t n);
|
|
|
|
std::string to_string_dec_uint(uint64_t n);
|
2023-06-11 16:35:45 -04:00
|
|
|
|
2016-12-05 06:56:41 -05:00
|
|
|
std::string to_string_bin(const uint32_t n, const uint8_t l = 0);
|
2023-07-11 16:48:36 -04:00
|
|
|
std::string to_string_dec_uint(const uint32_t n, const int32_t l, const char fill = ' ');
|
2023-08-18 15:35:41 -04:00
|
|
|
std::string to_string_dec_int(const int32_t n, const int32_t l, const char fill = 0);
|
2021-06-23 18:52:15 -04:00
|
|
|
std::string to_string_decimal(float decimal, int8_t precision);
|
|
|
|
|
2023-09-12 15:38:19 -04:00
|
|
|
std::string to_string_hex(uint64_t n, int32_t length);
|
|
|
|
std::string to_string_hex_array(uint8_t* array, int32_t length);
|
|
|
|
|
|
|
|
/* Helper to select length based on type size. */
|
|
|
|
template <typename T>
|
|
|
|
std::string to_string_hex(T n) {
|
|
|
|
return to_string_hex(n, sizeof(T) * 2); // Two digits/byte.
|
|
|
|
}
|
2015-08-20 23:39:08 -04:00
|
|
|
|
2022-03-28 23:53:09 -04:00
|
|
|
std::string to_string_freq(const uint64_t f);
|
2017-05-18 16:56:55 -04:00
|
|
|
std::string to_string_short_freq(const uint64_t f);
|
2023-07-14 14:38:02 -04:00
|
|
|
std::string to_string_rounded_freq(const uint64_t f, int8_t precision);
|
2017-12-10 23:14:54 -05:00
|
|
|
std::string to_string_time_ms(const uint32_t ms);
|
2017-04-24 13:15:57 -04:00
|
|
|
|
2017-08-17 07:56:47 -04:00
|
|
|
std::string to_string_datetime(const rtc::RTC& value, const TimeFormat format = YMDHMS);
|
2016-01-31 03:34:24 -05:00
|
|
|
std::string to_string_timestamp(const rtc::RTC& value);
|
2018-01-09 16:12:19 -05:00
|
|
|
std::string to_string_FAT_timestamp(const FATTimestamp& timestamp);
|
2015-08-20 23:39:08 -04:00
|
|
|
|
2023-05-19 16:39:35 -04:00
|
|
|
// Gets a human readable file size string.
|
|
|
|
std::string to_string_file_size(uint32_t file_size);
|
|
|
|
|
2023-09-18 17:22:46 -04:00
|
|
|
/* Scales 'n' to be a value less than 1000. 'base_unit' is the index of the unit from
|
|
|
|
* 'unit_prefix' that 'n' is in initially. 3 is the index of the '1s' unit. */
|
|
|
|
std::string unit_auto_scale(double n, const uint32_t base_unit, uint32_t precision);
|
2023-06-15 16:15:26 -04:00
|
|
|
double get_decimals(double num, int16_t mult, bool round = false);
|
2023-02-28 14:04:03 -05:00
|
|
|
|
2023-06-15 16:15:26 -04:00
|
|
|
std::string trim(std::string_view str); // Remove whitespace at ends.
|
|
|
|
std::string trimr(std::string_view str); // Remove trailing spaces
|
|
|
|
std::string truncate(std::string_view, size_t length);
|
2023-02-28 14:04:03 -05:00
|
|
|
|
2023-09-12 15:38:19 -04:00
|
|
|
/* Gets the int value for a character given the radix.
|
|
|
|
* e.g. '5' => 5, 'D' => 13. Out of bounds => 0. */
|
|
|
|
uint8_t char_to_uint(char c, uint8_t radix = 10);
|
|
|
|
|
|
|
|
/* Gets the int value for a character given the radix.
|
|
|
|
* e.g. 5 => '5', 13 => 'D'. Out of bounds => '\0'. */
|
|
|
|
char uint_to_char(uint8_t val, uint8_t radix = 10);
|
|
|
|
|
2023-05-18 16:16:05 -04:00
|
|
|
#endif /*__STRING_FORMAT_H__*/
|