summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
6ec42f8)
This is consistent with the behaviour of std::string.
string_data::data[string_data::len] = '\0';
}
}
string_data::data[string_data::len] = '\0';
}
}
- string() : string (nullptr, 0) {}
- string(const char* s)
- : string(s, s == nullptr ? 0 : strlen(s))
- {}
+ string() : string (const_cast<char*>(&NUL), 0) {}
+ string(const char* s) : string(s, strlen(s)) {}
string(string const& s) : string(s.c_str(), s.size()) {}
string(string&& s)
{
string(string const& s) : string(s.c_str(), s.size()) {}
string(string&& s)
{
// Assign
void assign(const char* s, size_t size)
{
// Assign
void assign(const char* s, size_t size)
{
- if (string_data::data != &NUL)
+ if (string_data::data != &NUL) {
std::free(string_data::data);
std::free(string_data::data);
- if (size == 0) {
- string_data::len = 0;
string_data::data = nullptr;
string_data::data = nullptr;
+ string_data::len = 0;
+ }
+ if (size != 0) {
string_data::len = size;
string_data::data = (char*) std::malloc(string_data::len + 1);
string_data::len = size;
string_data::data = (char*) std::malloc(string_data::len + 1);
- memcpy(string_data::data, s, string_data::len);
+ std::memcpy(string_data::data, s, string_data::len);
string_data::data[string_data::len] = '\0';
}
}
string_data::data[string_data::len] = '\0';
}
}
// Copy
string& operator=(const char* s)
{
// Copy
string& operator=(const char* s)
{
- assign(s, s == nullptr ? 0 : std::strlen(s));
+ assign(s, std::strlen(s));
return *this;
}
string& operator=(string const& s)
return *this;
}
string& operator=(string const& s)
void clear()
{
string_data::len = 0;
void clear()
{
string_data::len = 0;
- string_data::data = (char*) &NUL;
+ string_data::data = const_cast<char*>(&NUL);
}
bool equals(const char* data, std::size_t len) const
}
bool equals(const char* data, std::size_t len) const