class HTTParty::Response

def self._load(data)

def self._load(data)
  req, resp, parsed_resp, resp_body = Marshal.load(data)
  new(req, resp, -> { parsed_resp }, body: resp_body)
end

def self.underscore(string)

def self.underscore(string)
  string.gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2').gsub(/([a-z])([A-Z])/, '\1_\2').downcase
end

def _dump(_level)

def _dump(_level)
  Marshal.dump([request, response, parsed_response, body])
end

def code

def code
  response.code.to_i
end

def display(port=$>)

def display(port=$>)
  if !parsed_response.nil? && parsed_response.respond_to?(:display)
    parsed_response.display(port)
  elsif !response.nil? && !response.body.nil? && response.body.respond_to?(:display)
    response.body.display(port)
  else
    port.write(inspect)
  end
end

def http_version

def http_version
  response.http_version
end

def initialize(request, response, parsed_block, options = {})

def initialize(request, response, parsed_block, options = {})
  @request      = request
  @response     = response
  @body         = options[:body] || response.body
  @parsed_block = parsed_block
  @headers      = Headers.new(response.to_hash)
  if request.options[:logger]
    logger = ::HTTParty::Logger.build(
      request.options[:logger],
      request.options[:log_level],
      request.options[:log_format]
    )
    logger.format(request, self)
  end
  throw_exception
end

def inspect

def inspect
  inspect_id = ::Kernel::format '%x', (object_id * 2)
  %(#<#{self.class}:0x#{inspect_id} parsed_response=#{parsed_response.inspect}, @response=#{response.inspect}, @headers=#{headers.inspect}>)
end

def method_missing(name, *args, &block)

def method_missing(name, *args, &block)
  if parsed_response.respond_to?(name)
    parsed_response.send(name, *args, &block)
  elsif response.respond_to?(name)
    response.send(name, *args, &block)
  else
    super
  end
end

def nil?

def nil?
  warn_about_nil_deprecation
  response.nil? || response.body.nil? || response.body.empty?
end

def parsed_response

def parsed_response
  @parsed_response ||= @parsed_block.call
end

def pretty_print(pp)

def pretty_print(pp)
  if !parsed_response.nil? && parsed_response.respond_to?(:pretty_print)
    parsed_response.pretty_print(pp)
  else
    super
  end
end

def respond_to_missing?(name, *args)

def respond_to_missing?(name, *args)
  return true if super
  parsed_response.respond_to?(name) || response.respond_to?(name)
end

def tap

def tap
  yield self
  self
end

def throw_exception

def throw_exception
  if @request.options[:raise_on].to_a.detect { |c| code.to_s.match(/#{c.to_s}/) }
    ::Kernel.raise ::HTTParty::ResponseError.new(@response), "Code #{code} - #{body}"
  end
end

def to_s

def to_s
  if !response.nil? && !response.body.nil? && response.body.respond_to?(:to_s)
    response.body.to_s
  else
    inspect
  end
end

def warn_about_nil_deprecation

def warn_about_nil_deprecation
  trace_line = caller.reject { |line| line.include?('httparty') }.first
  warning = "[DEPRECATION] HTTParty will no longer override `response#nil?`. " \
    "This functionality will be removed in future versions. " \
    "Please, add explicit check `response.body.nil? || response.body.empty?`. " \
    "For more info refer to: https://github.com/jnunemaker/httparty/issues/568\n" \
    "#{trace_line}"
  warn(warning)
end