Commit 1f944c56 authored by Marja Hölttä's avatar Marja Hölttä Committed by V8 LUCI CQ

[d8] Add ability to process JSON files

Bug: v8:11525
Change-Id: I6a5c1cad0257157df605efb9777737d7fe40a42c
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3472078Reviewed-by: 's avatarCamillo Bruni <cbruni@chromium.org>
Commit-Queue: Marja Hölttä <marja@chromium.org>
Cr-Commit-Position: refs/heads/main@{#79175}
parent 05169ec0
...@@ -1452,6 +1452,38 @@ bool Shell::ExecuteWebSnapshot(Isolate* isolate, const char* file_name) { ...@@ -1452,6 +1452,38 @@ bool Shell::ExecuteWebSnapshot(Isolate* isolate, const char* file_name) {
return success; return success;
} }
// Treat every line as a JSON value and parse it.
bool Shell::LoadJSON(Isolate* isolate, const char* file_name) {
HandleScope handle_scope(isolate);
PerIsolateData* isolate_data = PerIsolateData::Get(isolate);
Local<Context> realm =
isolate_data->realms_[isolate_data->realm_current_].Get(isolate);
Context::Scope context_scope(realm);
TryCatch try_catch(isolate);
std::string absolute_path = NormalizePath(file_name, GetWorkingDirectory());
int length = 0;
std::unique_ptr<char[]> data(ReadChars(absolute_path.c_str(), &length));
if (length == 0) {
printf("Error reading '%s'\n", file_name);
base::OS::ExitProcess(1);
}
std::stringstream stream(data.get());
std::string line;
while (std::getline(stream, line, '\n')) {
Local<String> source =
String::NewFromUtf8(isolate, line.c_str()).ToLocalChecked();
MaybeLocal<Value> maybe_value = JSON::Parse(realm, source);
Local<Value> value;
if (!maybe_value.ToLocal(&value)) {
DCHECK(try_catch.HasCaught());
ReportException(isolate, &try_catch);
return false;
}
}
return true;
}
PerIsolateData::PerIsolateData(Isolate* isolate) PerIsolateData::PerIsolateData(Isolate* isolate)
: isolate_(isolate), realms_(nullptr) { : isolate_(isolate), realms_(nullptr) {
isolate->SetData(0, this); isolate->SetData(0, this);
...@@ -3577,11 +3609,12 @@ char* Shell::ReadChars(const char* name, int* size_out) { ...@@ -3577,11 +3609,12 @@ char* Shell::ReadChars(const char* name, int* size_out) {
MaybeLocal<PrimitiveArray> Shell::ReadLines(Isolate* isolate, MaybeLocal<PrimitiveArray> Shell::ReadLines(Isolate* isolate,
const char* name) { const char* name) {
int length; int length;
const char* data = reinterpret_cast<const char*>(ReadChars(name, &length)); std::unique_ptr<char[]> data(ReadChars(name, &length));
if (data == nullptr) {
if (data.get() == nullptr) {
return MaybeLocal<PrimitiveArray>(); return MaybeLocal<PrimitiveArray>();
} }
std::stringstream stream(data); std::stringstream stream(data.get());
std::string line; std::string line;
std::vector<std::string> lines; std::vector<std::string> lines;
while (std::getline(stream, line, '\n')) { while (std::getline(stream, line, '\n')) {
...@@ -3929,6 +3962,15 @@ bool SourceGroup::Execute(Isolate* isolate) { ...@@ -3929,6 +3962,15 @@ bool SourceGroup::Execute(Isolate* isolate) {
break; break;
} }
continue; continue;
} else if (strcmp(arg, "--json") == 0 && i + 1 < end_offset_) {
// Treat the next file as a JSON file.
arg = argv_[++i];
Shell::set_script_executed();
if (!Shell::LoadJSON(isolate, arg)) {
success = false;
break;
}
continue;
} else if (arg[0] == '-') { } else if (arg[0] == '-') {
// Ignore other options. They have been parsed already. // Ignore other options. They have been parsed already.
continue; continue;
...@@ -4562,7 +4604,8 @@ bool Shell::SetOptions(int argc, char* argv[]) { ...@@ -4562,7 +4604,8 @@ bool Shell::SetOptions(int argc, char* argv[]) {
current++; current++;
current->Begin(argv, i + 1); current->Begin(argv, i + 1);
} else if (strcmp(str, "--module") == 0 || } else if (strcmp(str, "--module") == 0 ||
strcmp(str, "--web-snapshot") == 0) { strcmp(str, "--web-snapshot") == 0 ||
strcmp(str, "--json") == 0) {
// Pass on to SourceGroup, which understands these options. // Pass on to SourceGroup, which understands these options.
} else if (strncmp(str, "--", 2) == 0) { } else if (strncmp(str, "--", 2) == 0) {
if (!i::FLAG_correctness_fuzzer_suppressions) { if (!i::FLAG_correctness_fuzzer_suppressions) {
......
...@@ -491,6 +491,7 @@ class Shell : public i::AllStatic { ...@@ -491,6 +491,7 @@ class Shell : public i::AllStatic {
ProcessMessageQueue process_message_queue); ProcessMessageQueue process_message_queue);
static bool ExecuteModule(Isolate* isolate, const char* file_name); static bool ExecuteModule(Isolate* isolate, const char* file_name);
static bool ExecuteWebSnapshot(Isolate* isolate, const char* file_name); static bool ExecuteWebSnapshot(Isolate* isolate, const char* file_name);
static bool LoadJSON(Isolate* isolate, const char* file_name);
static void ReportException(Isolate* isolate, Local<Message> message, static void ReportException(Isolate* isolate, Local<Message> message,
Local<Value> exception); Local<Value> exception);
static void ReportException(Isolate* isolate, TryCatch* try_catch); static void ReportException(Isolate* isolate, TryCatch* try_catch);
......
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