objstr: *strip(): If nothing is stripped, don't create dup string.
This commit is contained in:
parent
bcdffe53c6
commit
8827682b35
@ -691,6 +691,12 @@ STATIC mp_obj_t str_uni_strip(int type, uint n_args, const mp_obj_t *args) {
|
|||||||
assert(last_good_char_pos >= first_good_char_pos);
|
assert(last_good_char_pos >= first_good_char_pos);
|
||||||
//+1 to accomodate the last character
|
//+1 to accomodate the last character
|
||||||
machine_uint_t stripped_len = last_good_char_pos - first_good_char_pos + 1;
|
machine_uint_t stripped_len = last_good_char_pos - first_good_char_pos + 1;
|
||||||
|
if (stripped_len == orig_str_len) {
|
||||||
|
// If nothing was stripped, don't bother to dup original string
|
||||||
|
// TODO: watch out for this case when we'll get to bytearray.strip()
|
||||||
|
assert(first_good_char_pos == 0);
|
||||||
|
return args[0];
|
||||||
|
}
|
||||||
return mp_obj_new_str_of_type(self_type, orig_str + first_good_char_pos, stripped_len);
|
return mp_obj_new_str_of_type(self_type, orig_str + first_good_char_pos, stripped_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,3 +31,7 @@ print(" a".rstrip())
|
|||||||
print("a ".strip())
|
print("a ".strip())
|
||||||
print("a ".lstrip())
|
print("a ".lstrip())
|
||||||
print("a ".rstrip())
|
print("a ".rstrip())
|
||||||
|
|
||||||
|
# Test that stripping unstrippable string returns original object
|
||||||
|
s = "abc"
|
||||||
|
print(id(s.strip()) == id(s))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user