[issue47070] Improve performance of array_inplace_repeat
Dennis Sweeney
report at bugs.python.org
Sat Mar 19 19:09:13 EDT 2022
Dennis Sweeney <sweeney.dennis650 at gmail.com> added the comment:
I'd bet we could add a couple of utility functions that could be used in multiple places, to keep the "trick" all in one place. Something like
void
_PyBytes_RepeatInPlace(char **buffer, size_t start_len, size_t end_len)
{
// Repeatedly double.
size_t copied = start_len;
while (copied < end_len) {
size_t to_copy = Py_MIN(copied, end_len - copied);
memcpy(buffer + copied, buffer, to_copy);
copied += to_copy;
}
}
void
_PyBytes_Repeat(char *dest, size_t len_dest,
const char *src, size_t len_src)
{
// XXX maybe handle zero lengths
// XXX maybe use memset for len_src == 1
memcpy(dest, src, len_src);
_PyBytes_RepeatInPlace(dest, len_src, len_dest);
}
----------
nosy: +Dennis Sweeney
_______________________________________
Python tracker <report at bugs.python.org>
<https://bugs.python.org/issue47070>
_______________________________________
More information about the Python-bugs-list
mailing list