Sha256: fe22125946069fd0d9a72c59b6ea6865c80c60d3f7012c3ac40e05db8ceb2b38

Contents?: true

Size: 1.52 KB

Versions: 4

Compression:

Stored size: 1.52 KB

Contents

# -*- encoding: binary -*-
# Copyright (C) 2009-2013, Eric Wong <normalperson@yhbt.net> et. al.
# License: GPLv3 or later (https://www.gnu.org/licenses/gpl-3.0.txt)
if ENV["SENDFILE_BROKEN"]
  require_relative 'sendfile_compat'
else
  require 'sendfile'
end

module Yahns::WbufCommon # :nodoc:
  # returns nil on success, :wait_*able when blocked
  # currently, we rely on each thread having exclusive access to the
  # client socket, so this is never called concurrently with wbuf_write
  def wbuf_flush(client)
    case rv = client.trysendfile(@tmpio, @sf_offset, @sf_count)
    when Integer
      return wbuf_close(client) if (@sf_count -= rv) == 0 # all sent!

      @sf_offset += rv # keep going otherwise
    when :wait_writable, :wait_readable
      return rv
    when nil
      # response got truncated, drop the connection
      # this may happens when using Rack::File or similar, we can't
      # keep the connection alive because we already sent our Content-Length
      # header the client would be confused.
      @wbuf_persist = false
      return wbuf_close(client)
    else
      raise "BUG: rv=#{rv.inspect} " \
            "on tmpio=#{@tmpio.inspect} " \
            "sf_offset=#@sf_offset sf_count=#@sf_count"
    end while @sf_count > 0
    wbuf_close(client)
  end

  def wbuf_close_common(client)
    @body.close if @body.respond_to?(:close)
    if @wbuf_persist.respond_to?(:call) # hijack
      client.response_hijacked(@wbuf_persist) # :ignore
    else
      @wbuf_persist # true or false or Yahns::StreamFile
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
yahns-1.4.0 lib/yahns/wbuf_common.rb
yahns-1.3.1 lib/yahns/wbuf_common.rb
yahns-1.3.0 lib/yahns/wbuf_common.rb
yahns-1.2.0 lib/yahns/wbuf_common.rb