//************************************************************************************************* //************************************************************************************************* // // STRING // // Developed by jief666, from 1997. // //************************************************************************************************* //************************************************************************************************* #if !defined(__XString_H__) #define __XString_H__ #include #include "XStringAbstract.h" #include "../../Include/Library/printf_lite.h" #ifndef XString16GrowByDefault #define XString16GrowByDefault 16 #endif //------------------------------------------------------------------------------------------------------------------ class XString8; class LString8 : public LString { public: constexpr LString8() = delete; constexpr LString8(const char* s) : LString(s) {}; // no assignement, no destructor friend constexpr LString8 operator "" _XS8 ( const char* s, size_t) { return LString8(s); } }; class XString8 : public XStringAbstract { public: XString8() : XStringAbstract() {}; XString8(const XString8& S) : XStringAbstract(S) {} XString8(const LString8& S) : XStringAbstract(S) { } template // enable_if is to avoid constructing with a non-corresponding LString. To avoid memory allocation. XString8(const OtherXStringClass& S) : XStringAbstract(S) {} XString8& operator=(const XString8 &S) { this->XStringAbstract::operator=(S); return *this; } using XStringAbstract::operator =; protected: static void transmitSPrintf(const char* buf, unsigned int nbchar, void* context) { ((XString8*)(context))->strncat(buf, nbchar); } public: void vSPrintf(const char* format, va_list va) { setEmpty(); vprintf_with_callback(format, va, transmitSPrintf, this); } void SPrintf(const char* format, ...) __attribute__((__format__(__printf__, 2, 3))) { va_list va; va_start (va, format); vSPrintf(format, va); va_end(va); } }; //------------------------------------------------------------------------------------------------------------------ class XString16; class LString16 : public LString { constexpr LString16(const char16_t* s) : LString(s) {}; friend constexpr LString16 operator "" _XS16 ( const char16_t* s, size_t) { return LString16(s); } }; class XString16 : public XStringAbstract { public: XString16() : XStringAbstract() {}; XString16(const XString16& S) : XStringAbstract(S) {} template // enable_if is to avoid constructing with a non-corresponding LString. To avoid memory allocation. XString16(const OtherXStringClass& S) : XStringAbstract(S) {} XString16& operator=(const XString16 &S) { this->XStringAbstract::operator=(S); return *this; } using XStringAbstract::operator =; // friend LString16 operator "" _XS16 ( const char16_t* s, size_t len); }; //------------------------------------------------------------------------------------------------------------------ class XString32; class LString32 : public LString { constexpr LString32(const char32_t* s) : LString(s) {}; friend constexpr LString32 operator "" _XS32 ( const char32_t* s, size_t) { return LString32(s); } }; class XString32 : public XStringAbstract { public: XString32() : XStringAbstract() {}; XString32(const XString32& S) : XStringAbstract(S) {} template // enable_if is to avoid constructing with a non-corresponding LString. To avoid memory allocation. XString32(const OtherXStringClass& S) : XStringAbstract(S) {} XString32& operator=(const XString32 &S) { this->XStringAbstract::operator=(S); return *this; } using XStringAbstract::operator =; // friend LString32 operator "" _XS32 ( const char32_t* s, size_t len); }; //------------------------------------------------------------------------------------------------------------------ class XStringW; class LStringW : public LString { public: constexpr LStringW() = delete; constexpr LStringW(const wchar_t* s) : LString(s) {}; friend constexpr LStringW operator "" _XSW ( const wchar_t* s, size_t) { return LStringW(s); } }; class XStringW : public XStringAbstract { public: XStringW() : XStringAbstract() {}; XStringW(const XStringW& S) : XStringAbstract(S) {} template // enable_if is to avoid constructing with a non-corresponding LString. To avoid memory allocation. XStringW(const OtherXStringClass& S) : XStringAbstract(S) {} XStringW(const LStringW& S) : XStringAbstract(S) { } XStringW& operator=(const XStringW &S) { this->XStringAbstract::operator=(S); return *this; } using XStringAbstract::operator =; protected: static void transmitSPrintf(const wchar_t* buf, unsigned int nbchar, void* context) { ((XStringW*)(context))->strncat(buf, nbchar); } public: void vSWPrintf(const char* format, va_list va) { setEmpty(); vwprintf_with_callback(format, va, transmitSPrintf, this); } void SWPrintf(const char* format, ...) __attribute__((__format__(__printf__, 2, 3))) { va_list va; va_start (va, format); vSWPrintf(format, va); va_end(va); } }; constexpr LString8 operator"" _XS8 ( const char* s, size_t len); constexpr LString16 operator"" _XS16 ( const char16_t* s, size_t len); constexpr LString32 operator"" _XS32 ( const char32_t* s, size_t len); constexpr LStringW operator"" _XSW ( const wchar_t* s, size_t len); extern const XString8 NullXString; extern const XStringW NullXStringW; #ifdef _MSC_VER # define __attribute__(x) #endif XString8 SPrintf(const char* format, ...) __attribute__((__format__ (__printf__, 1, 2))); XStringW SWPrintf(const char* format, ...) __attribute__((__format__ (__printf__, 1, 2))); // //XStringAbstract SubString(const T *S, size_t pos, size_t count); #endif