InjectedScriptModule.cpp [plain text]
#include "config.h"
#include "InjectedScriptModule.h"
#include "InjectedScript.h"
#include "InjectedScriptManager.h"
#include "ScriptFunctionCall.h"
#include "ScriptObject.h"
namespace Inspector {
InjectedScriptModule::InjectedScriptModule(const String& name)
: InjectedScriptBase(name)
{
}
InjectedScriptModule::~InjectedScriptModule()
{
}
void InjectedScriptModule::ensureInjected(InjectedScriptManager* injectedScriptManager, JSC::JSGlobalObject* globalObject)
{
InjectedScript injectedScript = injectedScriptManager->injectedScriptFor(globalObject);
ensureInjected(injectedScriptManager, injectedScript);
}
void InjectedScriptModule::ensureInjected(InjectedScriptManager* injectedScriptManager, const InjectedScript& injectedScript)
{
ASSERT(!injectedScript.hasNoValue());
if (injectedScript.hasNoValue())
return;
JSC::JSLockHolder locker(injectedScript.globalObject());
Deprecated::ScriptFunctionCall function(injectedScript.injectedScriptObject(), "hasInjectedModule"_s, injectedScriptManager->inspectorEnvironment().functionCallHandler());
function.appendArgument(name());
auto hasInjectedModuleResult = injectedScript.callFunctionWithEvalEnabled(function);
ASSERT(hasInjectedModuleResult);
if (!hasInjectedModuleResult) {
auto& error = hasInjectedModuleResult.error();
ASSERT(error);
unsigned line = 0;
unsigned column = 0;
auto& stack = error->stack();
if (stack.size() > 0)
stack[0].computeLineAndColumn(line, column);
WTFLogAlways("Error when calling 'hasInjectedModule' for '%s': %s (%d:%d)\n", name().utf8().data(), error->value().toWTFString(injectedScript.globalObject()).utf8().data(), line, column);
WTFLogAlways("%s\n", source().utf8().data());
RELEASE_ASSERT_NOT_REACHED();
}
if (!hasInjectedModuleResult.value().isBoolean() || !hasInjectedModuleResult.value().asBoolean()) {
Deprecated::ScriptFunctionCall function(injectedScript.injectedScriptObject(), "injectModule"_s, injectedScriptManager->inspectorEnvironment().functionCallHandler());
function.appendArgument(name());
function.appendArgument(source());
function.appendArgument(host(injectedScriptManager, injectedScript.globalObject()));
auto injectModuleResult = injectedScript.callFunctionWithEvalEnabled(function);
if (!injectModuleResult) {
auto& error = injectModuleResult.error();
ASSERT(error);
unsigned line = 0;
unsigned column = 0;
auto& stack = error->stack();
if (stack.size() > 0)
stack[0].computeLineAndColumn(line, column);
WTFLogAlways("Error when calling 'injectModule' for '%s': %s (%d:%d)\n", name().utf8().data(), error->value().toWTFString(injectedScript.globalObject()).utf8().data(), line, column);
WTFLogAlways("%s\n", source().utf8().data());
RELEASE_ASSERT_NOT_REACHED();
}
}
}
}