# Changelog All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). ## [1.6.0] - 2022-02-16 ### Added - `::of` now supports both `String` and `Regexp` arguments ### Fixed - fixed segfault during `String` manipulation on Ruby 3.2.0-dev - improved performance for `String` manipulation - allow usage in Ractors - predefined sets must be pre-initialized for this, though - e.g. `CharacterSet.ascii`, `keep_character_set(:ascii)` etc. - call them once in the main Ractor to trigger initialization ## [1.5.0] - 2021-12-05 ### Added - new codepoints for `::assigned` and `::emoji` predefined sets, as in Ruby 3.1.0 - latest unicode case-folding data (for `#case_insensitive`) - support for passing any Enumerable to `#disjoint?`, `#intersect?` - this matches recent broadening of these methods in `ruby/set` - new instance method `#secure_token` (see README) - class method `::of` now accepts more than one `String` - `CharacterSet::ExpressionConverter` can now build output of any Set-like class ### Fixed - `CharacterSet::Pure::of_expression` now returns a `CharacterSet::Pure` - it used to return a regular `CharacterSet` ## [1.4.1] - 2020-01-10 ### Fixed - multiple fixes for Ruby 3 - fixed segfault for some `String` manipulation cases - added `sorted_set` as dependency, so `CharacterSet::Pure` (non-C fallback) works - fixed error when parsing a `Regexp` with an empty intersection (e.g. `/[a&&]/`) ## [1.4.0] - 2019-06-07 ### Added - `#to_s_with_surrogate_ranges` / `Writer::write_surrogate_ranges` - allows for much shorter astral plane representations e.g. in JavaScript - thanks to https://github.com/singpolyma for the suggestion and groundwork (#1) - improved performance for `#to_s` / `Writer` by avoiding bugged `Range#minmax` ### Fixed - '/' is now escaped by default when stringifying so as to work with //-regexp syntax ## [1.3.0] - 2019-04-26 ### Added - improved `String` manipulation speed - improved initialization and `#merge` speed when passing a large `Range` - reduced memory consumption by > 90% for most use cases via dynamic resizing - before, every set instance required 136 KB for codepoints - now, 16 bytes for a CharacterSet in ASCII space, 8 KB for one in BMP space etc. - `#count_in` and `#scan_in` methods for `String` interaction - new predefined sets `::any`/`::all`, `::assigned`, `::surrogate` - conversion methods `#assigned_part`, `#valid_part` - sectioning methods `#ascii_part`, `#plane(n)` - section test methods `#ascii_part?`, `#ascii_ratio`, `#ascii_only?`, `#astral_only?` ### Fixed - `#count` now supports passing an argument or block as usual - `CharacterSet::Pure#keep_in`, `#delete_in` now preserve the original encoding ## [1.2.0] - 2019-04-02 ### Added - added latest Unicode casefold data (for `#case_insensitive`) ## [1.1.2] - 2018-09-25 ### Fixed - restored `range_compressor` as a runtime dependency for JRuby only ## [1.1.1] - 2018-09-24 ### Fixed - improved messages for missing optional dependencies - made `range_compressor` an optional dependency as it is almost never needed ## [1.1.0] - 2018-09-21 ### Added - added option to reference a predefined set via Symbol in `String` extension methods - added predefined sets `::ascii_alnum` and `::ascii_letters` ## [1.0.0] - 2018-09-02 Initial release.