class Bootsnap::CLI::WorkerPool::Worker
def close
def close to_io.close end
def initialize(jobs)
def initialize(jobs) @jobs = jobs @pipe_out, @to_io = IO.pipe @pid = nil end
def spawn
def spawn @pid = Process.fork do to_io.close work_loop exit!(0) end @pipe_out.close true end
def work_loop
def work_loop loop do job, *args = Marshal.load(@pipe_out) return if job == :exit @jobs.fetch(job).call(*args) end rescue IOError nil end
def write(message, block: true)
def write(message, block: true) payload = Marshal.dump(message) if block to_io.write(payload) true else to_io.write_nonblock(payload, exception: false) != :wait_writable end end