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

Side by Side Diff: webkit/media/response_generator.cc

Issue 8649002: Rewrite BufferedDataSource tests to use real BufferedResourceLoader objects. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src
Patch Set: bam Created 9 years 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "webkit/media/response_generator.h"
6
7 #include "base/format_macros.h"
8 #include "base/string_number_conversions.h"
9 #include "base/stringprintf.h"
10 #include "net/base/net_errors.h"
11 #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h"
12 #include "third_party/WebKit/Source/WebKit/chromium/public/WebURLResponse.h"
13
14 using WebKit::WebString;
15 using WebKit::WebURLError;
16 using WebKit::WebURLResponse;
17
18 namespace webkit_media {
19
20 ResponseGenerator::ResponseGenerator(const GURL& gurl, int64 content_length)
21 : gurl_(gurl),
22 content_length_(content_length) {
23 }
24
25 WebURLError ResponseGenerator::GenerateError() {
26 WebURLError error;
27 error.reason = net::ERR_ABORTED;
28 error.domain = WebString::fromUTF8(net::kErrorDomain);
29 return error;
30 }
31
32 WebURLResponse ResponseGenerator::Generate200() {
33 WebURLResponse response(gurl_);
34 response.setHTTPStatusCode(200);
35
36 response.setHTTPHeaderField(
37 WebString::fromUTF8("Content-Length"),
38 WebString::fromUTF8(base::Int64ToString(content_length_)));
39 response.setExpectedContentLength(content_length_);
40 return response;
41 }
42
43 WebURLResponse ResponseGenerator::Generate206(int64 first_byte_offset) {
44 return Generate206(first_byte_offset, kNormal);
45 }
46
47 WebURLResponse ResponseGenerator::Generate206(int64 first_byte_offset,
48 Flags flags) {
49 int64 range_content_length = content_length_ - first_byte_offset;
50 int64 last_byte_offset = content_length_ - first_byte_offset - 1;
Ami GONE FROM CHROMIUM 2011/11/22 22:06:23 What the what? A 10-byte file, requesting starting
scherkus (not reviewing) 2011/11/23 04:22:41 whoops!
51
52 WebURLResponse response(gurl_);
53 response.setHTTPStatusCode(206);
54
55 if ((flags & kNoAcceptRanges) == 0) {
56 response.setHTTPHeaderField(WebString::fromUTF8("Accept-Ranges"),
57 WebString::fromUTF8("bytes"));
58 }
59
60 if ((flags & kNoContentRange) == 0) {
61 std::string content_range = base::StringPrintf(
62 "bytes %" PRId64 "-%" PRId64 "/%" PRId64,
63 first_byte_offset, last_byte_offset, content_length_);
64 response.setHTTPHeaderField(WebString::fromUTF8("Content-Range"),
65 WebString::fromUTF8(content_range));
66 }
67
68 if ((flags & kNoContentLength) == 0) {
69 response.setHTTPHeaderField(
70 WebString::fromUTF8("Content-Length"),
71 WebString::fromUTF8(base::Int64ToString(range_content_length)));
72 response.setExpectedContentLength(range_content_length);
73 }
74 return response;
75 }
76
77 WebURLResponse ResponseGenerator::Generate404() {
78 WebURLResponse response(gurl_);
79 response.setHTTPStatusCode(404);
80 return response;
81 }
82
83 } // namespace webkit_media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698