0
Files
src/pdf/loader/url_loader_wrapper.h
Lei Zhang 221ba7ceac Use more spans in chrome_pdf::URLLoaderWrapperImpl.
Replace separate pointer plus size variables with a span.

Change-Id: I31c1894d8c549c8d943851e2b63ec9f04da4ce9d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4209795
Commit-Queue: Lei Zhang <thestig@chromium.org>
Reviewed-by: Tom Sepez <tsepez@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1099602}
2023-02-01 01:24:28 +00:00

66 lines
2.0 KiB
C++

// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef PDF_LOADER_URL_LOADER_WRAPPER_H_
#define PDF_LOADER_URL_LOADER_WRAPPER_H_
#include <stdint.h>
#include <string>
#include "base/containers/span.h"
#include "base/functional/callback_forward.h"
namespace chrome_pdf {
class URLLoaderWrapper {
public:
virtual ~URLLoaderWrapper() {}
// Returns length of content, will be -1, if it is unknown.
virtual int GetContentLength() const = 0;
// Returns if the response headers contains "accept-ranges".
virtual bool IsAcceptRangesBytes() const = 0;
// Returns if the content encoded in response.
virtual bool IsContentEncoded() const = 0;
// Returns response content type.
virtual std::string GetContentType() const = 0;
// Returns response content disposition.
virtual std::string GetContentDisposition() const = 0;
// Returns response status code.
virtual int GetStatusCode() const = 0;
// Returns if the response contains multi parts.
virtual bool IsMultipart() const = 0;
// If true, `start` contains the start of the byte range.
// If false, response contains full document and `start` will be undefined.
virtual bool GetByteRangeStart(int* start) const = 0;
// Close connection.
virtual void Close() = 0;
// Open new connection and send http range request.
virtual void OpenRange(const std::string& url,
const std::string& referrer_url,
uint32_t position,
uint32_t size,
base::OnceCallback<void(int)> callback) = 0;
// Read the response body. The size of the buffer must be large enough to
// hold the specified number of bytes to read.
// This function might perform a partial read.
virtual void ReadResponseBody(base::span<char> buffer,
base::OnceCallback<void(int)> callback) = 0;
};
} // namespace chrome_pdf
#endif // PDF_LOADER_URL_LOADER_WRAPPER_H_