716cb28430
* chore: bump chromium in DEPS to 1e9f9a24aa12bea9cf194a82a7e249bd1242ec4f * chore: update patches * Make WebContents' theme color a base::Optional<SkColor> https://chromium-review.googlesource.com/c/chromium/src/+/1540022 * update autofill patch for incorrect header includes * Move Shell messages to web_test and rename to BlinkTest. https://chromium-review.googlesource.com/c/chromium/src/+/1525181 * Make PlatformNotificationServiceImpl a KeyedService. https://chromium-review.googlesource.com/c/chromium/src/+/1336150 * Move MediaPlayerId to its own file. https://chromium-review.googlesource.com/c/chromium/src/+/1547057 * Remove net/base/completion_callback.h, which is no longer used https://chromium-review.googlesource.com/c/chromium/src/+/1552821 * AW NS: support file scheme cookies https://chromium-review.googlesource.com/c/chromium/src/+/1533486 * Remove SecurityInfo and adapt remaining consumers https://chromium-review.googlesource.com/c/chromium/src/+/1509455 * Remove deprecated type-specific number to string conversion functions https://chromium-review.googlesource.com/c/chromium/src/+/1545881 * DevTools: Adding new performance histograms for launch of top 4 tools https://chromium-review.googlesource.com/c/chromium/src/+/1506388 * Update include paths for //base/hash/hash.h https://chromium-review.googlesource.com/c/chromium/src/+/1544630 * build: Disable ensure_gn_version gclient hook for mac CI checkout * update patches * use maybe version of v8::String::NewFromTwoByte * bump appveyor image version * fix mac ci hopefully * Convert enum to enum class for MenuAnchorPosition https://chromium-review.googlesource.com/c/chromium/src/+/1530508 * use maybe version of ToObject * RenderViewHost::GetProcess is no longer const * Unrefcount AuthChallengeInfo https://chromium-review.googlesource.com/c/chromium/src/+/1550631 * MenuButtonController takes Button rather than MenuButton https://chromium-review.googlesource.com/c/chromium/src/+/1500935 * add //ui/views_bridge_mac to deps to fix link error * forward declare views::Button in atom::MenuDelegate * more v8 patches * base/{=> hash}/md5.h https://chromium-review.googlesource.com/c/chromium/src/+/1535124 * gfx::{PlatformFontWin => win}::* https://chromium-review.googlesource.com/c/chromium/src/+/1534178 * fix v8 patches * [base] Rename TaskScheduler to ThreadPool https://chromium-review.googlesource.com/c/chromium/src/+/1561552 * use internal_config_base for bytecode_builtins_list_generator avoids windows link errors * FIXME: temporarily disable v8/breakpad integration * FIXME: temporarily disable prevent-will-redirect test * FIXME: disable neon on aarch64 pending crbug.com/953815 * update to account for WebCursor refactor https://chromium-review.googlesource.com/c/chromium/src/+/1562755 * enable stack dumping on appveyor * Revert "FIXME: disable neon on aarch64 pending crbug.com/953815" This reverts commit 57f082026be3d83069f2a2814684abf4dc9e7b53. * fix: remove const qualifiers to match upstream * fix: remove const qualifiers to match upstream in cc files as well * don't throw an error when testing if an object is an object * use non-deprecated Buffer constructor * Remove net::CookieSameSite::DEFAULT_MODE enum value https://chromium-review.googlesource.com/c/chromium/src/+/1567955 * depend on modded dbus-native to work around buffer deprecation https://github.com/sidorares/dbus-native/pull/262 * revert clang roll to fix arm build on linux * fixup! depend on modded dbus-native to work around buffer deprecation need more coffee * update coffee-script * robustify verify-mksnapshot w.r.t. command-line parameters * Revert "robustify verify-mksnapshot w.r.t. command-line parameters" This reverts commit a49af01411f684f6025528d604895c3696e0bc57. * fix mksnapshot by matching args * update patches * TMP: enable rdp on appveyor * Changed ContentBrowserClient::CreateQuotaPermissionContext() to return scoped_refptr. https://chromium-review.googlesource.com/c/chromium/src/+/1569376 * Make content::ResourceType an enum class. https://chromium-review.googlesource.com/c/chromium/src/+/1569345 * fixup! Make content::ResourceType an enum class. * turn off rdp * use net::CompletionRepeatingCallback instead of base::Callback<void(int)> * remove disable_ensure_gn_version_gclient_hook.patch * copy repeating callback instead of std::move * fix lint * add completion_repeating_callback.h include
130 lines
4.7 KiB
C++
130 lines
4.7 KiB
C++
// Copyright (c) 2013 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include <string>
|
|
#include <utility>
|
|
|
|
#include "atom/common/api/atom_api_key_weak_map.h"
|
|
#include "atom/common/api/remote_callback_freer.h"
|
|
#include "atom/common/api/remote_object_freer.h"
|
|
#include "atom/common/native_mate_converters/content_converter.h"
|
|
#include "atom/common/native_mate_converters/gurl_converter.h"
|
|
#include "atom/common/node_includes.h"
|
|
#include "base/hash/hash.h"
|
|
#include "native_mate/dictionary.h"
|
|
#include "url/origin.h"
|
|
#include "v8/include/v8-profiler.h"
|
|
|
|
namespace std {
|
|
|
|
// The hash function used by DoubleIDWeakMap.
|
|
template <typename Type1, typename Type2>
|
|
struct hash<std::pair<Type1, Type2>> {
|
|
std::size_t operator()(std::pair<Type1, Type2> value) const {
|
|
return base::HashInts(base::Hash(value.first), value.second);
|
|
}
|
|
};
|
|
|
|
} // namespace std
|
|
|
|
namespace mate {
|
|
|
|
template <typename Type1, typename Type2>
|
|
struct Converter<std::pair<Type1, Type2>> {
|
|
static bool FromV8(v8::Isolate* isolate,
|
|
v8::Local<v8::Value> val,
|
|
std::pair<Type1, Type2>* out) {
|
|
if (!val->IsArray())
|
|
return false;
|
|
|
|
v8::Local<v8::Array> array(v8::Local<v8::Array>::Cast(val));
|
|
if (array->Length() != 2)
|
|
return false;
|
|
return Converter<Type1>::FromV8(isolate, array->Get(0), &out->first) &&
|
|
Converter<Type2>::FromV8(isolate, array->Get(1), &out->second);
|
|
}
|
|
};
|
|
|
|
} // namespace mate
|
|
|
|
namespace {
|
|
|
|
v8::Local<v8::Value> GetHiddenValue(v8::Isolate* isolate,
|
|
v8::Local<v8::Object> object,
|
|
v8::Local<v8::String> key) {
|
|
v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
|
v8::Local<v8::Private> privateKey = v8::Private::ForApi(isolate, key);
|
|
v8::Local<v8::Value> value;
|
|
v8::Maybe<bool> result = object->HasPrivate(context, privateKey);
|
|
if (!(result.IsJust() && result.FromJust()))
|
|
return v8::Local<v8::Value>();
|
|
if (object->GetPrivate(context, privateKey).ToLocal(&value))
|
|
return value;
|
|
return v8::Local<v8::Value>();
|
|
}
|
|
|
|
void SetHiddenValue(v8::Isolate* isolate,
|
|
v8::Local<v8::Object> object,
|
|
v8::Local<v8::String> key,
|
|
v8::Local<v8::Value> value) {
|
|
if (value.IsEmpty())
|
|
return;
|
|
v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
|
v8::Local<v8::Private> privateKey = v8::Private::ForApi(isolate, key);
|
|
object->SetPrivate(context, privateKey, value);
|
|
}
|
|
|
|
void DeleteHiddenValue(v8::Isolate* isolate,
|
|
v8::Local<v8::Object> object,
|
|
v8::Local<v8::String> key) {
|
|
v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
|
v8::Local<v8::Private> privateKey = v8::Private::ForApi(isolate, key);
|
|
// Actually deleting the value would make force the object into
|
|
// dictionary mode which is unnecessarily slow. Instead, we replace
|
|
// the hidden value with "undefined".
|
|
object->SetPrivate(context, privateKey, v8::Undefined(isolate));
|
|
}
|
|
|
|
int32_t GetObjectHash(v8::Local<v8::Object> object) {
|
|
return object->GetIdentityHash();
|
|
}
|
|
|
|
void TakeHeapSnapshot(v8::Isolate* isolate) {
|
|
isolate->GetHeapProfiler()->TakeHeapSnapshot();
|
|
}
|
|
|
|
void RequestGarbageCollectionForTesting(v8::Isolate* isolate) {
|
|
isolate->RequestGarbageCollectionForTesting(
|
|
v8::Isolate::GarbageCollectionType::kFullGarbageCollection);
|
|
}
|
|
|
|
bool IsSameOrigin(const GURL& l, const GURL& r) {
|
|
return url::Origin::Create(l).IsSameOriginWith(url::Origin::Create(r));
|
|
}
|
|
|
|
void Initialize(v8::Local<v8::Object> exports,
|
|
v8::Local<v8::Value> unused,
|
|
v8::Local<v8::Context> context,
|
|
void* priv) {
|
|
mate::Dictionary dict(context->GetIsolate(), exports);
|
|
dict.SetMethod("getHiddenValue", &GetHiddenValue);
|
|
dict.SetMethod("setHiddenValue", &SetHiddenValue);
|
|
dict.SetMethod("deleteHiddenValue", &DeleteHiddenValue);
|
|
dict.SetMethod("getObjectHash", &GetObjectHash);
|
|
dict.SetMethod("takeHeapSnapshot", &TakeHeapSnapshot);
|
|
dict.SetMethod("setRemoteCallbackFreer", &atom::RemoteCallbackFreer::BindTo);
|
|
dict.SetMethod("setRemoteObjectFreer", &atom::RemoteObjectFreer::BindTo);
|
|
dict.SetMethod("addRemoteObjectRef", &atom::RemoteObjectFreer::AddRef);
|
|
dict.SetMethod("createIDWeakMap", &atom::api::KeyWeakMap<int32_t>::Create);
|
|
dict.SetMethod(
|
|
"createDoubleIDWeakMap",
|
|
&atom::api::KeyWeakMap<std::pair<std::string, int32_t>>::Create);
|
|
dict.SetMethod("requestGarbageCollectionForTesting",
|
|
&RequestGarbageCollectionForTesting);
|
|
dict.SetMethod("isSameOrigin", &IsSameOrigin);
|
|
}
|
|
|
|
} // namespace
|
|
|
|
NODE_LINKED_MODULE_CONTEXT_AWARE(atom_common_v8_util, Initialize)
|