class Async::HTTP::Protocol::HTTP2::Server

def accept_stream(stream_id)

def accept_stream(stream_id)
	super do
		Request::Stream.create(self, stream_id)
	end
end

def close(error = nil)

def close(error = nil)
	if @requests
		# Stop the request loop:
		@requests.enqueue(nil)
		@requests = nil
	end
	
	super
end

def each(task: Task.current)

def each(task: Task.current)
	task.annotate("#{version} reading requests for #{self.class}.")
	
	# It's possible the connection has died before we get here...
	@requests&.async do |task, request|
		task.annotate("Incoming request: #{request.method} #{request.path.inspect}.")
		
		@count += 1
		
		begin
			response = yield(request)
		rescue
			# We need to close the stream if the user code blows up while generating a response:
			request.stream.send_reset_stream(::Protocol::HTTP2::INTERNAL_ERROR)
			
			raise
		else
			request.send_response(response)
		end
	end
	
	# Maybe we should add some synchronisation here - i.e. only exit once all requests are finished.
end

def initialize(stream)

def initialize(stream)
	# Used by some generic methods in Connetion:
	@stream = stream
	
	framer = ::Protocol::HTTP2::Framer.new(stream)
	
	super(framer)
	
	@requests = Async::Queue.new
end