58#define strtoull _strtoui64
62namespace std { using ::list; }
120 memcpy(
data, s.c_str(),
n);
129 Error(
"TString::TString",
"NULL input string!");
134 Error(
"TString::TString",
"Negative length!");
138 if (strlen(cs) < (
size_t)
n) {
139 Warning(
"TString::TString",
"Input string is shorter than requested size.");
168 Error(
"TString::TString",
"Negative length!");
196 fRep.fRaw = s.fRep.fRaw;
207 memcpy(
data, substr.data(),
len);
226 Error(
"TString::TString",
"Negative first length!");
231 Error(
"TString::TString",
"Negative second length!");
239 Error(
"TString::TString",
"Too large number of characters!");
244 if (a1) memcpy(
data, a1, n1);
245 if (a2) memcpy(
data+n1, a2, n2);
264 Error(
"TString::Init",
"Negative length!");
268 Error(
"*TString::Init",
"Negative length!");
271 if (
nchar > capacity) {
272 Error(
"TString::Init",
"capacity is smaller than nchar (%d > %d)",
nchar, capacity);
276 Fatal(
"TString::Init",
"capacity too large (%d, max = %d)", capacity,
MaxSize());
278 if (
nchar > capacity)
283 if (capacity < kMinCap) {
288 data =
new char[cap+1];
374 fRep.fRaw = rhs.fRep.fRaw;
399 if (!rep)
return *
this;
402 Error(
"TString::Append",
"Negative length!");
409 Fatal(
"TString::Append",
"rep too large (%d, max = %d)", rep,
MaxSize()-
len);
417 if (capac - tot >= 0) {
422 data =
new char[cap+1];
461 const char *cs1 =
Data();
465 for (; cs2[i]; ++i) {
466 if (i ==
len)
return -1;
467 if (cs1[i] != cs2[i])
return ((cs1[i] > cs2[i]) ? 1 : -1);
470 for (; cs2[i]; ++i) {
471 if (i ==
len)
return -1;
472 char c1 = tolower((
unsigned char)cs1[i]);
473 char c2 = tolower((
unsigned char)cs2[i]);
474 if (
c1 !=
c2)
return ((
c1 >
c2) ? 1 : -1);
477 return (i <
len) ? 1 : 0;
490 const char *s2 = str.
Data();
494 if (
len < slen) slen =
len;
500 for (; i < slen; ++i) {
501 char c1 = tolower((
unsigned char)
s1[i]);
502 char c2 = tolower((
unsigned char)s2[i]);
503 if (
c1 !=
c2)
return ((
c1 >
c2) ? 1 : -1);
508 if (
len == slen)
return 0;
509 return (
len > slen) ? 1 : -1;
521 if (
data[
n] ==
c) count++;
540 const char *
f = strchr(
Data(),
c);
549 const char *
f = strpbrk(
Data(), cs);
558 return (((
x & 0x000000ffU) << 24) | ((
x & 0x0000ff00U) << 8) |
559 ((
x & 0x00ff0000U) >> 8) | ((
x & 0xff000000U) >> 24));
596 if ((i =
len*
sizeof(
char)%
sizeof(
UInt_t)) != 0) {
598 const char*
c = (
const char*)
p;
606 const unsigned char *
p = (
const unsigned char*)str;
619 if ((i =
len*
sizeof(
char)%
sizeof(
UInt_t)) != 0) {
621 const char*
c = (
const char*)
p;
651 const char*
c = (
const char*)
p;
666 const unsigned char *
p = (
const unsigned char*)
Data();
668 Mash(hv, toupper(*
p));
702#if defined(_MSC_VER) && (_MSC_VER < 1800)
704 typedef unsigned char uint8_t;
705 typedef unsigned long uint32_t;
706 typedef unsigned __int64 uint64_t;
716#define ROTL64(x,y) _rotl64(x,y)
717#define BIG_CONSTANT(x) (x)
722 return (
x <<
r) | (
x >> (64 -
r));
725#define ROTL64(x,y) rotl64(x,y)
726#define BIG_CONSTANT(x) (x##LLU)
760 static void MurmurHash3_x64_128(
const void * key,
const int len,
761 const uint32_t seed, uint64_t out[2] )
763 const uint8_t *
data = (
const uint8_t*)key;
764 const int nblocks =
len / 16;
775 const uint64_t * blocks = (
const uint64_t *)(
data);
777 for(
int i = 0; i < nblocks; i++)
779 uint64_t k1 = getblock(blocks,i*2+0);
780 uint64_t k2 = getblock(blocks,i*2+1);
786 k2 *=
c2; k2 =
ROTL64(k2,33); k2 *=
c1; h2 ^= k2;
788 h2 =
ROTL64(h2,31); h2 +=
h1; h2 = h2*5+0x38495ab5;
794 const uint8_t * tail = (
const uint8_t*)(
data + nblocks*16);
800 case 15: k2 ^= uint64_t(tail[14]) << 48;
801 case 14: k2 ^= uint64_t(tail[13]) << 40;
802 case 13: k2 ^= uint64_t(tail[12]) << 32;
803 case 12: k2 ^= uint64_t(tail[11]) << 24;
804 case 11: k2 ^= uint64_t(tail[10]) << 16;
805 case 10: k2 ^= uint64_t(tail[ 9]) << 8;
806 case 9: k2 ^= uint64_t(tail[ 8]) << 0;
807 k2 *=
c2; k2 =
ROTL64(k2,33); k2 *=
c1; h2 ^= k2;
809 case 8: k1 ^= uint64_t(tail[ 7]) << 56;
810 case 7: k1 ^= uint64_t(tail[ 6]) << 48;
811 case 6: k1 ^= uint64_t(tail[ 5]) << 40;
812 case 5: k1 ^= uint64_t(tail[ 4]) << 32;
813 case 4: k1 ^= uint64_t(tail[ 3]) << 24;
814 case 3: k1 ^= uint64_t(tail[ 2]) << 16;
815 case 2: k1 ^= uint64_t(tail[ 1]) << 8;
816 case 1: k1 ^= uint64_t(tail[ 0]) << 0;
834 ((uint64_t*)out)[0] =
h1;
835 ((uint64_t*)out)[1] = h2;
852 if (ntxt !=
sizeof(
void*)) {
853 uint64_t buf[2] = {0};
854 MurmurHash3_x64_128(txt, ntxt, 0x6384BA69, buf);
860 if (((
size_t)txt) %
sizeof(
void*)) {
863 if (
sizeof(
void*) >
sizeof(
UInt_t)) {
867 const unsigned char* ctxt = (
const unsigned char*) txt;
868 for (
unsigned int i = 0; i < 4; ++i) {
869 ret ^= ctxt[i] << (i * 8);
871 if (
sizeof(
void*) >
sizeof(
UInt_t)) {
873 for (
unsigned int i = 0; i < 4; ++i) {
874 ret ^= ctxt[i] << (i * 8);
889 if (tolower((
unsigned char)*
p) != tolower((
unsigned char)*
q))
905 Error(
"TString::Index",
"Negative first pattern length!");
909 if (slen < startIndex + plen)
return kNPOS;
910 if (plen == 0)
return startIndex;
911 slen -= startIndex + plen;
912 const char *sp =
Data() + startIndex;
914 char first = *pattern;
915 for (
Ssiz_t i = 0; i <= slen; ++i)
916 if (sp[i] == first && memcmp(sp+i+1, pattern+1, plen-1) == 0)
917 return i + startIndex;
919 int first = tolower((
unsigned char) *pattern);
920 for (
Ssiz_t i = 0; i <= slen; ++i)
921 if (tolower((
unsigned char) sp[i]) == first &&
923 return i + startIndex;
933 const char *
f = strrchr(
Data(), (
unsigned char)
c);
954 const char *specials =
"^$.[]*+?";
966 const char *specials =
"[]*?";
986 Fatal(
"TString::Prepend",
"rep too large (%d, max = %d)", rep,
MaxSize()-
len);
994 if (capac - tot >= 0) {
995 memmove(
p + rep,
p,
len);
1000 data =
new char[cap+1];
1022 if (pos <= kNPOS || pos >
len) {
1023 Error(
"TString::Replace",
1024 "first argument out of bounds: pos = %d, Length = %d", pos,
len);
1028 Error(
"TString::Replace",
"Negative number of characters to remove!");
1032 Error(
"TString::Replace",
"Negative number of replacement characters!");
1041 Error(
"TString::Replace",
"Too large number of characters!");
1053 if (n2) memmove(
p + pos, cs, n2);
1054 memmove(
p + pos + n2,
p + pos + n1, rem);
1059 if (
p + pos < cs && cs <
p +
len) {
1060 if (
p + pos + n1 <= cs)
1063 memmove(
p + pos, cs, n1);
1070 memmove(
p + pos + n2,
p + pos + n1, rem);
1073 if (n2) memmove(
p + pos, cs, n2);
1078 char *
data =
new char[cap+1];
1079 if (pos) memcpy(
data,
p, pos);
1080 if (n2 ) memcpy(
data + pos, cs, n2);
1081 if (rem) memcpy(
data + pos + n2,
p + pos + n1, rem);
1098 if (
s1 && ls1 > 0) {
1132 while (start < end &&
direct[start] ==
c)
1135 while (start < end &&
direct[end-1] ==
c)
1145 Remove(send - start - (send - end), send - end);
1170 while (start < end &&
direct[start] ==
c)
1173 while (start < end &&
direct[end-1] ==
c)
1175 if (end == start) start = end =
kNPOS;
1187 *
p = tolower((
unsigned char)*
p);
1200 *
p = toupper((
unsigned char)*
p);
1211 Error(
"TString::AssertElement",
1212 "out of bounds: i = %d, Length = %d", i,
Length());
1223 if (newCap > ms - 1) {
1224 Fatal(
"TString::AdjustCapacity",
"capacity too large (%d, max = %d)",
1249 Fatal(
"TString::Clobber",
"capacity too large (%d, max = %d)", nc,
MaxSize());
1263 data =
new char[cap+1];
1282 if (
len >= tot)
return;
1285 Fatal(
"TString::Clone",
"tot too large (%d, max = %d)", tot,
MaxSize());
1292 if (capac - tot < 0) {
1294 data =
new char[cap+1];
1318 tobuf(buffer, nchars);
1324 for (
int i = 0; i < nchars; i++) buffer[i] =
data[i];
1346 Error(
"TString::ReadBuffer",
"found case with nwh=%d and nchars=%d", nwh, nchars);
1352 for (
int i = 0; i < nchars; i++)
frombuf(buffer, &
data[i]);
1373 TClass *clRef =
b.ReadClass(clReq, &tag);
1384 ::Error(
"TString::ReadObject",
"could not create object of class %s",
1392 b.CheckByteCount(startpos, tag, clRef);
1414 if (
b.IsReading()) {
1415 b.ReadTString(*
this);
1417 b.WriteTString(*
this);
1451 b.SetByteCount(cntpos);
1458#if defined(R__TEMPLATE_OVERLOAD_BUG)
1486 const char *
data =
s1.Data();
1489 for (i = 0; s2[i]; ++i)
1501 const char *uc = str.
Data();
1502 char *lc = (
char*)temp.
Data();
1504 while (
n--) { *lc++ = tolower((
unsigned char)*uc); uc++; }
1515 const char* uc = str.
Data();
1516 char* lc = (
char*)temp.
Data();
1518 while (
n--) { *lc++ = toupper((
unsigned char)*uc); uc++; }
1570 ::Obsolete(
"TString::GetInitialCapacity",
"v5-30-00",
"v5-32-00");
1578 ::Obsolete(
"TString::GetResizeIncrement",
"v5-30-00",
"v5-32-00");
1586 ::Obsolete(
"TString::GetMaxWaste",
"v5-30-00",
"v5-32-00");
1595 ::Obsolete(
"TString::InitialCapacity",
"v5-30-00",
"v5-32-00");
1604 ::Obsolete(
"TString::ResizeIncrement",
"v5-30-00",
"v5-32-00");
1614 ::Obsolete(
"TString::MaxWaste",
"v5-30-00",
"v5-32-00");
1632 : fStr((
TString&)str), fBegin(start), fExtent(nextent)
1660 Ssiz_t len = pattern ? strlen(pattern) : 0;
1709 if (ss.
IsNull())
return *cs ==
'\0';
1713 for (i = 0; cs[i]; ++i)
1733 if (
s1.IsNull())
return s2.
IsNull();
1747 while (
n--) { *
p = tolower((
unsigned char)*
p);
p++;}
1759 while (
n--) { *
p = toupper((
unsigned char)*
p);
p++;}
1768 Error(
"TSubString::SubStringError",
1769 "out of bounds: start = %d, n = %d, sr = %d", start,
n, sr);
1778 Error(
"TSubString::AssertElement",
1779 "out of bounds: i = %d, Length = %d", i,
Length());
1787 const char *cp =
Data();
1800 const char *cp =
Data();
1804 if (!isalpha(cp[i]))
1815 const char *cp =
Data();
1819 if (!isalnum(cp[i]))
1832 const char *cp =
Data();
1837 if (cp[i] !=
' ' && !isdigit(cp[i]))
return kFALSE;
1838 if (cp[i] ==
' ')
b++;
1839 if (isdigit(cp[i]))
d++;
1868 Ssiz_t pos = tmp.First(
'.');
1869 if (pos !=
kNPOS) tmp.Replace(pos, 1,
" ", 1);
1870 pos = tmp.First(
',');
1871 if (pos !=
kNPOS) tmp.Replace(pos, 1,
" ", 1);
1872 pos = tmp.Index(
"e-");
1873 if (pos >= 1) tmp.Replace(pos, 2,
" ", 1);
1874 pos = tmp.Index(
"e+");
1875 if (pos >= 1) tmp.Replace(pos, 2,
" ", 1);
1876 pos = tmp.Index(
"e");
1877 if (pos >= 1) tmp.Replace(pos, 1,
" ", 1);
1878 pos = tmp.First(
'-');
1879 if (pos == 0) tmp.Replace(pos, 1,
" ", 1);
1880 pos = tmp.First(
'+');
1881 if (pos == 0) tmp.Replace(pos, 1,
" ", 1);
1884 return tmp.IsDigit();
1894 const char *cp =
Data();
1898 if (!isxdigit(cp[i]))
1910 const char *cp =
Data();
1914 if (cp[i] !=
'0' && cp[i] !=
'1')
1926 const char *cp =
Data();
1930 if (!isdigit(cp[i]) || cp[i]==
'8' || cp[i]==
'9')
1942 const char *cp =
Data();
1946 if (!isdigit(cp[i]))
1959 if (base < 2 || base > 36) {
1960 Error(
"TString::IsInBaseN",
"base %d is not supported. Supported bases are {2,3,...,36}.", base);
1964 Error(
"TString::IsInBaseN",
"input string is empty.") ;
1969 TString str_ref0 =
"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ" ;
1993 if (end == -1)
return atoi(
Data());
1999 tmp += (*this)(start, end-start);
2000 start = end+1; end =
Index(
" ", start);
2004 tmp += (*this)(start, end-start);
2005 return atoi(tmp.Data());
2020 if (end == -1)
return atoll(
Data());
2022 if (end == -1)
return _atoi64(
Data());
2029 tmp += (*this)(start, end-start);
2030 start = end+1; end =
Index(
" ", start);
2034 tmp += (*this)(start, end-start);
2036 return atoll(tmp.Data());
2038 return _atoi64(tmp.Data());
2060 if (comma == -1 && end == -1)
return atof(
Data());
2064 tmp.Replace(comma, 1,
".");
2067 if (end == -1)
return atof(tmp.Data());
2072 tmp2 += tmp(start, end-start);
2073 start = end+1; end = tmp.Index(
" ", start);
2076 tmp2 += tmp(start, end-start);
2077 return atof(tmp2.
Data());
2096 if (base < 2 || base > 36) {
2097 Error(
"TString::Itoa",
"base %d is not supported. Supported bases are {2,3,...,36}.",base) ;
2104 buf +=
"0123456789abcdefghijklmnopqrstuvwxyz"[
TMath::Abs(quotient % base) ];
2108 if (
value < 0) buf +=
'-';
2109 std::reverse(buf.begin(), buf.end());
2123 if (base < 2 || base > 36) {
2124 Error(
"TString::UItoa",
"base %d is not supported. Supported bases are {2,3,...,36}.",base);
2131 buf +=
"0123456789abcdefghijklmnopqrstuvwxyz"[ quotient % base ];
2134 std::reverse(buf.begin(), buf.end());
2148 if (base < 2 || base > 36) {
2149 Error(
"TString::LLtoa",
"base %d is not supported. Supported bases are {2,3,...,36}.",base);
2156 buf +=
"0123456789abcdefghijklmnopqrstuvwxyz"[
TMath::Abs(quotient % base) ];
2160 if (
value < 0) buf +=
'-';
2161 std::reverse(buf.begin(), buf.end());
2175 if (base < 2 || base > 36) {
2176 Error(
"TString::ULLtoa",
"base %d is not supported. Supported bases are {2,3,...,36}.",base);
2183 buf +=
"0123456789abcdefghijklmnopqrstuvwxyz"[ quotient % base ];
2186 std::reverse(buf.begin(), buf.end());
2198 if (base_in < 2 || base_in > 36 || base_out < 2 || base_out > 36) {
2199 Error(
"TString::BaseConvert",
"only bases 2-36 are supported (base_in=%d, base_out=%d).", base_in, base_out);
2205 if (s_in_[0] ==
'-') {
2209 if (!isSigned && s_in_[0] ==
'+') s_in_.
Remove(0, 1);
2212 if (!s_in_.
Length()) s_in_ +=
'0';
2215 Error(
"TString::BaseConvert",
"s_in=\"%s\" is not in base %d", s_in.
Data(), base_in);
2222 Error(
"TString::BaseConvert",
"s_in=\"%s\" > %s = 2^64-1 in base %d.", s_in.
Data(), s_max.
Data(), base_in);
2227 if (s_in_ > s_max) {
2229 Error(
"TString::BaseConvert",
"s_in=\"%s\" > %s = 2^64-1 in base %d.", s_in.
Data(), s_max.
Data(), base_in);
2237 if (isSigned) s_out.
Prepend(
"-");
2246 if (!s)
return kTRUE;
2253 return strcmp(s, s2) == 0;
2254 return strcasecmp(s, s2) == 0;
2266 std::list<Int_t> splitIndex;
2268 Int_t i, start, nrDiff = 0;
2269 for (i = 0; i < delim.
Length(); i++) {
2271 while (start <
Length()) {
2273 if (pos ==
kNPOS)
break;
2274 splitIndex.push_back(pos);
2277 if (start > 0) nrDiff++;
2279 splitIndex.push_back(
Length());
2288 std::list<Int_t>::const_iterator it;
2290 for (it = splitIndex.begin(); it != splitIndex.end(); ++it) {
2292 for (it = splitIndex.begin(); it != (std::list<Int_t>::const_iterator) splitIndex.end(); ++it) {
2295 if (stop - 1 >= start + 1) {
2296 TString tok = (*this)(start+1, stop-start-1);
2312 Ssiz_t buflen = 20 + 20 * strlen(fmt);
2323 if (
n == -1 ||
n >= buflen) {
2359 va_start(ap,
va_(fmt));
2381 va_start(ap,
va_(fmt));
2396 static const int fld_size = 2048;
2397 TTHREAD_TLS(
char*) slowBuffer(
nullptr);
2398 TTHREAD_TLS(
int) slowBufferSize(0);
2400 if (hint == -1) hint = fld_size;
2401 if (hint > slowBufferSize) {
2402 delete [] slowBuffer;
2403 slowBufferSize = 2 * hint;
2404 if (hint < 0 || slowBufferSize < 0) {
2406 slowBuffer =
nullptr;
2409 slowBuffer =
new char[slowBufferSize];
2415 int n = vsnprintf(slowBuffer, slowBufferSize,
format, ap);
2418 if (
n == -1 ||
n >= slowBufferSize) {
2419 if (
n == -1)
n = 2 * slowBufferSize;
2420 if (
n == slowBufferSize)
n++;
2444 static const int cb_size = 4096;
2445 static const int fld_size = 2048;
2448 TTHREAD_TLS_ARRAY(
char,cb_size,gFormbuf);
2449 TTHREAD_TLS(
char*) gBfree(
nullptr);
2450 TTHREAD_TLS(
char*) gEndbuf(
nullptr);
2452 if (gBfree ==
nullptr) {
2454 gEndbuf = &gFormbuf[cb_size-1];
2458 if (buf+fld_size > gEndbuf)
2464 int n = vsnprintf(buf, fld_size,
format, ap);
2467 if (
n == -1 ||
n >= fld_size) {
2492 va_start(ap,
va_(fmt));
2506 va_start(ap,
va_(fmt));
2523 if (!s)
return nullptr;
2526 char *buf =
new char[
l+1];
2539 const char *t2 = s +
l - 1;
2540 while (*t2 ==
c && t2 > s)
2548 *(buf+(t2-
t1+1)) =
'\0';
2559 if (!str)
return nullptr;
2561 auto len = strlen(str)+1;
2562 char *s =
new char[
len];
2563 if (s) strlcpy(s, str,
len);
2574 if (!str)
return nullptr;
2576 const char *
p = str;
2577 char *s, *
s1 =
new char[strlen(str)+1];
2593int EscChar(
const char *
src,
char *dst,
int dstlen,
char *specchars,
2597 char *
q, *end = dst+dstlen-1;
2599 for (
p =
src,
q = dst; *
p &&
q < end; ) {
2600 if (strchr(specchars, *
p)) {
2617int UnEscChar(
const char *
src,
char *dst,
int dstlen,
char *specchars,
char)
2620 char *
q, *end = dst+dstlen-1;
2622 for (
p =
src,
q = dst; *
p &&
q < end; ) {
2623 if (strchr(specchars, *
p))
2635#ifdef NEED_STRCASECMP
2639int strcasecmp(
const char *str1,
const char *str2)
2641 return strncasecmp(str1, str2, str2 ? strlen(str2)+1 : 0);
2647int strncasecmp(
const char *str1,
const char *str2,
Ssiz_t n)
2673std::string cling::printValue(
const TString* val) {
2681std::string cling::printValue(
const TSubString* val) {
2689std::string cling::printValue(
const std::string_view* val) {
2690 std::string str(*val);
void frombuf(char *&buf, Bool_t *x)
void tobuf(char *&buf, Bool_t x)
constexpr ULong_t kBitsPerByte
unsigned long long ULong64_t
TBuffer & operator<<(TBuffer &buf, const Tmpl *obj)
#define R__ASSERT(e)
Checks condition e and reports a fatal error if it's false.
void ErrorHandler(int level, const char *location, const char *fmt, std::va_list va)
General error handler function. It calls the user set error handler.
void Error(const char *location, const char *msgfmt,...)
Use this function in case an error occurred.
void Obsolete(const char *function, const char *asOfVers, const char *removedFromVers)
Use this function to declare a function obsolete.
void Warning(const char *location, const char *msgfmt,...)
Use this function in warning situations.
void Fatal(const char *location, const char *msgfmt,...)
Use this function in case of a fatal error. It will abort the program.
Bool_t gPrintViaErrorHandler
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t result
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t index
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void value
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t UChar_t len
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t GCValues_t GetPrimarySelectionOwner GetDisplay GetScreen GetColormap GetNativeEvent const char const char dpyName wid window const char font_name cursor keysym reg const char only_if_exist regb h Point_t winding char text const char depth char const char Int_t count const char ColorStruct_t color const char Pixmap_t Pixmap_t PictureAttributes_t attr const char char ret_data h unsigned char height h Atom_t Int_t ULong_t ULong_t unsigned char prop_list Atom_t Atom_t Atom_t Time_t format
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t Float_t Float_t Int_t Int_t UInt_t UInt_t Rectangle_t Int_t Int_t Window_t TString Int_t nchar
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t src
uint64_t rotl64(uint64_t x, int8_t r)
TString ToLower(const TString &str)
Return a lower-case version of str.
TString operator+(const TString &s, const char *cs)
Use the special concatenation constructor.
static int MemIsEqual(const char *p, const char *q, Ssiz_t n)
Returns false if strings are not equal.
TBuffer & operator>>(TBuffer &buf, TString *&s)
Read string from TBuffer. Function declared in ClassDef.
Bool_t operator==(const TString &s1, const char *s2)
Compare TString with a char *.
UInt_t Hash(const char *str)
Return a case-sensitive hash value (endian independent).
static char * SlowFormat(const char *format, va_list ap, int hint)
Format a string in a formatting buffer (using a printf style format descriptor).
TString ToUpper(const TString &str)
Return an upper-case version of str.
static UInt_t SwapInt(UInt_t x)
static void Mash(UInt_t &hash, UInt_t chars)
Utility used by Hash().
char * Compress(const char *str)
Remove all blanks from the string str.
int UnEscChar(const char *src, char *dst, int dstlen, char *specchars, char escchar)
Un-escape specchars in src from escchar and copy to dst.
void Printf(const char *fmt,...)
Formats a string in a circular formatting buffer and prints the string.
char * StrDup(const char *str)
Duplicate the string str.
int EscChar(const char *src, char *dst, int dstlen, char *specchars, char escchar)
Escape specchars in src with escchar and copy to dst.
#define R__VA_COPY(to, from)
Buffer base class used for serializing objects.
TClass instances represent classes, structs and namespaces in the ROOT type system.
void Streamer(void *obj, TBuffer &b, const TClass *onfile_class=nullptr) const
void * New(ENewType defConstructor=kClassNew, Bool_t quiet=kFALSE) const
Return a pointer to a newly allocated object of this class.
TClass * IsA() const override
virtual void SetOwner(Bool_t enable=kTRUE)
Set whether this collection is the owner (enable==true) of its content.
This code implements the MD5 message-digest algorithm.
const char * AsString() const
Return message digest as string.
void Update(const UChar_t *buf, UInt_t len)
Update TMD5 object to reflect the concatenation of another buffer full of bytes.
void Final()
MD5 finalization, ends an MD5 message-digest operation, writing the the message digest and zeroizing ...
const char * GetName() const override
Returns name of object.
void Add(TObject *obj) override
Collectable string class.
TString Copy() const
Copy a string.
static TString UItoa(UInt_t value, Int_t base)
Converts a UInt_t (twice the range of an Int_t) to a TString with respect to the base specified (2-36...
static TString LLtoa(Long64_t value, Int_t base)
Converts a Long64_t to a TString with respect to the base specified (2-36).
void SetShortSize(Ssiz_t s)
char & operator()(Ssiz_t i)
Bool_t IsDec() const
Returns true if all characters in string are decimal digits (0-9).
void ToLower()
Change string to lower-case.
int CompareTo(const char *cs, ECaseCompare cmp=kExact) const
Compare a string to char *cs2.
static Ssiz_t MaxWaste(Ssiz_t mw=15)
Set maximum space that may be wasted in a string before doing a resize.
Int_t Atoi() const
Return integer value of string.
void SetLongSize(Ssiz_t s)
static constexpr Ssiz_t kNPOS
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
Return true if string ends with the specified string.
TSubString Strip(EStripType s=kTrailing, char c=' ') const
Return a substring of self stripped at beginning and/or end.
TString()
TString default ctor.
Bool_t IsHex() const
Returns true if all characters in string are hexadecimal digits (0-9,a-f,A-F).
Double_t Atof() const
Return floating-point value contained in string.
TString & ReplaceSpecialCppChars()
Find special characters which are typically used in printf() calls and replace them by appropriate es...
Bool_t IsFloat() const
Returns kTRUE if string contains a floating point or integer number.
void Clear()
Clear string without changing its capacity.
TSubString SubString(const char *pat, Ssiz_t start=0, ECaseCompare cmp=kExact) const
Returns a substring matching "pattern", or the null substring if there is no such match.
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
Ssiz_t First(char c) const
Find first occurrence of a character c.
const char * Data() const
static TString * ReadString(TBuffer &b, const TClass *clReq)
Read TString object from buffer.
Bool_t IsDigit() const
Returns true if all characters in string are digits (0-9) or white spaces, i.e.
Bool_t MaybeRegexp() const
Returns true if string contains one of the regexp characters "^$.[]*+?".
static Ssiz_t ResizeIncrement(Ssiz_t ri=16)
Set default resize increment for all TStrings. Default is 16.
UInt_t HashCase() const
Return a case-sensitive hash value (endian independent).
Bool_t IsOct() const
Returns true if all characters in string are octal digits (0-7).
virtual ~TString()
Delete a TString.
static Ssiz_t GetMaxWaste()
TString & ReplaceAll(const TString &s1, const TString &s2)
static Ssiz_t AdjustCapacity(Ssiz_t oldCap, Ssiz_t newCap)
Calculate a nice capacity greater than or equal to newCap.
TString MD5() const
Return the MD5 digest for this string, in a string representation.
void Resize(Ssiz_t n)
Resize the string. Truncate or add blanks as necessary.
Bool_t IsAlpha() const
Returns true if all characters in string are alphabetic.
UInt_t HashFoldCase() const
Return a case-insensitive hash value (endian independent).
Ssiz_t Last(char c) const
Find last occurrence of a character c.
void ToUpper()
Change string to upper case.
Bool_t IsAscii() const
Returns true if all characters in string are ascii.
TObjArray * Tokenize(const TString &delim) const
This function is used to isolate sequential tokens in a TString.
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
static Ssiz_t GetResizeIncrement()
void SetLongCap(Ssiz_t s)
TString & Prepend(const char *cs)
Bool_t IsBin() const
Returns true if all characters in string are binary digits (0,1).
static TString BaseConvert(const TString &s_in, Int_t base_in, Int_t base_out)
Converts string from base base_in to base base_out.
static TString ULLtoa(ULong64_t value, Int_t base)
Converts a ULong64_t (twice the range of an Long64_t) to a TString with respect to the base specified...
Int_t CountChar(Int_t c) const
Return number of times character c occurs in the string.
UInt_t Hash(ECaseCompare cmp=kExact) const
Return hash value.
static void WriteString(TBuffer &b, const TString *a)
Write TString object to buffer.
virtual void FillBuffer(char *&buffer) const
Copy string into I/O buffer.
TString & operator=(char s)
Assign character c to TString.
TString & Remove(Ssiz_t pos)
static Ssiz_t InitialCapacity(Ssiz_t ic=15)
Set default initial capacity for all TStrings. Default is 15.
virtual void Streamer(TBuffer &)
Stream a string object.
TString & Append(const char *cs)
Bool_t IsInBaseN(Int_t base) const
Returns true if all characters in string are expressed in the base specified (range=2-36),...
char * Init(Ssiz_t capacity, Ssiz_t nchar)
Private member function returning an empty string representation of size capacity and containing ncha...
Bool_t MaybeWildcard() const
Returns true if string contains one of the wildcard characters "[]*?".
void InitChar(char c)
Initialize a string with a single character.
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
static TString Itoa(Int_t value, Int_t base)
Converts an Int_t to a TString with respect to the base specified (2-36).
virtual Int_t Sizeof() const
Returns size string will occupy on I/O buffer.
Ssiz_t Clobber(Ssiz_t nc)
Clear string and make sure it has a capacity of nc.
void Clone(Ssiz_t nc)
Make self a distinct copy with capacity of at least tot, where tot cannot be smaller than the current...
void SetLongPointer(char *p)
Ssiz_t GetLongSize() const
void Form(const char *fmt,...)
Formats a string using a printf style format descriptor.
static Ssiz_t GetInitialCapacity()
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
void AssertElement(Ssiz_t nc) const
Check to make sure a string index is in range.
virtual void ReadBuffer(char *&buffer)
Read string from I/O buffer.
Bool_t IsAlnum() const
Returns true if all characters in string are alphanumeric.
void FormImp(const char *fmt, va_list ap)
Formats a string using a printf style format descriptor.
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
static Ssiz_t Recommend(Ssiz_t s)
Long64_t Atoll() const
Return long long value of string.
A zero length substring is legal.
TSubString(const TString &s, Ssiz_t start, Ssiz_t len)
Private constructor.
TSubString & operator=(const char *s)
Assign char* to sub-string.
void ToUpper()
Convert sub-string to upper-case.
void SubStringError(Ssiz_t, Ssiz_t, Ssiz_t) const
Output error message.
char & operator[](Ssiz_t i)
Return character at pos i from sub-string. Check validity of i.
void AssertElement(Ssiz_t i) const
Check to make sure a sub-string index is in range.
void ToLower()
Convert sub-string to lower-case.
const char * Data() const
char & operator()(Ssiz_t i)
Return character at pos i from sub-string. No check on i.
Short_t Max(Short_t a, Short_t b)
Returns the largest of a and b.
Short_t Min(Short_t a, Short_t b)
Returns the smallest of a and b.
Short_t Abs(Short_t d)
Returns the absolute value of parameter Short_t d.