This source file includes following definitions.
- m_targetType
- loadSynchronously
- loadAsynchronously
- responseURL
- createResourceRequest
- didReceiveResponse
- didReceiveData
- didFinishLoading
- didFail
- didFailRedirectCheck
- notifyError
- cancel
- script
- notifyFinished
#include "config.h"
#include "core/workers/WorkerScriptLoader.h"
#include "core/dom/ExecutionContext.h"
#include "core/html/parser/TextResourceDecoder.h"
#include "core/loader/WorkerThreadableLoader.h"
#include "core/workers/WorkerGlobalScope.h"
#include "core/workers/WorkerScriptLoaderClient.h"
#include "platform/network/ResourceResponse.h"
#include "wtf/OwnPtr.h"
#include "wtf/RefPtr.h"
namespace WebCore {
WorkerScriptLoader::WorkerScriptLoader()
: m_client(0)
, m_failed(false)
, m_identifier(0)
, m_finishing(false)
, m_targetType(ResourceRequest::TargetIsWorker)
{
}
WorkerScriptLoader::~WorkerScriptLoader()
{
}
void WorkerScriptLoader::loadSynchronously(ExecutionContext* executionContext, const KURL& url, CrossOriginRequestPolicy crossOriginRequestPolicy)
{
m_url = url;
OwnPtr<ResourceRequest> request(createResourceRequest());
if (!request)
return;
ASSERT_WITH_SECURITY_IMPLICATION(executionContext->isWorkerGlobalScope());
ThreadableLoaderOptions options;
options.allowCredentials = AllowStoredCredentials;
options.crossOriginRequestPolicy = crossOriginRequestPolicy;
options.contentSecurityPolicyEnforcement = DoNotEnforceContentSecurityPolicy;
WorkerThreadableLoader::loadResourceSynchronously(toWorkerGlobalScope(executionContext), *request, *this, options);
}
void WorkerScriptLoader::loadAsynchronously(ExecutionContext* executionContext, const KURL& url, CrossOriginRequestPolicy crossOriginRequestPolicy, WorkerScriptLoaderClient* client)
{
ASSERT(client);
m_client = client;
m_url = url;
OwnPtr<ResourceRequest> request(createResourceRequest());
if (!request)
return;
ThreadableLoaderOptions options;
options.allowCredentials = AllowStoredCredentials;
options.crossOriginRequestPolicy = crossOriginRequestPolicy;
RefPtr<WorkerScriptLoader> protect(this);
m_threadableLoader = ThreadableLoader::create(executionContext, this, *request, options);
}
const KURL& WorkerScriptLoader::responseURL() const
{
ASSERT(!failed());
return m_responseURL;
}
PassOwnPtr<ResourceRequest> WorkerScriptLoader::createResourceRequest()
{
OwnPtr<ResourceRequest> request = adoptPtr(new ResourceRequest(m_url));
request->setHTTPMethod("GET");
request->setTargetType(m_targetType);
return request.release();
}
void WorkerScriptLoader::didReceiveResponse(unsigned long identifier, const ResourceResponse& response)
{
if (response.httpStatusCode() / 100 != 2 && response.httpStatusCode()) {
m_failed = true;
return;
}
m_responseURL = response.url();
m_responseEncoding = response.textEncodingName();
if (m_client)
m_client->didReceiveResponse(identifier, response);
}
void WorkerScriptLoader::didReceiveData(const char* data, int len)
{
if (m_failed)
return;
if (!m_decoder) {
if (!m_responseEncoding.isEmpty())
m_decoder = TextResourceDecoder::create("text/javascript", m_responseEncoding);
else
m_decoder = TextResourceDecoder::create("text/javascript", "UTF-8");
}
if (!len)
return;
if (len == -1)
len = strlen(data);
m_script.append(m_decoder->decode(data, len));
}
void WorkerScriptLoader::didFinishLoading(unsigned long identifier, double)
{
if (m_failed) {
notifyError();
return;
}
if (m_decoder)
m_script.append(m_decoder->flush());
m_identifier = identifier;
notifyFinished();
}
void WorkerScriptLoader::didFail(const ResourceError&)
{
notifyError();
}
void WorkerScriptLoader::didFailRedirectCheck()
{
notifyError();
}
void WorkerScriptLoader::notifyError()
{
m_failed = true;
notifyFinished();
}
void WorkerScriptLoader::cancel()
{
if (m_threadableLoader)
m_threadableLoader->cancel();
}
String WorkerScriptLoader::script()
{
return m_script.toString();
}
void WorkerScriptLoader::notifyFinished()
{
if (!m_client || m_finishing)
return;
m_finishing = true;
m_client->notifyFinished();
}
}