lib/io/event/support.rb
# frozen_string_literal: true # Released under the MIT License. # Copyright, 2022-2024, by Samuel Williams. class IO module Event # Helper methods for detecting support for various features. module Support # Some features are only availble if the IO::Buffer class is available. # # @returns [Boolean] Whether the IO::Buffer class is available. def self.buffer? IO.const_defined?(:Buffer) end # The basic fiber scheduler was introduced along side the IO::Buffer class. # # @returns [Boolean] Whether the IO::Buffer class is available. # # To be removed on 31 Mar 2025. def self.fiber_scheduler_v1? IO.const_defined?(:Buffer) end # More advanced read/write methods and blocking controls were introduced in Ruby 3.2. # # To be removed on 31 Mar 2026. def self.fiber_scheduler_v2? # Some interface changes were back-ported incorrectly: # https://github.com/ruby/ruby/pull/10778 # Specifically "Improvements to IO::Buffer read/write/pread/pwrite." # Missing correct size calculation. return false if RUBY_VERSION >= "3.2.5" IO.const_defined?(:Buffer) and Fiber.respond_to?(:blocking) and IO::Buffer.instance_method(:read).arity == -1 end # Updated inferfaces for read/write and IO::Buffer were introduced in Ruby 3.3, including pread/pwrite. # # To become the default 31 Mar 2026. def self.fiber_scheduler_v3? if fiber_scheduler_v2? return true if RUBY_VERSION >= "3.3" # Feature detection if required: begin IO::Buffer.new.slice(0, 0).write(STDOUT) return true rescue return false end end end end end end