Index: test/cctest/interpreter/interpreter-tester.cc |
diff --git a/test/cctest/interpreter/interpreter-tester.cc b/test/cctest/interpreter/interpreter-tester.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b1c412f4e724993e27072fde4f913e93e0127719 |
--- /dev/null |
+++ b/test/cctest/interpreter/interpreter-tester.cc |
@@ -0,0 +1,79 @@ |
+// Copyright 2015 the V8 project 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 "test/cctest/interpreter/interpreter-tester.h" |
+ |
+namespace v8 { |
+namespace internal { |
+namespace interpreter { |
+ |
+MaybeHandle<Object> CallInterpreter(Isolate* isolate, |
+ Handle<JSFunction> function) { |
+ return Execution::Call(isolate, function, |
+ isolate->factory()->undefined_value(), 0, nullptr); |
+} |
+ |
+InterpreterTester::InterpreterTester( |
+ Isolate* isolate, const char* source, MaybeHandle<BytecodeArray> bytecode, |
+ MaybeHandle<TypeFeedbackVector> feedback_vector, const char* filter) |
+ : isolate_(isolate), |
+ source_(source), |
+ bytecode_(bytecode), |
+ feedback_vector_(feedback_vector) { |
+ i::FLAG_ignition = true; |
+ i::FLAG_always_opt = false; |
+ // Set ignition filter flag via SetFlagsFromString to avoid double-free |
+ // (or potential leak with StrDup() based on ownership confusion). |
+ ScopedVector<char> ignition_filter(64); |
+ SNPrintF(ignition_filter, "--ignition-filter=%s", filter); |
+ FlagList::SetFlagsFromString(ignition_filter.start(), |
+ ignition_filter.length()); |
+ // Ensure handler table is generated. |
+ isolate->interpreter()->Initialize(); |
+} |
+ |
+InterpreterTester::InterpreterTester( |
+ Isolate* isolate, Handle<BytecodeArray> bytecode, |
+ MaybeHandle<TypeFeedbackVector> feedback_vector, const char* filter) |
+ : InterpreterTester(isolate, nullptr, bytecode, feedback_vector, filter) {} |
+ |
+InterpreterTester::InterpreterTester(Isolate* isolate, const char* source, |
+ const char* filter) |
+ : InterpreterTester(isolate, source, MaybeHandle<BytecodeArray>(), |
+ MaybeHandle<TypeFeedbackVector>(), filter) {} |
+ |
+InterpreterTester::~InterpreterTester() {} |
+ |
+Local<Message> InterpreterTester::CheckThrowsReturnMessage() { |
+ TryCatch try_catch(reinterpret_cast<v8::Isolate*>(isolate_)); |
+ auto callable = GetCallable<>(); |
+ MaybeHandle<Object> no_result = callable(); |
+ CHECK(isolate_->has_pending_exception()); |
+ CHECK(try_catch.HasCaught()); |
+ CHECK(no_result.is_null()); |
+ isolate_->OptionalRescheduleException(true); |
+ CHECK(!try_catch.Message().IsEmpty()); |
+ return try_catch.Message(); |
+} |
+ |
+Handle<Object> InterpreterTester::NewObject(const char* script) { |
+ return v8::Utils::OpenHandle(*CompileRun(script)); |
+} |
+ |
+Handle<String> InterpreterTester::GetName(Isolate* isolate, const char* name) { |
+ Handle<String> result = isolate->factory()->NewStringFromAsciiChecked(name); |
+ return isolate->factory()->string_table()->LookupString(isolate, result); |
+} |
+ |
+std::string InterpreterTester::SourceForBody(const char* body) { |
+ return "function " + function_name() + "() {\n" + std::string(body) + "\n}"; |
+} |
+ |
+std::string InterpreterTester::function_name() { |
+ return std::string(kFunctionName); |
+} |
+ |
+} // namespace interpreter |
+} // namespace internal |
+} // namespace v8 |