class Protocol::Rack::Response

def self.wrap(env, status, headers, meta, body, request = nil)

@parameter request [Protocol::HTTP::Request] The original request.
@parameter body [Duck(:each, :close) | Nil] The rack response body.
@parameter headers [Duck(:each)] The rack response headers.
@parameter status [Integer] The rack response status.
Wrap a rack response.
def self.wrap(env, status, headers, meta, body, request = nil)
	ignored = headers.extract(HOP_HEADERS)
	
	unless ignored.empty?
		Console.logger.warn(self, "Ignoring protocol-level headers: #{ignored.inspect}")
	end
	if hijack_body = meta['rack.hijack']
		body = hijack_body
	end
	body = Body.wrap(env, status, headers, body, request&.body)
	if request&.head?
		# I thought about doing this in Output.wrap, but decided the semantics are too tricky. Specifically, the various ways a rack response body can be wrapped, and the need to invoke #close at the right point.
		body = ::Protocol::HTTP::Body::Head.for(body)
	end
	
	protocol = meta[RACK_PROTOCOL]
	
	# https://tools.ietf.org/html/rfc7231#section-7.4.2
	# headers.add('server', "falcon/#{Falcon::VERSION}")
	
	# https://tools.ietf.org/html/rfc7231#section-7.1.1.2
	# headers.add('date', Time.now.httpdate)
	
	return self.new(status, headers, body, protocol)
end