CloverBootloader/rEFIt_UEFI/cpp_foundation/XString.h

330 lines
16 KiB
C
Raw Normal View History

2020-03-12 15:40:38 +01:00
//*************************************************************************************************
//*************************************************************************************************
//
// STRING
//
//*************************************************************************************************
//*************************************************************************************************
#if !defined(__XSTRING_H__)
#define __XSTRING_H__
#include "XToolsCommon.h"
#define PATH_SEPARATOR '\\'
extern UINTN XStringGrowByDefault;
//class XConstString;
class XStringW;
class XString
{
protected:
2020-03-26 13:59:20 +01:00
char *m_data;
xsize m_allocatedSize;
// convenience method. Did it this way to avoid #define in header. They can have an impact on other headers
xsize min(xsize x1, xsize x2) const { if ( x1 < x2 ) return x1; return x2; }
xsize max(xsize x1, xsize x2) const { if ( x1 > x2 ) return x1; return x2; }
// Next 2 methods are protected intentionally. They are const method returning non-const pointer. That's intentional, but dangerous. Do not expose to public.
// It's better practice, if you need a non-const pointer for low-level access, to use dataSized and ahev to specify the size
2020-04-05 14:25:39 +02:00
// It's possible to access data(m_allocatedSize) because the real allocated size is m_allocatedSize+1
char* _data(unsigned int ui) const { if ( ui > m_allocatedSize ) panic("char* data(unsigned int ui=0) -> ui > m_allocatedSize"); return m_data+ui; }
char* _data(int i) const { if ( i<0 ) panic("char* data(int i) -> i < 0"); if ( (unsigned int)i > m_allocatedSize ) panic("char* data(int i) -> i > m_allocatedSize"); return m_data+i; }
char* _data(unsigned long ui) const { if ( ui > m_allocatedSize ) panic("char* data(unsigned long ui=0) -> ui > m_allocatedSize"); return m_data+ui; }
char* _data(long i) const { if ( i<0 ) panic("char* data(long i) -> i < 0"); if ( (unsigned long)i > m_allocatedSize ) panic("char* data(long i) -> i > m_allocatedSize"); return m_data+i; }
char* _data(xsize ui) const { if ( ui > m_allocatedSize ) panic("char* data(xsize ui=0) -> ui > m_allocatedSize"); return m_data+ui; }
char* _data(xisize i) const { if ( i<0 ) panic("char* data(xisize i) -> i < 0"); if ( (xsize)i > m_allocatedSize ) panic("char* data(xisize i) -> i > m_allocatedSize"); return m_data+i; }
2020-03-12 15:40:38 +01:00
public:
void Init(xsize aSize=0);
XString();
XString(const XString &aString);
2020-03-28 17:17:02 +01:00
XString(XString&& aString); // Move constructor
2020-03-12 15:40:38 +01:00
// XString(const XConstString &aConstString);
// XString(const char *S);
// XString(const char* S, xsize count);
2020-03-12 15:40:38 +01:00
// XString(const wchar_t *S);
2020-03-12 15:40:38 +01:00
// XString(uchar);
// XString(char);
// XString(int);
// XString(unsigned long long);
2020-03-12 15:40:38 +01:00
~XString();
public:
char *CheckSize(xsize nNewSize, xsize nGrowBy = XStringGrowByDefault);
public:
2020-03-26 13:59:20 +01:00
const char* c_str() const { return m_data; } // same as std::string
const char* data(xsize ui=0) const { return _data(ui); }
const char* data(xisize i) const { return _data(i); }
2020-03-12 15:40:38 +01:00
2020-03-26 13:59:20 +01:00
char* dataSized(xsize ui, xsize sizeMin, xsize nGrowBy=XStringGrowByDefault) { CheckSize(ui+sizeMin, nGrowBy); return _data(ui); }
xsize length() const { return strlen(m_data); }
xsize size() const { return strlen(m_data); }
xsize allocatedSize() const { return m_allocatedSize; }
void setLength(xsize len);
2020-03-12 15:40:38 +01:00
/* IsNull ? */
2020-03-26 13:59:20 +01:00
void setEmpty() { setLength(0); }
2020-03-12 15:40:38 +01:00
bool isEmpty() const { return length() == 0; }
2020-04-05 14:25:39 +02:00
bool notEmpty() const { return !isEmpty(); }
2020-03-12 15:40:38 +01:00
/* Cast */
2020-04-05 14:25:39 +02:00
// operator const char *() const { return data(); } // disabled during big refactoring
2020-03-12 15:40:38 +01:00
// operator char *() { return data(); }
2020-03-26 13:59:20 +01:00
// int ToInt() const;
// UINTN ToUINTN() const;
2020-03-12 15:40:38 +01:00
/* char [] */
2020-03-26 13:59:20 +01:00
char operator [](int i) const { return *_data(i); }
char operator [](unsigned int ui) const { return *_data(ui); }
char operator [](long i) const { return *_data(i); }
char operator [](unsigned long ui) const { return *_data(ui); }
char operator [](xisize i) const { return *data(i); }
char operator [](xsize ui) const { return *data(ui); }
2020-03-12 15:40:38 +01:00
/* char& [] */
2020-03-26 13:59:20 +01:00
char& operator [](int i) { return *_data(i); }
char& operator [](unsigned int ui) { return *_data(ui); }
char& operator [](long i) { return *_data(i); }
char& operator [](unsigned long ui) { return *_data(ui); }
char& operator [](xisize i) { return *_data(i); }
char& operator [](xsize ui) { return *_data(ui); }
2020-03-12 15:40:38 +01:00
2020-03-26 13:59:20 +01:00
char lastChar() const { if ( length() > 0 ) return data()[length()-1]; else return 0; }
void removeLastEspCtrl();
2020-03-12 15:40:38 +01:00
void StrCpy(const char *buf);
void StrnCpy(const char *buf, xsize len);
void StrnCat(const char *buf, xsize len);
void StrCat(const char *buf);
2020-04-05 14:25:39 +02:00
void StrCat(const XString& S) { StrCat(S.c_str()) ; }
2020-03-12 15:40:38 +01:00
void Delete(xsize pos, xsize count=1);
void Insert(xsize pos, const XString& Str);
void Cat(const XString &uneXString);
XString& vSPrintf(const char *Format, va_list va);
2020-04-05 14:25:39 +02:00
XString& SPrintf(const char *format, ...) __attribute__((format (printf, 2, 3))); // 2 and 3 because of hidden parameter 'this'.
2020-03-12 15:40:38 +01:00
const XString& takeValueFrom(const char* S) { StrCpy(S); return *this; }
const XString& takeValueFrom(const char* S, xsize count) { StrnCpy(S, count); return *this; }
2020-03-12 17:16:18 +01:00
const XString& takeValueFrom(const wchar_t* S) { SPrintf("%ls", S); return *this; }
2020-03-12 15:40:38 +01:00
2020-03-28 17:17:02 +01:00
const XString& operator =(const XString& aString);
XString& operator =(XString&& aString);
2020-03-12 15:40:38 +01:00
// const XString &operator =(const XConstString &aConstString);
// Deactivate assignment during refactoring to avoid confusion
// const XString &operator =(const char* S);
// const XString &operator =(char);
// const XString &operator =(int);
// const XString &operator =(unsigned int);
// const XString &operator =(long);
// const XString &operator =(unsigned long long);
2020-03-12 15:40:38 +01:00
const XString &operator += (const XString &);
const XString &operator += (const char* S);
// const XString &operator += (const XConstString &aConstString);
// Deactivate assignment during refactoring to avoid confusion
// const XString &operator += (char);
// const XString &operator += (int);
// const XString &operator += (unsigned int);
// const XString &operator += (long);
// const XString &operator += (unsigned long long);
2020-03-12 15:40:38 +01:00
XString SubString(xsize pos, xsize count) const;
2020-04-05 14:25:39 +02:00
2020-03-12 15:40:38 +01:00
xsize IdxOf(char c, xsize Pos = 0) const;
2020-04-05 14:25:39 +02:00
xsize IdxOf(const char* s, xsize s_len, xsize pos) const;
xsize IdxOf(const char* s, xsize pos = 0) const { return IdxOf(s, strlen(s), pos); }
xsize IdxOf(const XString &S, xsize pos = 0) const { return IdxOf(S.c_str(), S.length(), pos); }
bool ExistIn(const char* s, xsize s_len, xsize pos = 0) const { return IdxOf(s, s_len, pos) != MAX_XSIZE; }
bool ExistIn(const char* s, xsize pos = 0) const { return IdxOf(s, pos) != MAX_XSIZE; }
bool ExistIn(const XString &S, xsize pos = 0) const { return IdxOf(S, pos) != MAX_XSIZE; }
xsize IdxOfIC(const char* s, xsize s_len, xsize pos) const;
xsize IdxOfIC(const char* s, xsize pos = 0) const { return IdxOfIC(s, strlen(s), pos); }
xsize IdxOfIC(const XString &S, xsize pos = 0) const { return IdxOfIC(S.c_str(), S.length(), pos); }
bool ExistInIC(const char* s, xsize s_len, xsize pos = 0) const { return IdxOfIC(s, s_len, pos) != MAX_XSIZE; }
bool ExistInIC(const char* s, xsize pos = 0) const { return IdxOfIC(s, pos) != MAX_XSIZE; }
bool ExistInIC(const XString &S, xsize pos = 0) const { return IdxOfIC(S, pos) != MAX_XSIZE; }
#ifdef TODO_skqdjfhksqjhfksjqdf
bool ExistInIAC(const XString &S) const { return IdxOfIC(S) != MAX_XSIZE; }
#endif
2020-03-12 15:40:38 +01:00
#ifdef TODO_skqdjfhksqjhfksjqdf
xsize IdxOfIAC(const XString &S, xsize Pos = 0) const;
#endif
2020-04-05 14:25:39 +02:00
xsize RIdxOf(const char* s, xsize s_len, xsize pos) const;
xsize RIdxOf(const char* s, xsize pos = MAX_XSIZE) const { return IdxOf(s, strlen(s), pos); }
xsize RIdxOf(const XString &S, xsize pos = MAX_XSIZE) const { return IdxOf(S.c_str(), S.length(), pos); }
2020-03-12 15:40:38 +01:00
void ToLower(bool FirstCharIsCap = false);
bool IsLetters() const;
bool IsLettersNoAccent() const;
bool IsDigits() const;
bool IsDigits(xsize pos, xsize count) const;
#ifdef TODO_skqdjfhksqjhfksjqdf
bool DeleteIC(const XString &S);
#endif
void Replace(char c1, char c2);
XString SubStringReplace(char c1, char c2);
2020-03-29 15:44:08 +02:00
int Compare(const char* S) const { return strcmp(data(), (S ? S : "")); }// AsciiStrCmp return 0 or !0, not usual strcmp
2020-03-12 15:40:38 +01:00
#ifdef TODO_skqdjfhksqjhfksjqdf
//IC
int CompareIC(const char* S) const { return StringCompareIC(data(), (S ? S : "")); }
// IA
int CompareIA(const char* S) const { return StringCompareIA(data(), (S ? S : "")); }
// IAC
int CompareIAC(const char* S) const { return StringCompareIAC(data(), (S ? S : "")); }
/*
int CompareIACSubString(const char* S, size_t LenS) const { return SubStringCompareIAC(data(), length(), S, LenS); } //SubStringCompareIC renvoi 0 (ÈgalitÈ) si Len1 ou Len2 == 0
int CompareIACSubString(xsize Pos, const char* S, size_t LenS) const { return SubStringCompareIAC(data(Pos), length()-Pos, S, LenS); } //SubStringCompareIC renvoi 0 (ÈgalitÈ) si Len1 ou Len2 == 0
int CompareIACSubString(xsize Pos, xsize Len, const char* S, size_t LenS) const { return SubStringCompareIAC(data(Pos), Len, S, LenS); }
*/
#endif
2020-04-05 14:25:39 +02:00
// bool Equal(const char* S) const { return strcmp(data(), (S ? S : "")) == 0; };
bool Equal(const XString& S) const { return strcmp(c_str(), S.c_str()) == 0; };
2020-03-12 15:40:38 +01:00
// bool BeginEqual(const char* S) const { return StringBeginEqual(data(), S); }
// bool SubStringEqual(xsize Pos, const char* S) const { return StringBeginEqual(data(Pos), S); }
#ifdef TODO_skqdjfhksqjhfksjqdf
// IC
bool EqualIC(const char* S) const { return StringEqualIC(data(), S); }
bool BeginEqualIC(const char* S) const { return StringBeginEqualIC(data(), S); }
bool SubStringEqualIC(xsize Pos, const char* S) const { return StringBeginEqualIC(data(Pos), S); }
bool EqualSubStringIC(const char* S) const { return StringBeginEqualIC(S, data()); }
// IA
bool EqualIA(const char* S) const { return CompareIA(S) == 0; };
// IAC
bool EqualIAC(const char* S) const { return CompareIAC(S) == 0; };
bool BeginEqualIAC(const char* S) const { return StringBeginEqualIAC(data(), S); }
bool SubStringEqualIAC(xsize Pos, const char* S) const { return StringBeginEqualIAC(data(Pos), S); }
bool EqualSubStringIAC(const char* S) const { return StringBeginEqualIAC(S, data()); }
/* bool EqualIACSubString(const char* S, size_t LenS) const { return CompareIACSubString(S, LenS) == 0; }
bool EqualIACSubString(xsize Pos, const char* S, size_t LenS) const { return CompareIACSubString(Pos, S, LenS) == 0; }
bool EqualIACSubString(xsize Pos, xsize Len, const char* S, size_t LenS) const { return CompareIACSubString(Pos, Len, S, LenS) == 0; }
*/
#endif
XString basename() const;
XString dirname() const;
// size_t Sizeof() const { return size_t(sizeof(xsize)+length()); } // overflow ? underflow ?
// bool ReadFromBuf(const char *buf, size_t *idx, size_t count);
// bool WriteToBuf(char *buf, size_t *idx, size_t count) const;
// bool ReadFromFILE(FILE *fp);
// bool WriteToFILE(FILE *fp) const;
// //
// bool ReadFromXBuffer(XRBuffer &unXBuffer); // Impossible de mettre le XBuffer en const car il y a une variable d'instance de XBuffer incrÈmentÈe par ReadFromXBuffer
// void CatToXBuffer(XBuffer *unXBuffer) const;
//// void WriteToXBuffer(XBuffer *unXBuffer, xsize *idx) const;
public:
// OpÈrateur +
// Chaines
friend XString operator + (const XString& p1, const XString& p2) { XString s; s=p1; s+=p2; return s; }
2020-03-28 17:17:02 +01:00
// friend XString operator + (const XString& p1, const char *p2 ) { XString s; s=p1; s+=p2; return s; }
2020-04-05 14:25:39 +02:00
// XString operator + (const char *p2 ) { XString s(*this); s+=p2; return s; }
2020-03-28 17:17:02 +01:00
friend XString operator + (const char *p1, const XString& p2) { XString s; s.takeValueFrom(p1); s+=p2; return s; }
2020-03-12 15:40:38 +01:00
// friend XString operator + (const XConstString& p1, const XString& p2) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const XString& p1, const XConstString& p2) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const XConstString& p1, const XConstString& p2) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const XConstString &p1, const char *p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const char *p1, const XConstString &p2) { XString s; s=p1; s+=p2; return s; }
// deactivate during refactoring
// // Char
// friend XString operator + (const XString& p1, char p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (char p1, const XString& p2 ) { XString s; s=p1; s+=p2; return s; }
// // NumÈrique
// friend XString operator + (const XString& p1, int p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (int p1, const XString& p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const XString& p1, unsigned int p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (unsigned int p1, const XString& p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const XString& p1, long p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (long p1, const XString& p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (const XString& p1, unsigned long long p2 ) { XString s; s=p1; s+=p2; return s; }
// friend XString operator + (unsigned long long p1, const XString& p2 ) { XString s; s=p1; s+=p2; return s; }
2020-03-12 15:40:38 +01:00
// OpÈrateur ==
// Chaines
friend bool operator == (const XString& s1, const XString& s2) { return s1.Equal(s2); }
2020-04-05 14:25:39 +02:00
// friend bool operator == (const XString& s1, const char* s2 ) { return s1.Equal(s2); } // during refactor
// friend bool operator == (const char* s1, const XString& s2) { return s2.Equal(s1); } // during refactor
2020-03-12 15:40:38 +01:00
// friend bool operator == (const XConstString &s1, const XString& s2) { return s1.Compare(s2) == 0; }
// friend bool operator == (const XString &s1, const XConstString& s2) { return s1.Compare(s2) == 0; }
// friend bool operator == (const XConstString &s1, const XConstString& s2) { return s1.Compare(s2) == 0; }
friend bool operator != (const XString& s1, const XString& s2) { return !s1.Equal(s2); }
2020-04-05 14:25:39 +02:00
// friend bool operator != (const XString& s1, const char* s2 ) { return !s1.Equal(s2); } // during refactor
// friend bool operator != (const char* s1, const XString& s2) { return !s2.Equal(s1); } // during refactor
2020-03-12 15:40:38 +01:00
// friend bool operator != (const XConstString &s1, const XString& s2) { return s1.Compare(s2) != 0; }
// friend bool operator != (const XString &s1, const XConstString& s2) { return s1.Compare(s2) != 0; }
// friend bool operator != (const XConstString &s1, const XConstString& s2) { return s1.Compare(s2) != 0; }
// friend bool operator < (const XString& s1, const XString& s2) { return s1.Compare(s2) < 0; }
// friend bool operator < (const XString& s1, const char* s2 ) { return s1.Compare(s2) < 0; }
// friend bool operator < (const char* s1, const XString& s2) { return s2.Compare(s1) > 0; }
//
// friend bool operator > (const XString& s1, const XString& s2) { return s1.Compare(s2) > 0; }
// friend bool operator > (const XString& s1, const char* s2 ) { return s1.Compare(s2) > 0; }
// friend bool operator > (const char* s1, const XString& s2) { return s2.Compare(s1) < 0; }
//
// friend bool operator <= (const XString& s1, const XString& s2) { return s1.Compare(s2) <= 0; }
// friend bool operator <= (const XString& s1, const char* s2 ) { return s1.Compare(s2) <= 0; }
// friend bool operator <= (const char* s1, const XString& s2) { return s2.Compare(s1) >= 0; }
//
// friend bool operator >= (const XString& s1, const XString& s2) { return s1.Compare(s2) >= 0; }
// friend bool operator >= (const XString& s1, const char* s2 ) { return s1.Compare(s2) >= 0; }
// friend bool operator >= (const char* s1, const XString& s2) { return s2.Compare(s1) <= 0; }
2020-04-05 14:25:39 +02:00
static char to_lower(char ch) { return (((ch >= L'A') && (ch <= L'Z')) ? ((ch - L'A') + L'a') : ch); }
2020-03-12 15:40:38 +01:00
};
extern const XString NullXString;
XString operator"" _XS ( const char* s, size_t len);
2020-04-05 14:25:39 +02:00
XString SPrintf(const char *format, ...) __attribute__((format(printf, 1, 2)));
XString SubString(const char *s, xsize s_len, xsize pos, xsize count);
inline XString SubString(const char *s, xsize pos, xsize count) { return SubString(s, strlen(s), pos, count); }
inline XString SubString(const XString& S, xsize pos, xsize count) { return SubString(S.c_str(), S.length(), pos, count); }
2020-03-12 15:40:38 +01:00
#ifdef TODO_skqdjfhksqjhfksjqdf
XString ToAlpha(const char *S);
XString ToAlpha(const XString &S);
XString ToLower(const char *S, bool FirstCharIsCap = false);
XString ToUpper(const char *S);
#endif
// Deactivate assignment during refactoring to avoid confusion
//XString CleanCtrl(const XString &S);
2020-03-12 15:40:38 +01:00
#endif