removed redundant strlen calculation from String::substr
This commit is contained in:
parent
a2f9ce2569
commit
e0df1221bf
2 changed files with 16 additions and 6 deletions
|
@ -161,14 +161,21 @@ void String::copy_from(const CharType *p_cstr, int p_clip_to) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
resize(len + 1);
|
copy_from_unchecked(p_cstr, len);
|
||||||
set(len, 0);
|
}
|
||||||
|
|
||||||
|
// assumes the following have already been validated:
|
||||||
|
// p_char != NULL
|
||||||
|
// p_length > 0
|
||||||
|
// p_length <= p_char strlen
|
||||||
|
void String::copy_from_unchecked(const CharType *p_char, int p_length) {
|
||||||
|
resize(p_length + 1);
|
||||||
|
set(p_length, 0);
|
||||||
|
|
||||||
CharType *dst = &operator[](0);
|
CharType *dst = &operator[](0);
|
||||||
|
|
||||||
for (int i = 0; i < len; i++) {
|
for (int i = 0; i < p_length; i++) {
|
||||||
|
dst[i] = p_char[i];
|
||||||
dst[i] = p_cstr[i];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2246,7 +2253,9 @@ String String::substr(int p_from, int p_chars) const {
|
||||||
return String(*this);
|
return String(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
return String(&c_str()[p_from], p_chars);
|
String s = String();
|
||||||
|
s.copy_from_unchecked(&c_str()[p_from], p_chars);
|
||||||
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
int String::find_last(const String &p_str) const {
|
int String::find_last(const String &p_str) const {
|
||||||
|
|
|
@ -65,6 +65,7 @@ class String : public Vector<CharType> {
|
||||||
void copy_from(const char *p_cstr);
|
void copy_from(const char *p_cstr);
|
||||||
void copy_from(const CharType *p_cstr, int p_clip_to = -1);
|
void copy_from(const CharType *p_cstr, int p_clip_to = -1);
|
||||||
void copy_from(const CharType &p_char);
|
void copy_from(const CharType &p_char);
|
||||||
|
void copy_from_unchecked(const CharType *p_char, int p_length);
|
||||||
bool _base_is_subsequence_of(const String &p_string, bool case_insensitive) const;
|
bool _base_is_subsequence_of(const String &p_string, bool case_insensitive) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in a new issue