| Index: webkit/plugins/npapi/plugin_stream_url.cc
|
| ===================================================================
|
| --- webkit/plugins/npapi/plugin_stream_url.cc (revision 212369)
|
| +++ webkit/plugins/npapi/plugin_stream_url.cc (working copy)
|
| @@ -1,164 +0,0 @@
|
| -// Copyright (c) 2012 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.
|
| -
|
| -#include "webkit/plugins/npapi/plugin_stream_url.h"
|
| -
|
| -#include <algorithm>
|
| -
|
| -#include "net/http/http_response_headers.h"
|
| -#include "webkit/plugins/npapi/plugin_host.h"
|
| -#include "webkit/plugins/npapi/plugin_instance.h"
|
| -#include "webkit/plugins/npapi/plugin_lib.h"
|
| -#include "webkit/plugins/npapi/webplugin.h"
|
| -
|
| -namespace webkit {
|
| -namespace npapi {
|
| -
|
| -PluginStreamUrl::PluginStreamUrl(
|
| - unsigned long resource_id,
|
| - const GURL &url,
|
| - PluginInstance *instance,
|
| - bool notify_needed,
|
| - void *notify_data)
|
| - : PluginStream(instance, url.spec().c_str(), notify_needed, notify_data),
|
| - url_(url),
|
| - id_(resource_id) {
|
| -}
|
| -
|
| -bool PluginStreamUrl::Close(NPReason reason) {
|
| - // Protect the stream against it being destroyed or the whole plugin instance
|
| - // being destroyed within the destroy stream handler.
|
| - scoped_refptr<PluginStream> protect(this);
|
| - CancelRequest();
|
| - bool result = PluginStream::Close(reason);
|
| - instance()->RemoveStream(this);
|
| - return result;
|
| -}
|
| -
|
| -WebPluginResourceClient* PluginStreamUrl::AsResourceClient() {
|
| - return static_cast<WebPluginResourceClient*>(this);
|
| -}
|
| -
|
| -void PluginStreamUrl::CancelRequest() {
|
| - if (id_ > 0) {
|
| - if (instance()->webplugin()) {
|
| - instance()->webplugin()->CancelResource(id_);
|
| - }
|
| - id_ = 0;
|
| - }
|
| - if (instance()->webplugin()) {
|
| - for (size_t i = 0; i < range_requests_.size(); ++i)
|
| - instance()->webplugin()->CancelResource(range_requests_[i]);
|
| - }
|
| - range_requests_.clear();
|
| -}
|
| -
|
| -void PluginStreamUrl::WillSendRequest(const GURL& url, int http_status_code) {
|
| - if (notify_needed()) {
|
| - // If the plugin participates in HTTP url redirect handling then notify it.
|
| - if (net::HttpResponseHeaders::IsRedirectResponseCode(http_status_code) &&
|
| - instance()->handles_url_redirects()) {
|
| - pending_redirect_url_ = url.spec();
|
| - instance()->NPP_URLRedirectNotify(url.spec().c_str(), http_status_code,
|
| - notify_data());
|
| - return;
|
| - }
|
| - }
|
| - url_ = url;
|
| - UpdateUrl(url.spec().c_str());
|
| -}
|
| -
|
| -void PluginStreamUrl::DidReceiveResponse(const std::string& mime_type,
|
| - const std::string& headers,
|
| - uint32 expected_length,
|
| - uint32 last_modified,
|
| - bool request_is_seekable) {
|
| - // Protect the stream against it being destroyed or the whole plugin instance
|
| - // being destroyed within the new stream handler.
|
| - scoped_refptr<PluginStream> protect(this);
|
| -
|
| - bool opened = Open(mime_type,
|
| - headers,
|
| - expected_length,
|
| - last_modified,
|
| - request_is_seekable);
|
| - if (!opened) {
|
| - CancelRequest();
|
| - instance()->RemoveStream(this);
|
| - } else {
|
| - SetDeferLoading(false);
|
| - }
|
| -}
|
| -
|
| -void PluginStreamUrl::DidReceiveData(const char* buffer, int length,
|
| - int data_offset) {
|
| - if (!open())
|
| - return;
|
| -
|
| - // Protect the stream against it being destroyed or the whole plugin instance
|
| - // being destroyed within the write handlers
|
| - scoped_refptr<PluginStream> protect(this);
|
| -
|
| - if (length > 0) {
|
| - // The PluginStreamUrl instance could get deleted if the plugin fails to
|
| - // accept data in NPP_Write.
|
| - if (Write(const_cast<char*>(buffer), length, data_offset) > 0) {
|
| - SetDeferLoading(false);
|
| - }
|
| - }
|
| -}
|
| -
|
| -void PluginStreamUrl::DidFinishLoading(unsigned long resource_id) {
|
| - if (!seekable()) {
|
| - Close(NPRES_DONE);
|
| - } else {
|
| - std::vector<unsigned long>::iterator it_resource = std::find(
|
| - range_requests_.begin(),
|
| - range_requests_.end(),
|
| - resource_id);
|
| - // Resource id must be known to us - either main resource id, or one
|
| - // of the resources, created for range requests.
|
| - DCHECK(resource_id == id_ || it_resource != range_requests_.end());
|
| - // We should notify the plugin about failed/finished requests to ensure
|
| - // that the number of active resource clients does not continue to grow.
|
| - if (instance()->webplugin())
|
| - instance()->webplugin()->CancelResource(resource_id);
|
| - if (it_resource != range_requests_.end())
|
| - range_requests_.erase(it_resource);
|
| - }
|
| -}
|
| -
|
| -void PluginStreamUrl::DidFail(unsigned long resource_id) {
|
| - Close(NPRES_NETWORK_ERR);
|
| -}
|
| -
|
| -bool PluginStreamUrl::IsMultiByteResponseExpected() {
|
| - return seekable();
|
| -}
|
| -
|
| -int PluginStreamUrl::ResourceId() {
|
| - return id_;
|
| -}
|
| -
|
| -PluginStreamUrl::~PluginStreamUrl() {
|
| - if (instance() && instance()->webplugin()) {
|
| - instance()->webplugin()->ResourceClientDeleted(AsResourceClient());
|
| - }
|
| -}
|
| -
|
| -void PluginStreamUrl::AddRangeRequestResourceId(unsigned long resource_id) {
|
| - DCHECK_NE(resource_id, 0u);
|
| - range_requests_.push_back(resource_id);
|
| -}
|
| -
|
| -void PluginStreamUrl::SetDeferLoading(bool value) {
|
| - if (id_ > 0)
|
| - instance()->webplugin()->SetDeferResourceLoading(id_, value);
|
| - for (size_t i = 0; i < range_requests_.size(); ++i)
|
| - instance()->webplugin()->SetDeferResourceLoading(range_requests_[i],
|
| - value);
|
| -}
|
| -
|
| -} // namespace npapi
|
| -} // namespace webkit
|
|
|