/* * Copyright (C) 2006 Apple Computer, Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "config.h" #include "NetscapePlugInStreamLoader.h" #include "FrameLoader.h" #include "DocumentLoader.h" namespace WebCore { NetscapePlugInStreamLoader::NetscapePlugInStreamLoader(Frame* frame, NetscapePlugInStreamLoaderClient* client) : ResourceLoader(frame, true, true) , m_client(client) { } NetscapePlugInStreamLoader::~NetscapePlugInStreamLoader() { } PassRefPtr<NetscapePlugInStreamLoader> NetscapePlugInStreamLoader::create(Frame* frame, NetscapePlugInStreamLoaderClient* client, const ResourceRequest& request) { RefPtr<NetscapePlugInStreamLoader> loader(adoptRef(new NetscapePlugInStreamLoader(frame, client))); loader->setShouldBufferData(false); loader->documentLoader()->addPlugInStreamLoader(loader.get()); if (!loader->init(request)) return 0; return loader.release(); } bool NetscapePlugInStreamLoader::isDone() const { return !m_client; } void NetscapePlugInStreamLoader::releaseResources() { m_client = 0; ResourceLoader::releaseResources(); } void NetscapePlugInStreamLoader::didReceiveResponse(const ResourceResponse& response) { RefPtr<NetscapePlugInStreamLoader> protect(this); m_client->didReceiveResponse(this, response); // Don't continue if the stream is cancelled if (!m_client) return; ResourceLoader::didReceiveResponse(response); // Don't continue if the stream is cancelled if (!m_client) return; if (!response.isHTTP()) return; if (m_client->wantsAllStreams()) return; if (response.httpStatusCode() < 100 || response.httpStatusCode() >= 400) didCancel(frameLoader()->fileDoesNotExistError(response)); } void NetscapePlugInStreamLoader::didReceiveData(const char* data, int length, long long encodedDataLength, bool allAtOnce) { RefPtr<NetscapePlugInStreamLoader> protect(this); m_client->didReceiveData(this, data, length); ResourceLoader::didReceiveData(data, length, encodedDataLength, allAtOnce); } void NetscapePlugInStreamLoader::didFinishLoading(double finishTime) { RefPtr<NetscapePlugInStreamLoader> protect(this); m_documentLoader->removePlugInStreamLoader(this); m_client->didFinishLoading(this); ResourceLoader::didFinishLoading(finishTime); } void NetscapePlugInStreamLoader::didFail(const ResourceError& error) { RefPtr<NetscapePlugInStreamLoader> protect(this); m_documentLoader->removePlugInStreamLoader(this); m_client->didFail(this, error); ResourceLoader::didFail(error); } void NetscapePlugInStreamLoader::didCancel(const ResourceError& error) { RefPtr<NetscapePlugInStreamLoader> protect(this); m_client->didFail(this, error); // If calling didFail spins the run loop the stream loader can reach the terminal state. // If that's the case we just return early. if (reachedTerminalState()) return; // We need to remove the stream loader after the call to didFail, since didFail can // spawn a new run loop and if the loader has been removed it won't be deferred when // the document loader is asked to defer loading. m_documentLoader->removePlugInStreamLoader(this); ResourceLoader::didCancel(error); } }