"title"=>"Ruby 3.3.0 Released",
"summary"=>"\n
We are pleased to announce the release of Ruby 3.3.0. Ruby 3.3 adds a new parser named Prism, uses Lrama as a parser generator, adds a new pure-Ruby JIT compiler named RJIT, and many performance improvements especially YJIT.
\n\nPrism
\n\n- \n
- Introduced the Prism parser as a default gem\n
- \n
- Prism is a portable, error tolerant, and maintainable recursive descent parser for the Ruby language \n
\n - Prism is production ready and actively maintained, you can use it in place of Ripper\n
- \n
- There is extensive documentation on how to use Prism \n
- Prism is both a C library that will be used internally by CRuby and a Ruby gem that can be used by any tooling which needs to parse Ruby code \n
- Notable methods in the Prism API are:\n
- \n
Prism.parse(source)
which returns the AST as part of a parse result object \n Prism.parse_comments(source)
which returns the comments \n Prism.parse_success?(source)
which returns true if there are no errors \n
\n
\n - You can make pull requests or issues directly on the Prism repository if you are interested in contributing \n
- You can now use
ruby --parser=prism
orRUBYOPT=\"--parser=prism\"
to experiment with the Prism compiler. Please note that this flag is for debugging only. \n
Use Lrama instead of Bison
\n\n- \n
- Replace Bison with Lrama LALR parser generator [Feature #19637]\n
- \n
- If you have interest, please see The future vision of Ruby Parser \n
- Lrama internal parser is replaced with LR parser generated by Racc for maintainability \n
- Parameterizing Rules
(?, *, +)
are supported, it will be used in Ruby parse.y \n
\n
YJIT
\n\n- \n
- Major performance improvements over Ruby 3.2\n
- \n
- Support for splat and rest arguments has been improved. \n
- Registers are allocated for stack operations of the virtual machine. \n
- More calls with optional arguments are compiled. Exception handlers are also compiled. \n
- Unsupported call types and megamorphic call sites no longer exit to the interpreter. \n
- Basic methods like Rails
#blank?
and\nspecialized#present?
are inlined. \n Integer#*
,Integer#!=
,String#!=
,String#getbyte
,\nKernel#block_given?
,Kernel#is_a?
,Kernel#instance_of?
, andModule#===
\nare specially optimized. \n - Compilation speed is now slightly faster than Ruby 3.2. \n
- Now more than 3x faster than the interpreter on Optcarrot! \n
\n - Significantly improved memory usage over Ruby 3.2\n
- \n
- Metadata for compiled code uses a lot less memory. \n
--yjit-call-threshold
is automatically raised from 30 to 120\nwhen the application has more than 40,000 ISEQs. \n --yjit-cold-threshold
is added to skip compiling cold ISEQs. \n - More compact code is generated on Arm64. \n
\n - Code GC is now disabled by default\n
- \n
--yjit-exec-mem-size
is treated as a hard limit where compilation of new code stops. \n - No sudden drops in performance due to code GC.\nBetter copy-on-write behavior on servers reforking with\nPitchfork. \n
- You can still enable code GC if desired with
--yjit-code-gc
\n
\n - Add
RubyVM::YJIT.enable
that can enable YJIT at run-time\n- \n
- You can start YJIT without modifying command-line arguments or environment variables.\nRails 7.2 will enable YJIT by default\nusing this method. \n
- This can also be used to enable YJIT only once your application is\ndone booting.
--yjit-disable
can be used if you want to use other\nYJIT options while disabling YJIT at boot. \n
\n - More YJIT stats are available by default\n
- \n
yjit_alloc_size
and several more metadata-related stats are now available by default. \n ratio_in_yjit
stat produced by--yjit-stats
is now available in release builds,\na special stats or dev build is no longer required to access most stats. \n
\n - Add more profiling capabilities\n
- \n
--yjit-perf
is added to facilitate profiling with Linux perf. \n --yjit-trace-exits
now supports sampling with--yjit-trace-exits-sample-rate=N
\n
\n - More thorough testing and multiple bug fixes \n
RJIT
\n\n- \n
- Introduced a pure-Ruby JIT compiler RJIT and replaced MJIT.\n
- \n
- RJIT supports only x86-64 architecture on Unix platforms. \n
- Unlike MJIT, it doesn’t require a C compiler at runtime. \n
\n - RJIT exists only for experimental purposes.\n
- \n
- You should keep using YJIT in production. \n
\n - If you are interested in developing JIT for Ruby, please check out k0kubun’s presentation on Day 3 of RubyKaigi. \n
M:N thread scheduler
\n\n- \n
- M:N thread scheduler was introduced. [Feature #19842]\n
- \n
- M Ruby threads are managed by N native threads (OS threads) so the thread creation and management cost are reduced. \n
- It can break C-extension compatibility so that M:N thread scheduler is disabled on the main Ractor by default.\n
- \n
RUBY_MN_THREADS=1
environment variable enables M:N threads on the main Ractor. \n - M:N threads are always enabled on non-main Ractors. \n
\n RUBY_MAX_CPU=n
environment variable sets maximum number ofN
(maximum number of native threads). The default value is 8.\n- \n
- Since only one Ruby thread per Ractor can run at the same time, the number of native threads will be used, which is the smaller of the number specified in
RUBY_MAX_CPU
and the number of running Ractors. So that single Ractor applications (most of applications) will only use 1 native thread. \n - To support blocking operations, more than
N
native threads can be used. \n
\n - Since only one Ruby thread per Ractor can run at the same time, the number of native threads will be used, which is the smaller of the number specified in
\n
Performance improvements
\n\n- \n
defined?(@ivar)
is optimized with Object Shapes. \n - Name resolution such as
Socket.getaddrinfo
can now be interrupted (in environments where pthreads are available). [Feature #19965] \n - Several performance improvements to the Garbage Collector\n
- \n
- Young objects referenced by old objects are no longer immediately\n promoted to the old generation. This significantly reduces the frequency of\n major GC collections. [Feature #19678] \n
- A new
REMEMBERED_WB_UNPROTECTED_OBJECTS_LIMIT_RATIO
tuning variable was\n introduced to control the number of unprotected objects cause a major GC\n collection to trigger. The default is set to0.01
(1%). This significantly\n reduces the frequency of major GC collection. [Feature #19571] \n - Write Barriers were implemented for many core types that were missing them,\n notably
Time
,Enumerator
,MatchData
,Method
,File::Stat
,BigDecimal
\n and several others. This significantly reduces minor GC collection time and major\n GC collection frequency. \n - Most core classes are now using Variable Width Allocation, notably
Hash
,Time
,\nThread::Backtrace
,Thread::Backtrace::Location
,File::Stat
,Method
.\n This makes these classes faster to allocate and free, use less memory and reduce\n heap fragmentation. \n - Support for weak references has been added to the garbage collector. [Feature #19783] \n
\n
Other notable changes since 3.2
\n\nIRB
\n\nIRB has received several enhancements, including but not limited to:
\n\n- \n
- Advanced
irb:rdbg
integration that provides an equivalent debugging experience topry-byebug
(doc). \n - Pager support for
ls
,show_source
andshow_cmds
commands. \n - More accurate and helpful information provided by the
ls
andshow_source
commands. \n - Experimental autocompletion using type analysis (doc). \n
- It is now possible to change the font color and font style in the completion dialog by a newly introduced class Reline::Face (doc) \n
In addition, IRB has also undergone extensive refactoring and received dozens of bug fixes to facilitate easier future enhancements.
\n\nFor more detailed updates, please refer to Unveiling the big leap in Ruby 3.3’s IRB.
\n\nCompatibility issues
\n\nNote: Excluding feature bug fixes.
\n\n- \n
it
calls without arguments in a block with no ordinary parameters are\ndeprecated.it
will be a reference to the first block parameter in Ruby 3.4.\n[Feature #18980] \n
Removed environment variables
\n\nThe following deprecated methods are removed.
\n\n- \n
- Environment variable
RUBY_GC_HEAP_INIT_SLOTS
has been deprecated and is a no-op. Please use environment variablesRUBY_GC_HEAP_{0,1,2,3,4}_INIT_SLOTS
instead. [Feature #19785] \n
Stdlib compatibility issues
\n\next/readline
is retired
\n\n- \n
- We have
reline
that is pure Ruby implementation compatible withext/readline
API. We rely onreline
in the future. If you need to useext/readline
, you can installext/readline
via rubygems.org withgem install readline-ext
. \n - We no longer need to install libraries like
libreadline
orlibedit
. \n
Standard library updates
\n\nRubyGems and Bundler warn if users do require
the following gems without adding them to Gemfile or gemspec. This is because they will become the bundled gems in the future version of Ruby.
This warning is suppressed if you use bootsnap gem. We recommend to run your application with DISABLE_BOOTSNAP=1
environment variable at least once. This is limitation of this version.
Targeted libraries are:
\n- \n
- abbrev \n
- base64 \n
- bigdecimal \n
- csv \n
- drb \n
- getoptlong \n
- mutex_m \n
- nkf \n
- observer \n
- racc \n
- resolv-replace \n
- rinda \n
- syslog \n
The following default gem is added.
\n\n- \n
- prism 0.19.0 \n
The following default gems are updated.
\n\n- \n
- RubyGems 3.5.3 \n
- abbrev 0.1.2 \n
- base64 0.2.0 \n
- benchmark 0.3.0 \n
- bigdecimal 3.1.5 \n
- bundler 2.5.3 \n
- cgi 0.4.1 \n
- csv 3.2.8 \n
- date 3.3.4 \n
- delegate 0.3.1 \n
- drb 2.2.0 \n
- english 0.8.0 \n
- erb 4.0.3 \n
- error_highlight 0.6.0 \n
- etc 1.4.3 \n
- fcntl 1.1.0 \n
- fiddle 1.1.2 \n
- fileutils 1.7.2 \n
- find 0.2.0 \n
- getoptlong 0.2.1 \n
- io-console 0.7.1 \n
- io-nonblock 0.3.0 \n
- io-wait 0.3.1 \n
- ipaddr 1.2.6 \n
- irb 1.11.0 \n
- json 2.7.1 \n
- logger 1.6.0 \n
- mutex_m 0.2.0 \n
- net-http 0.4.0 \n
- net-protocol 0.2.2 \n
- nkf 0.1.3 \n
- observer 0.1.2 \n
- open-uri 0.4.1 \n
- open3 0.2.1 \n
- openssl 3.2.0 \n
- optparse 0.4.0 \n
- ostruct 0.6.0 \n
- pathname 0.3.0 \n
- pp 0.5.0 \n
- prettyprint 0.2.0 \n
- pstore 0.1.3 \n
- psych 5.1.2 \n
- rdoc 6.6.2 \n
- readline 0.0.4 \n
- reline 0.4.1 \n
- resolv 0.3.0 \n
- rinda 0.2.0 \n
- securerandom 0.3.1 \n
- set 1.1.0 \n
- shellwords 0.2.0 \n
- singleton 0.2.0 \n
- stringio 3.1.0 \n
- strscan 3.0.7 \n
- syntax_suggest 2.0.0 \n
- syslog 0.1.2 \n
- tempfile 0.2.1 \n
- time 0.3.0 \n
- timeout 0.4.1 \n
- tmpdir 0.2.0 \n
- tsort 0.2.0 \n
- un 0.3.0 \n
- uri 0.13.0 \n
- weakref 0.1.3 \n
- win32ole 1.8.10 \n
- yaml 0.3.0 \n
- zlib 3.1.0 \n
The following bundled gem is promoted from default gems.
\n\n- \n
- racc 1.7.3 \n
The following bundled gems are updated.
\n\n- \n
- minitest 5.20.0 \n
- rake 13.1.0 \n
- test-unit 3.6.1 \n
- rexml 3.2.6 \n
- rss 0.3.0 \n
- net-ftp 0.3.3 \n
- net-imap 0.4.9 \n
- net-smtp 0.4.0 \n
- rbs 3.4.0 \n
- typeprof 0.21.9 \n
- debug 1.9.1 \n
See GitHub releases like Logger or\nchangelog for details of the default gems or bundled gems.
\n\nSee NEWS\nor commit logs\nfor more details.
\n\nWith those changes, 5532 files changed, 326851 insertions(+), 185793 deletions(-)\nsince Ruby 3.2.0!
\n\nMerry Christmas, Happy Holidays, and enjoy programming with Ruby 3.3!
\n\nDownload
\n\n- \n
- \n
https://cache.ruby-lang.org/pub/ruby/3.3/ruby-3.3.0.tar.gz
\n\n\nSIZE: 22065999\nSHA1: 1a7e56851bf29bda1183aca99b3b323c58e0187b\nSHA256: 96518814d9832bece92a85415a819d4893b307db5921ae1f0f751a9a89a56b7d\nSHA512: 26074009b501fc793d71a74e419f34a6033c9353433919ca74ba2d24a3de432dbb11fd92c2bc285f0e4d951a6d6c74bf5b69a2ab36200c8c26e871746d6e0fc6\n
\n - \n
https://cache.ruby-lang.org/pub/ruby/3.3/ruby-3.3.0.tar.xz
\n\n\nSIZE: 16345456\nSHA1: c8f68e1b0a114b90460a0b44165a3b2f540fa5b6\nSHA256: 676b65a36e637e90f982b57b059189b3276b9045034dcd186a7e9078847b975b\nSHA512: 7959c5753bfa0bfc4d6d74060869aabbe9815c1c97930659da11b917ee0803ddbbd80e869e00c48b8694b4ba48709c3b6493fd045568e36e902616c35ababf01\n
\n - \n
https://cache.ruby-lang.org/pub/ruby/3.3/ruby-3.3.0.zip
\n\n\nSIZE: 26935108\nSHA1: a433eef1d7f96daeaf3b4cb842d0ed2dd82e7dc1\nSHA256: 0e6563f679dd3694732eb3addf9de681c67b584602ac574376b60e7a509d2cd8\nSHA512: a94a85937a14b217c1f4b90d24185289ed4aee79239c4f3eecf8034d3fd34e65ee8d66869473857ed153067188adc9b70c0471e4ebe842c9f98ef60c34090450\n
\n
What is Ruby
\n\nRuby was first developed by Matz (Yukihiro Matsumoto) in 1993,\nand is now developed as Open Source. It runs on multiple platforms\nand is used all over the world especially for web development.
\n\nPosted by naruse on 25 Dec 2023
","content"=>nil,
"author"=>nil,
"link"=>"https://www.ruby-lang.org/en/news/2023/12/25/ruby-3-3-0-released/",
"published_date"=>Mon, 25 Dec 2023 00:00:00.000000000 UTC +00:00,
"image_url"=>nil,
"feed_url"=>"https://www.ruby-lang.org/en/news/2023/12/25/ruby-3-3-0-released/",
"language"=>nil,
"active"=>true,
"ricc_source"=>"feedjira::v1",
"created_at"=>Wed, 03 Apr 2024 14:31:18.942923000 UTC +00:00,
"updated_at"=>Mon, 13 May 2024 19:03:15.489927000 UTC +00:00,
"newspaper"=>"Ruby (EN RSS)",
"macro_region"=>"Technology"}