summaryrefslogtreecommitdiff
path: root/include/ruby/internal/encoding/sprintf.h
diff options
context:
space:
mode:
authorJean Boussier <jean.boussier@gmail.com>2025-02-24 11:39:00 +0100
committerJean Boussier <jean.boussier@gmail.com>2025-02-24 18:32:46 +0100
commit87f9c3c65e38fa3e5c6ef097e2cf63ff448f48d6 (patch)
tree511d0e2492dad3ec4f140ee4728abe4d8fa4c45c /include/ruby/internal/encoding/sprintf.h
parent21ac0a3a640a2a86e8716675f82221f178e29088 (diff)
String#gsub! Elide MatchData allocation when we know it can't escape
In gsub is used with a string replacement or a map that doesn't have a default proc, we know for sure no code can cause the MatchData to escape the `gsub` call. In such case, we still have to allocate a new MatchData because we don't know what is the lifetime of the backref, but for any subsequent match we can re-use the MatchData we allocated ourselves, reducing allocations significantly. This partially fixes [Misc #20652], except when a block is used, and partially reduce the performance impact of abc0304cb28cb9dcc3476993bc487884c139fd11 / [Bug #17507] ``` compare-ruby: ruby 3.5.0dev (2025-02-24T09:44:57Z master 5cf146399f) +PRISM [arm64-darwin24] built-ruby: ruby 3.5.0dev (2025-02-24T10:58:27Z gsub-elude-match da966636e9) +PRISM [arm64-darwin24] warming up.... | |compare-ruby|built-ruby| |:----------------|-----------:|---------:| |escape | 3.577k| 3.697k| | | -| 1.03x| |escape_bin | 5.869k| 6.743k| | | -| 1.15x| |escape_utf8 | 3.448k| 3.738k| | | -| 1.08x| |escape_utf8_bin | 6.361k| 7.267k| | | -| 1.14x| ``` Co-Authored-By: Étienne Barrié <etienne.barrie@gmail.com>
Diffstat (limited to 'include/ruby/internal/encoding/sprintf.h')
0 files changed, 0 insertions, 0 deletions