EventSourceIOEventSupport

module Support

Helper methods for detecting support for various features.

Definitions

def self.buffer?

Some features are only availble if the IO::Buffer class is available.

Signature

returns Boolean

Whether the IO::Buffer class is available.

Implementation

def self.buffer?
	IO.const_defined?(:Buffer)
end

def self.fiber_scheduler_v1?

The basic fiber scheduler was introduced along side the IO::Buffer class.

To be removed on 31 Mar 2025.

Signature

returns Boolean

Whether the IO::Buffer class is available.

Implementation

def self.fiber_scheduler_v1?
	IO.const_defined?(:Buffer)
end

def self.fiber_scheduler_v2?

More advanced read/write methods and blocking controls were introduced in Ruby 3.2.

To be removed on 31 Mar 2026.

Implementation

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

def self.fiber_scheduler_v3?

Updated inferfaces for read/write and IO::Buffer were introduced in Ruby 3.3, including pread/pwrite.

To become the default 31 Mar 2026.

Implementation

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