Changelog¶ ↑
3.7.0 / 2025-05-07¶ ↑
- 
Deprecated MIME::Type#priority_compare. In a future release, this will be will be renamed toMIME::Type#<=>. This method is used in tight loops, so there is no warning message for eitherMIME::Type#priority_compareorMIME::Type#<=>.
- 
Improved the performance of sorting by eliminating the complex comparison flow from MIME::Type#priority_compare. The old version shows under 600 i/s, and the new version shows over 900 i/s. In sorting the full set ofMIMEdata, there are three differences between the old and new versions; after comparison, these differences are considered acceptable.
- 
Simplified the default compare implementation ( MIME::Type#<=>) to use the newMIME::Type#priority_compareoperation and simplify the fallback toStringcomparison. This may result in exceptions where there had been none, as explicit support for several special values (which should have caused errors in any case) have been removed.
- 
When sorting the result of MIME::Types#type_for, provided a priority boost if one of the target extensions is the type's preferred extension. This means that for the case in #148, when getting the type forfoo.webm, the typevideo/webmwill be returned before the typeaudio/webm, because.webmis the preferred extension forvideo/webmbut notaudio/webm(which has a preferred extension of.weba). Added tests to ensureMIMEtypes are retrieved in a stable order (which is alphabetical).
3.6.2 / 2025-03-25¶ ↑
- 
Updated the reference to the changelog in the README, fixing RubyGems metadata on the next release. Fixed in #189 by nna774. 
- 
Daniel Watkins fixed an error in the repo tag for this release because the modified gemspec was not included in the release. Fixed in #196. 
3.6.1 / 2025-03-15¶ ↑
- 
Restructure project structure to be more consistent with mime-types-data. 
- 
Increased GitHub action security. Added Ruby 3.4, dropped macOS 12, added macOS 15. 
- 
Added trusted publishing for fully automated releases. 
- 
Added MIME::Types::NullLoggerto completely silenceMIME::Typeslogging.
- 
Improved the development experience with updates to the Gemfile. 
- 
Worked around various issues with the benchmarks and profiling code. 
- 
Removed Forwardable from MIME::Types::Container. 
- 
Added coverage support (back). 
3.6.0 / 2024-10-02¶ ↑
- 
2 deprecations: 
- 
Array-based MIME::Typeinitialization
- 
String-based MIME::Typeinitialization
Use of these these will result in deprecation warnings.
- 
Added loggerto the gemspec to suppress a bundled gem warning with Ruby 3.3.5. This warning should not be showing up until Ruby 3.4.0 is released and will be suppressed in Ruby 3.3.6.
- 
Reworked the deprecation message code to be somewhat more flexible and allow for outputting certain warnings once. Because there will be at least one other release after 3.6, we do not need to make the type initialization deprecations frequent with this release. 
3.5.2 / 2024-01-02¶ ↑
There are no primary code changes, but we are releasing this as an update as there are some validation changes and updated code with formatting.
- 
Dependency and CI updates: 
- 
Masato Nakamura added Ruby 3.3 to the CI workflow in #179. 
- 
Fixed regressions in standard formatting in #180. 
- 
Removed minitest-bonus-assertionsbecause of a bundler resolution issue. Created a better replacement in-line.
3.5.1 / 2023-08-21¶ ↑
- 
1 bug fix: 
- 
Better handle possible line-termination strings (legal in Unix filenames) such as \ninMIME::Types.type_for. Reported by ooooooo-q in #177, resolved in #178.
3.5.0 / 2023-08-07¶ ↑
- 
1 minor enhancement: 
- 
Robb Shecter changed the default log level for duplicate type variant from warntodebugin #170. This works becauseMIME::Types.loggeris intended to fit the::Loggerinterface, and the default logger (WarnLogger) is a subclass of::Loggerthat passes through toKernel.warn.- 
Further consideration has changed cache load messages from warntoerrorand deprecation messages fromwarntodebug.
 
- 
- 
1 bug fix: 
- 
Added a definition of MIME::Type#hash. Contributed by Alex Vondrak in #167, fixing #166.
- 
Dependency and CI updates: 
- 
Update the .github/workflows/ci.yml workflow to test Ruby 3.2 and more reliably test certain combinations rather than depending on exclusions. 
- 
Change .standard.ymlconfiguration to format for Ruby 2.3 as certain files are not properly detected with Ruby 2.0.- 
Change from hoe-gittohoe-git2to support Hoe version 4.
- 
Apply standardrb --fix.
- 
The above changes have resulted in the Soft deprecation of Ruby versions below 2.6. Any errors reported for Ruby versions 2.0, 2.1, 2.2, 2.3, 2.4, and 2.5 will be resolved, but maintaining CI for these versions is unsustainable. 
 
- 
3.4.1 / 2021-11-16¶ ↑
- 
1 bug fix: 
- 
Fixed a Ruby < 2.3 incompatibility introduced by the use of standardrb, where <<-heredocs were converted to<<~heredocs. These have been reverted back to<<-with the indentation kept and a.stripcall to prevent excess whitespace.
3.4.0 / 2021-11-15¶ ↑
- 
1 minor enhancement: 
- 
Added a new field to MIME::Typefor checking provisional registrations from IANA. [#157]
- 
Documentation: 
- 
Kevin Menard synced the documentation so that all examples are correct. [#153] 
- 
Administrivia: 
- 
Added Ruby 3.0 to the CI test matrix. Added windows/jrubyto the CI exclusion list; it refuses to run successfully.
- 
Removed the Travis CI configuration and changed it to Github Workflows #150. Removed Coveralls configuration. 
- 
Igor Victor added TruffleRuby to the Travis CI configuration. [#149] 
- 
Koichi ITO loosened an excessively tight dependency. [#147] 
- 
Started using standardrbfor Ruby formatting and validation.
- 
Moved deps:topfunctionality to a support file.
3.3.1 / 2019-12-26¶ ↑
- 
1 minor bug fix: 
- 
Al Snow fixed a warning with MIME::Types::Logger producing a warning because Ruby 2.7 introduces numbered block parameters. Because of the way that the MIME::Types::Logger works for deprecation messages, the initializer parameters had been named _1,_2, and_3. This has now been resolved. [#146]
- 
Administrivia: 
- 
Olle Jonsson removed an outdated Travis configuration option. #142 
3.3 / 2019-09-04¶ ↑
- 
1 minor enhancement: 
- 
Jean Boussier reduced memory usage for Ruby versions 2.3 or higher by interning various string values in each type. This is done with a backwards-compatible call that freezes the strings on older versions of Ruby. [#141] 
- 
Administrivia: 
- 
Nicholas La Roux updated Travis build configurations. [#139] 
3.2.2 / 2018-08-12¶ ↑
- 
Hiroto Fukui removed a stray debuggerstatement that I had used in producing v3.2.1. [#137]
3.2.1 / 2018-08-12¶ ↑
- 
A few bugs related to MIME::Types::Container and its use in the mime-types-data helper tools reared their head because I released 3.2 before verifying against mime-types-data. 
3.2 / 2018-08-12¶ ↑
- 
2 minor enhancements 
- 
Janko Marohnić contributed a change to MIME::Type#priority_orderthat should improve on strict sorting when dealing withMIMEtypes that appear to be in the same family even if strict sorting would cause an unregistered type to be sorted first. [#132]
- 
Dillon Welch contributed a change that added frozen_string_literal: trueto files so that modern Rubies can automatically reduce duplicate string allocations. [#135]
- 
2 bug fixes 
- 
Burke Libbey fixed a problem with cached data loading. [#126] 
- 
Resolved an issue where Enumerable#inject returns nilwhen provided an empty enumerable and a default value has not been provided. This is because when Enumerable#inject isn't provided a starting value, the first value is used as the default value. In every case where this error was happening, the result was supposed to be an array containing Set objects so they can be reduced to a single Set. #117, #127, #134
- 
Fixed an uncontrolled growth bug in MIME::Types::Container where a key miss would create a new entry with an empty Set in the container. This was working as designed (this particular feature was heavily used during MIME::Typeregistry construction), but the design was flawed in that it did not have any way of determining the difference between construction and querying. This would mean that, if you have a function in your web app that queries theMIME::Typesregistry by extension, the extension registry would grow uncontrollably. [#136]
- 
Deprecations: 
- 
Lazy loading ( $RUBY_MIME_TYPES_LAZY_LOAD) has been deprecated.
- 
Documentation Changes: 
- 
Supporting files are now Markdown instead of rdoc, except for the README. 
- 
The history file has been modified to remove all history prior to 3.0. This history can be found in previous commits. 
- 
A spelling error was corrected by Edward Betts (#129). 
- 
Administrivia: 
- 
CI configuration for more modern versions of Ruby were added by Nicolas Leger (#130), Jun Aruga (#125), and Austin Ziegler. Removed ruby-head-clang and rbx (Rubinius) from CI. 
- 
Fixed tests which were asserting equality against nil, which will become an error in Minitest 6. 
3.1 / 2016-05-22¶ ↑
- 
1 documentation change: 
- 
Tim Smith (@tas50) updated the build badges to be SVGs to improve readability on high-density (retina) screens with pull request #112. 
- 
3 bug fixes 
- 
A test for MIME::Types::Cachefails under Ruby 2.3 because of frozen strings, #118. This has been fixed.
- 
The JSON data has been incorrectly encoded since the release of mime-types 3 on the xrefsfield, because of the switch to using a Set to store cross-reference information. This has been fixed.
- 
A tentative fix for #117 has been applied, removing the only circular require dependencies that exist (and for which there was code to prevent, but the current fix is simpler). I have no way to verify this fix and depending on how things are loaded by delayed_job, this fix may not be sufficient.
- 
1 governance change 
- 
Updated to Contributor Covenant 1.4. 
3.0 / 2015-11-21¶ ↑
- 
2 governance changes 
- 
This project and the related mime-types-data project are now exclusively MIT licensed. Resolves #95. 
- 
All projects under the mime-types organization now have a standard code of conduct adapted from the Contributor Covenant. This text can be found in the Code of Conduct file. 
- 
3 major changes 
- 
All methods deprecated in mime-types 2.x have been removed. 
- 
mime-types now requires Ruby 2.0 compatibility or later. Resolves #97. 
- 
The registry data has been removed from mime-types and put into mime-types-data, maintained and released separately. It can be found at mime-types-data. 
- 
17 minor changes: 
- 
MIME::Typechanges:- 
Changed the way that simplified types representations are created to reflect the fact that x-prefixes are no longer considered special according to IANA. A simplifiedMIMEtype is case-folded to lowercase. A new keyword parameter,remove_x_prefix, can be provided to removex-prefixes.
- 
Improved initialization with an Array works so that extensions do not need to be wrapped in another array. This means that %w(text/yaml yaml yml)works in the same way that['text/yaml', %w(yaml yml)]did (and still does).
- 
Changed priority_compareto conform with attributes that no longer exist.
- 
Changed the internal implementation of extensions to use a frozen Set. 
- 
When extensions are set or modified with add_extensions, the primary registry will be informed of a need to re-index extensions. Resolves #84.
- 
The preferred extension can be set explicitly. If not set, it will be the first extension. If the preferred extension is not in the extension list, it will be added. 
- 
Improved how xref URLs are generated. 
- 
Converted obsolete,registeredandsignaturetoattr_accessors.
 
- 
- 
MIME::Typeschanges:- 
Modified MIME::Types.newto track instances ofMIME::Typesso that they can be told to reindex the extensions as necessary.
- 
Removed data_versionattribute.
- 
Changed [] so that the completeandregisteredflags are keywords instead of a generic options parameter.
- 
Extracted the class methods to a separate file. 
- 
Changed the container implementation to use a Set instead of an Array to prevent data duplication. Resolves #79. 
 
- 
- 
MIME::Types::Cachechanges:- 
Caching is now based on the data gem version instead of the mime-types version. 
- 
Caching is compatible with columnar registry stores. 
 
- 
- 
MIME::Types::Loaderchanges:- 
MIME::Types::Loader::PATHhas been removed and replaced withMIME::Types::Data::PATHfrom the mime-types-data gem. The environment variableRUBY_MIME_TYPES_DATAis still used.
- 
Support for the long-deprecated mime-types v1 format has been removed. 
- 
The registry is default loaded from the columnar store by default. The internal format of the columnar store has changed; many of the boolean flags are now loaded from a single file. Resolves #85. 
 
-