Feature #17219
closedMake URI#hostname 86-89% and hostname= 55-154% faster
Description
Hello,
URI#hostname extends URI#host with IPv6 support. In URI, IPv6 address must have square brackets (e.g. http://[2001:db8::1]
), URI#hostname strips these characters out while URI#hostname= adds them if missing. There are three regular expressions to perform these tasks which can dramatically slow down performance. I am attaching a two-line patch and here is a benchmark: https://gist.github.com/lzap/24cbecb47daf29111350e41a24250922
Results are in the gist. A patch and a PR incoming.
Files
Updated by lzap (Lukas Zapletal) about 4 years ago
- File 3635.patch 3635.patch added
Attaching patch. Also available as https://github.com/ruby/ruby/pull/3635
Updated by lzap (Lukas Zapletal) about 4 years ago
There is a nil exception in the test suite with the initial patch. Also @nobu (Nobuyoshi Nakada) on Github pointed out that start_with? and end_with? might be faster which is indeed the case. I will update the patch shortly.
Updated by lzap (Lukas Zapletal) about 4 years ago
- Subject changed from Make URI#hostname 18-20% and hostname= 31-156% faster to Make URI#hostname 86-89% and hostname= 55-154% faster
- Description updated (diff)
So I learned that URI is a separate rubygem, therefore I filed PR against https://github.com/ruby/uri/pull/12 and this RM issue is no longer necessary I guess. Please close.
Updated by jeremyevans0 (Jeremy Evans) almost 4 years ago
- Status changed from Open to Closed