From 1c8e13c7cd6b187c564afe8a05cadf51d8880fe1 Mon Sep 17 00:00:00 2001 From: Jean Boussier Date: Wed, 3 Apr 2019 11:50:50 +0200 Subject: [PATCH] Intern content type strings --- lib/mime/type.rb | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/lib/mime/type.rb b/lib/mime/type.rb index 5a05a91..552a888 100644 --- a/lib/mime/type.rb +++ b/lib/mime/type.rb @@ -537,11 +537,28 @@ def content_type=(type_string) match = MEDIA_TYPE_RE.match(type_string) fail InvalidContentType, type_string if match.nil? - @content_type = type_string + @content_type = intern_string(type_string) @raw_media_type, @raw_sub_type = match.captures - @simplified = MIME::Type.simplified(match) - @i18n_key = MIME::Type.i18n_key(match) + @simplified = intern_string(MIME::Type.simplified(match)) + @i18n_key = intern_string(MIME::Type.i18n_key(match)) @media_type, @sub_type = MEDIA_TYPE_RE.match(@simplified).captures + + @raw_media_type = intern_string(@raw_media_type) + @raw_sub_type = intern_string(@raw_sub_type) + @media_type = intern_string(@media_type) + @sub_type = intern_string(@sub_type) + end + + if String.method_defined?(:-@) + def intern_string(string) + -string + end + else + # MRI 2.2 and older don't have a method for string interning, + # so we simply freeze them for keeping a similar interface + def intern_string(string) + string.freeze + end end def xref_map(values, helper)