Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(248)

Unified Diff: net/http/partial_data.h

Issue 992733002: Remove //net (except for Android test stuff) and sdch (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/http/mock_sspi_library_win.cc ('k') | net/http/partial_data.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/http/partial_data.h
diff --git a/net/http/partial_data.h b/net/http/partial_data.h
deleted file mode 100644
index ea98ff00a8809cffa473ea14d0e467605b50427a..0000000000000000000000000000000000000000
--- a/net/http/partial_data.h
+++ /dev/null
@@ -1,146 +0,0 @@
-// Copyright (c) 2011 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef NET_HTTP_PARTIAL_DATA_H_
-#define NET_HTTP_PARTIAL_DATA_H_
-
-#include "base/basictypes.h"
-#include "net/base/completion_callback.h"
-#include "net/http/http_byte_range.h"
-#include "net/http/http_request_headers.h"
-
-namespace disk_cache {
-class Entry;
-}
-
-namespace net {
-
-class HttpResponseHeaders;
-class IOBuffer;
-
-// This class provides support for dealing with range requests and the
-// subsequent partial-content responses. We use sparse cache entries to store
-// these requests. This class is tightly integrated with HttpCache::Transaction
-// and it is intended to allow a cleaner implementation of that class.
-//
-// In order to fulfill range requests, we may have to perform a sequence of
-// reads from the cache, interleaved with reads from the network / writes to the
-// cache. This class basically keeps track of the data required to perform each
-// of those individual network / cache requests.
-class PartialData {
- public:
- PartialData();
- ~PartialData();
-
- // Performs initialization of the object by examining the request |headers|
- // and verifying that we can process the requested range. Returns true if
- // we can process the requested range, and false otherwise.
- bool Init(const HttpRequestHeaders& headers);
-
- // Sets the headers that we should use to make byte range requests. This is a
- // subset of the request extra headers, with byte-range related headers
- // removed.
- void SetHeaders(const HttpRequestHeaders& headers);
-
- // Restores the byte-range headers, by appending the byte range to the headers
- // provided to SetHeaders().
- void RestoreHeaders(HttpRequestHeaders* headers) const;
-
- // Starts the checks to perform a cache validation. Returns 0 when there is no
- // need to perform more operations because we reached the end of the request
- // (so 0 bytes should be actually returned to the user), a positive number to
- // indicate that PrepareCacheValidation should be called, or an appropriate
- // error code. If this method returns ERR_IO_PENDING, the |callback| will be
- // notified when the result is ready.
- int ShouldValidateCache(disk_cache::Entry* entry,
- const CompletionCallback& callback);
-
- // Builds the required |headers| to perform the proper cache validation for
- // the next range to be fetched.
- void PrepareCacheValidation(disk_cache::Entry* entry,
- HttpRequestHeaders* headers);
-
- // Returns true if the current range is stored in the cache.
- bool IsCurrentRangeCached() const;
-
- // Returns true if the current range is the last one needed to fulfill the
- // user's request.
- bool IsLastRange() const;
-
- // Extracts info from headers already stored in the cache. Returns false if
- // there is any problem with the headers. |truncated| should be true if we
- // have an incomplete 200 entry.
- bool UpdateFromStoredHeaders(const HttpResponseHeaders* headers,
- disk_cache::Entry* entry, bool truncated);
-
- // Sets the byte current range to start again at zero (for a truncated entry).
- void SetRangeToStartDownload();
-
- // Returns true if the requested range is valid given the stored data.
- bool IsRequestedRangeOK();
-
- // Returns true if the response headers match what we expect, false otherwise.
- bool ResponseHeadersOK(const HttpResponseHeaders* headers);
-
- // Fixes the response headers to include the right content length and range.
- // |success| is the result of the whole request so if it's false, we'll change
- // the result code to be 416.
- void FixResponseHeaders(HttpResponseHeaders* headers, bool success);
-
- // Fixes the content length that we want to store in the cache.
- void FixContentLength(HttpResponseHeaders* headers);
-
- // Reads up to |data_len| bytes from the cache and stores them in the provided
- // buffer (|data|). Basically, this is just a wrapper around the API of the
- // cache that provides the right arguments for the current range. When the IO
- // operation completes, OnCacheReadCompleted() must be called with the result
- // of the operation.
- int CacheRead(disk_cache::Entry* entry, IOBuffer* data, int data_len,
- const net::CompletionCallback& callback);
-
- // Writes |data_len| bytes to cache. This is basically a wrapper around the
- // API of the cache that provides the right arguments for the current range.
- int CacheWrite(disk_cache::Entry* entry, IOBuffer* data, int data_len,
- const net::CompletionCallback& callback);
-
- // This method should be called when CacheRead() finishes the read, to update
- // the internal state about the current range.
- void OnCacheReadCompleted(int result);
-
- // This method should be called after receiving data from the network, to
- // update the internal state about the current range.
- void OnNetworkReadCompleted(int result);
-
- bool initial_validation() const { return initial_validation_; }
-
- private:
- class Core;
- // Returns the length to use when scanning the cache.
- int GetNextRangeLen();
-
- // Completion routine for our callback.
- void GetAvailableRangeCompleted(int result, int64 start);
-
- int64 current_range_start_;
- int64 current_range_end_;
- int64 cached_start_;
- int64 resource_size_;
- int cached_min_len_;
- HttpByteRange byte_range_; // The range requested by the user.
- // The clean set of extra headers (no ranges).
- HttpRequestHeaders extra_headers_;
- bool range_present_; // True if next range entry is already stored.
- bool final_range_;
- bool sparse_entry_;
- bool truncated_; // We have an incomplete 200 stored.
- bool initial_validation_; // Only used for truncated entries.
- Core* core_;
- CompletionCallback callback_;
-
- DISALLOW_COPY_AND_ASSIGN(PartialData);
-};
-
-} // namespace net
-
-#endif // NET_HTTP_PARTIAL_DATA_H_
« no previous file with comments | « net/http/mock_sspi_library_win.cc ('k') | net/http/partial_data.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698