Content of basic-string repository was moved to BTL repository as subpackage btl:string
https://submada.github.io/btl/btl/string.html
The BasicString is the generalization of struct string for character type char, wchar and dchar.
Allocator is template argument instead of using theAllocator so that string can be used in @nogc code. Default allocator is Mallocator.
BasicString use Small String Optimization (SSO)
Works with pure, @safe, @nogc and nothrow.
Compatible with -betterC
-dip1000 is too unstable, for now is not supported.
Does not rely on runtime type information (TypeInfo).
pure nothrow @safe @nogc unittest { import std.experimental.allocator.mallocator : Mallocator; alias String = BasicString!( char, //character type Mallocator, //allocator type (can be stateless or with state) 32 //additional padding to increas max size of small string (small string does not allocate memory). ); //copy: { String a = "123"; String b = a; a = "456"d; assert(a == "456"); assert(b == "123"); } //append: { String str = "12"; str.append("34"); //same as str += "34" str.append("56"w); //same as str += "56"w str.append(7); //same as str += 7; str.append('8'); assert(str == "12345678"); str.clear(); assert(str.empty); } //erase: { String str = "123456789"; str.erase(2, 2); assert(str == "1256789"); } //insert: { String str = "123456789"; str.insert(1, "xyz"); assert(str == "1xyz23456789"); } //replace: { String str = "123456789"; str.replace(1, 2, "xyz"); assert(str == "1xyz456789"); } //slice to string: ()@trusted{ String str = "123456789"; string dstr = str[]; assert(str == dstr); }(); }