Unverified Commit 722c4641 authored by Rodrigo Garcia's avatar Rodrigo Garcia Committed by GitHub

Extends String to print 64-bit integers (#6768)

parent ba6e82c3
...@@ -137,6 +137,24 @@ String::String(double value, unsigned int decimalPlaces) { ...@@ -137,6 +137,24 @@ String::String(double value, unsigned int decimalPlaces) {
} }
} }
String::String(long long value, unsigned char base) {
init();
char buf[2 + 8 * sizeof(long long)];
if (base==10) {
sprintf(buf, "%lld", value); // NOT SURE - NewLib Nano ... does it support %lld?
} else {
lltoa(value, buf, base);
}
*this = buf;
}
String::String(unsigned long long value, unsigned char base) {
init();
char buf[1 + 8 * sizeof(unsigned long long)];
ulltoa(value, buf, base);
*this = buf;
}
String::~String() { String::~String() {
invalidate(); invalidate();
} }
...@@ -408,6 +426,17 @@ unsigned char String::concat(double num) { ...@@ -408,6 +426,17 @@ unsigned char String::concat(double num) {
return concat(string, strlen(string)); return concat(string, strlen(string));
} }
unsigned char String::concat(long long num) {
char buf[2 + 3 * sizeof(long long)];
return concat(buf, sprintf(buf, "%lld", num)); // NOT SURE - NewLib Nano ... does it support %lld?
}
unsigned char String::concat(unsigned long long num) {
char buf[1 + 3 * sizeof(unsigned long long)];
ulltoa(num, buf, 10);
return concat(buf, strlen(buf));
}
unsigned char String::concat(const __FlashStringHelper * str) { unsigned char String::concat(const __FlashStringHelper * str) {
if (!str) return 0; if (!str) return 0;
int length = strlen_P((PGM_P)str); int length = strlen_P((PGM_P)str);
...@@ -493,6 +522,20 @@ StringSumHelper & operator +(const StringSumHelper &lhs, double num) { ...@@ -493,6 +522,20 @@ StringSumHelper & operator +(const StringSumHelper &lhs, double num) {
return a; return a;
} }
StringSumHelper & operator +(const StringSumHelper &lhs, long long num) {
StringSumHelper &a = const_cast<StringSumHelper&>(lhs);
if(!a.concat(num))
a.invalidate();
return a;
}
StringSumHelper & operator +(const StringSumHelper &lhs, unsigned long long num) {
StringSumHelper &a = const_cast<StringSumHelper&>(lhs);
if(!a.concat(num))
a.invalidate();
return a;
}
StringSumHelper & operator + (const StringSumHelper &lhs, const __FlashStringHelper *rhs) StringSumHelper & operator + (const StringSumHelper &lhs, const __FlashStringHelper *rhs)
{ {
StringSumHelper &a = const_cast<StringSumHelper&>(lhs); StringSumHelper &a = const_cast<StringSumHelper&>(lhs);
......
...@@ -73,6 +73,8 @@ class String { ...@@ -73,6 +73,8 @@ class String {
explicit String(unsigned long, unsigned char base = 10); explicit String(unsigned long, unsigned char base = 10);
explicit String(float, unsigned int decimalPlaces = 2); explicit String(float, unsigned int decimalPlaces = 2);
explicit String(double, unsigned int decimalPlaces = 2); explicit String(double, unsigned int decimalPlaces = 2);
explicit String(long long, unsigned char base = 10);
explicit String(unsigned long long, unsigned char base = 10);
~String(void); ~String(void);
// memory management // memory management
...@@ -122,6 +124,8 @@ class String { ...@@ -122,6 +124,8 @@ class String {
unsigned char concat(unsigned long num); unsigned char concat(unsigned long num);
unsigned char concat(float num); unsigned char concat(float num);
unsigned char concat(double num); unsigned char concat(double num);
unsigned char concat(long long num);
unsigned char concat(unsigned long long num);
unsigned char concat(const __FlashStringHelper * str); unsigned char concat(const __FlashStringHelper * str);
// if there's not enough memory for the concatenated value, the string // if there's not enough memory for the concatenated value, the string
...@@ -166,6 +170,14 @@ class String { ...@@ -166,6 +170,14 @@ class String {
concat(num); concat(num);
return (*this); return (*this);
} }
String & operator +=(long long num) {
concat(num);
return (*this);
}
String & operator +=(unsigned long long num) {
concat(num);
return (*this);
}
String & operator += (const __FlashStringHelper *str){ String & operator += (const __FlashStringHelper *str){
concat(str); concat(str);
return (*this); return (*this);
...@@ -182,6 +194,8 @@ class String { ...@@ -182,6 +194,8 @@ class String {
friend StringSumHelper & operator +(const StringSumHelper &lhs, float num); friend StringSumHelper & operator +(const StringSumHelper &lhs, float num);
friend StringSumHelper & operator +(const StringSumHelper &lhs, double num); friend StringSumHelper & operator +(const StringSumHelper &lhs, double num);
friend StringSumHelper & operator +(const StringSumHelper &lhs, const __FlashStringHelper *rhs); friend StringSumHelper & operator +(const StringSumHelper &lhs, const __FlashStringHelper *rhs);
friend StringSumHelper & operator +(const StringSumHelper &lhs, long long num);
friend StringSumHelper & operator +(const StringSumHelper &lhs, unsigned long long num);
// comparison (only works w/ Strings and "strings") // comparison (only works w/ Strings and "strings")
operator StringIfHelperType() const { operator StringIfHelperType() const {
...@@ -373,6 +387,12 @@ class StringSumHelper: public String { ...@@ -373,6 +387,12 @@ class StringSumHelper: public String {
StringSumHelper(double num) : StringSumHelper(double num) :
String(num) { String(num) {
} }
StringSumHelper(long long num) :
String(num) {
}
StringSumHelper(unsigned long long num) :
String(num) {
}
}; };
extern const String emptyString; extern const String emptyString;
......
...@@ -67,6 +67,31 @@ char* ltoa(long value, char* result, int base) { ...@@ -67,6 +67,31 @@ char* ltoa(long value, char* result, int base) {
return result; return result;
} }
char* lltoa (long long val, char* result, int base) {
if(base < 2 || base > 16) {
*result = 0;
return result;
}
char* out = result;
long long quotient = val > 0 ? val : -val;
do {
const long long tmp = quotient / base;
*out = "0123456789abcdef"[quotient - (tmp * base)];
++out;
quotient = tmp;
} while(quotient);
// Apply negative sign
if(val < 0)
*out++ = '-';
reverse(result, out);
*out = 0;
return result;
}
char* ultoa(unsigned long value, char* result, int base) { char* ultoa(unsigned long value, char* result, int base) {
if(base < 2 || base > 16) { if(base < 2 || base > 16) {
*result = 0; *result = 0;
...@@ -88,6 +113,27 @@ char* ultoa(unsigned long value, char* result, int base) { ...@@ -88,6 +113,27 @@ char* ultoa(unsigned long value, char* result, int base) {
return result; return result;
} }
char* ulltoa (unsigned long long val, char* result, int base) {
if(base < 2 || base > 16) {
*result = 0;
return result;
}
char* out = result;
unsigned long long quotient = val;
do {
const unsigned long long tmp = quotient / base;
*out = "0123456789abcdef"[quotient - (tmp * base)];
++out;
quotient = tmp;
} while(quotient);
reverse(result, out);
*out = 0;
return result;
}
char * dtostrf(double number, signed int width, unsigned int prec, char *s) { char * dtostrf(double number, signed int width, unsigned int prec, char *s) {
bool negative = false; bool negative = false;
...@@ -160,3 +206,5 @@ char * dtostrf(double number, signed int width, unsigned int prec, char *s) { ...@@ -160,3 +206,5 @@ char * dtostrf(double number, signed int width, unsigned int prec, char *s) {
*out = 0; *out = 0;
return s; return s;
} }
...@@ -35,10 +35,14 @@ char* itoa (int val, char *s, int radix); ...@@ -35,10 +35,14 @@ char* itoa (int val, char *s, int radix);
char* ltoa (long val, char *s, int radix); char* ltoa (long val, char *s, int radix);
char* lltoa (long long val, char* s, int radix);
char* utoa (unsigned int val, char *s, int radix); char* utoa (unsigned int val, char *s, int radix);
char* ultoa (unsigned long val, char *s, int radix); char* ultoa (unsigned long val, char *s, int radix);
char* ulltoa (unsigned long long val, char* s, int radix);
char* dtostrf (double val, signed int width, unsigned int prec, char *s); char* dtostrf (double val, signed int width, unsigned int prec, char *s);
#ifdef __cplusplus #ifdef __cplusplus
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment