Commit abb9eda4 authored by adamk's avatar adamk Committed by Commit bot

[api] Use CHECK instead of DCHECK for IsModule tests in ScriptCompiler

This is such a mis-use of the API that it's important to fail fast:
this patch was prompted by a bug report from a Node.js developer
trying to use CompileModule() without passing a properly
module-tagged ScriptOrigin.

R=jochen@chromium.org, neis@chromium.org
BUG=v8:1569

Review-Url: https://codereview.chromium.org/2695713014
Cr-Commit-Position: refs/heads/master@{#43354}
parent e6819ee2
...@@ -2179,7 +2179,10 @@ MaybeLocal<UnboundScript> ScriptCompiler::CompileUnboundInternal( ...@@ -2179,7 +2179,10 @@ MaybeLocal<UnboundScript> ScriptCompiler::CompileUnboundInternal(
MaybeLocal<UnboundScript> ScriptCompiler::CompileUnboundScript( MaybeLocal<UnboundScript> ScriptCompiler::CompileUnboundScript(
Isolate* v8_isolate, Source* source, CompileOptions options) { Isolate* v8_isolate, Source* source, CompileOptions options) {
DCHECK(!source->GetResourceOptions().IsModule()); Utils::ApiCheck(
!source->GetResourceOptions().IsModule(),
"v8::ScriptCompiler::CompileUnboundScript",
"v8::ScriptCompiler::CompileModule must be used to compile modules");
return CompileUnboundInternal(v8_isolate, source, options); return CompileUnboundInternal(v8_isolate, source, options);
} }
...@@ -2187,7 +2190,10 @@ MaybeLocal<UnboundScript> ScriptCompiler::CompileUnboundScript( ...@@ -2187,7 +2190,10 @@ MaybeLocal<UnboundScript> ScriptCompiler::CompileUnboundScript(
Local<UnboundScript> ScriptCompiler::CompileUnbound(Isolate* v8_isolate, Local<UnboundScript> ScriptCompiler::CompileUnbound(Isolate* v8_isolate,
Source* source, Source* source,
CompileOptions options) { CompileOptions options) {
DCHECK(!source->GetResourceOptions().IsModule()); Utils::ApiCheck(
!source->GetResourceOptions().IsModule(),
"v8::ScriptCompiler::CompileUnbound",
"v8::ScriptCompiler::CompileModule must be used to compile modules");
RETURN_TO_LOCAL_UNCHECKED(CompileUnboundInternal(v8_isolate, source, options), RETURN_TO_LOCAL_UNCHECKED(CompileUnboundInternal(v8_isolate, source, options),
UnboundScript); UnboundScript);
} }
...@@ -2196,7 +2202,9 @@ Local<UnboundScript> ScriptCompiler::CompileUnbound(Isolate* v8_isolate, ...@@ -2196,7 +2202,9 @@ Local<UnboundScript> ScriptCompiler::CompileUnbound(Isolate* v8_isolate,
MaybeLocal<Script> ScriptCompiler::Compile(Local<Context> context, MaybeLocal<Script> ScriptCompiler::Compile(Local<Context> context,
Source* source, Source* source,
CompileOptions options) { CompileOptions options) {
DCHECK(!source->GetResourceOptions().IsModule()); Utils::ApiCheck(
!source->GetResourceOptions().IsModule(), "v8::ScriptCompiler::Compile",
"v8::ScriptCompiler::CompileModule must be used to compile modules");
auto isolate = context->GetIsolate(); auto isolate = context->GetIsolate();
auto maybe = CompileUnboundInternal(isolate, source, options); auto maybe = CompileUnboundInternal(isolate, source, options);
Local<UnboundScript> result; Local<UnboundScript> result;
...@@ -2218,7 +2226,9 @@ MaybeLocal<Module> ScriptCompiler::CompileModule(Isolate* isolate, ...@@ -2218,7 +2226,9 @@ MaybeLocal<Module> ScriptCompiler::CompileModule(Isolate* isolate,
Source* source) { Source* source) {
i::Isolate* i_isolate = reinterpret_cast<i::Isolate*>(isolate); i::Isolate* i_isolate = reinterpret_cast<i::Isolate*>(isolate);
DCHECK(source->GetResourceOptions().IsModule()); Utils::ApiCheck(source->GetResourceOptions().IsModule(),
"v8::ScriptCompiler::CompileModule",
"Invalid ScriptOrigin: is_module must be true");
auto maybe = CompileUnboundInternal(isolate, source, kNoCompileOptions); auto maybe = CompileUnboundInternal(isolate, source, kNoCompileOptions);
Local<UnboundScript> unbound; Local<UnboundScript> unbound;
if (!maybe.ToLocal(&unbound)) return MaybeLocal<Module>(); if (!maybe.ToLocal(&unbound)) return MaybeLocal<Module>();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment