summaryrefslogtreecommitdiff
path: root/deno2/snapshot_creator.cc
diff options
context:
space:
mode:
Diffstat (limited to 'deno2/snapshot_creator.cc')
-rw-r--r--deno2/snapshot_creator.cc62
1 files changed, 40 insertions, 22 deletions
diff --git a/deno2/snapshot_creator.cc b/deno2/snapshot_creator.cc
index 481c657cc..2a1622994 100644
--- a/deno2/snapshot_creator.cc
+++ b/deno2/snapshot_creator.cc
@@ -7,41 +7,59 @@
#include "v8/include/v8.h"
#include "v8/src/base/logging.h"
-v8::StartupData StringToStartupData(const std::string& s) {
- return v8::StartupData{s.c_str(), s.size()};
+namespace deno {
+
+v8::StartupData SerializeInternalFields(v8::Local<v8::Object> holder, int index,
+ void* data) {
+ DCHECK_EQ(data, nullptr);
+ InternalFieldData* embedder_field = static_cast<InternalFieldData*>(
+ holder->GetAlignedPointerFromInternalField(index));
+ if (embedder_field == nullptr) return {nullptr, 0};
+ int size = sizeof(*embedder_field);
+ char* payload = new char[size];
+ // We simply use memcpy to serialize the content.
+ memcpy(payload, embedder_field, size);
+ return {payload, size};
+}
+
+v8::StartupData MakeSnapshot(const char* js_filename, const char* js_source) {
+ auto* creator = new v8::SnapshotCreator(external_references);
+ auto* isolate = creator->GetIsolate();
+ v8::Isolate::Scope isolate_scope(isolate);
+ {
+ v8::HandleScope handle_scope(isolate);
+ auto context = v8::Context::New(isolate);
+ InitializeContext(isolate, context, js_filename, js_source);
+ creator->SetDefaultContext(context, v8::SerializeInternalFieldsCallback(
+ SerializeInternalFields, nullptr));
+ }
+
+ // Note that using kKeep here will cause segfaults. This is demoed in the
+ // "SnapshotBug" test case.
+ auto snapshot_blob =
+ creator->CreateBlob(v8::SnapshotCreator::FunctionCodeHandling::kClear);
+
+ return snapshot_blob;
}
+} // namespace deno
+
int main(int argc, char** argv) {
const char* js_fn = argv[1];
- const char* natives_in_bin = argv[2];
- const char* snapshot_in_bin = argv[3];
- const char* natives_out_cc = argv[4];
- const char* snapshot_out_cc = argv[5];
+ const char* snapshot_out_cc = argv[2];
+ v8::V8::SetFlagsFromCommandLine(&argc, argv, true);
+
+ CHECK_EQ(argc, 3);
CHECK_NE(js_fn, nullptr);
- CHECK_NE(natives_in_bin, nullptr);
- CHECK_NE(snapshot_in_bin, nullptr);
- CHECK_NE(natives_out_cc, nullptr);
CHECK_NE(snapshot_out_cc, nullptr);
- v8::V8::SetFlagsFromCommandLine(&argc, argv, true);
-
std::string js_source;
CHECK(deno::ReadFileToString(js_fn, &js_source));
- std::string natives_str;
- CHECK(deno::ReadFileToString(natives_in_bin, &natives_str));
- auto natives_blob = StringToStartupData(natives_str);
-
- std::string snapshot_in_str;
- CHECK(deno::ReadFileToString(snapshot_in_bin, &snapshot_in_str));
- auto snapshot_in_blob = StringToStartupData(snapshot_in_str);
-
deno_init();
- auto snapshot_blob = deno::MakeSnapshot(&natives_blob, &snapshot_in_blob,
- js_fn, js_source.c_str());
+ auto snapshot_blob = deno::MakeSnapshot(js_fn, js_source.c_str());
std::string snapshot_str(snapshot_blob.data, snapshot_blob.raw_size);
- CHECK(deno::WriteDataAsCpp("natives", natives_out_cc, natives_str));
CHECK(deno::WriteDataAsCpp("snapshot", snapshot_out_cc, snapshot_str));
}