Source code

Revision control

Copy as Markdown

Other Tools

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef js_ShadowReamCallbacks_h
#define js_ShadowReamCallbacks_h
#include "jstypes.h"
#include "js/RootingAPI.h"
#include "js/TypeDecls.h"
struct JS_PUBLIC_API JSContext;
namespace JS {
class RealmOptions;
using GlobalInitializeCallback = bool (*)(JSContext*, JS::Handle<JSObject*>);
// Install the HostInitializeShadowRealm callback that will be invoked when
// creating a shadow realm.
//
// The callback will be passed the realm's global object, so that it is possible
// for the embedding to make any host-determined manipulations to the global,
// such as installing interfaces or helpers that should exist even within
// ShadowRealms. (For example, in the web platform, WebIDL with the
// [Exposed=*] attribute should be installed within a shadow realm.)
extern JS_PUBLIC_API void SetShadowRealmInitializeGlobalCallback(
JSContext* cx, GlobalInitializeCallback callback);
using GlobalCreationCallback =
JSObject* (*)(JSContext* cx, JS::RealmOptions& creationOptions,
JSPrincipals* principals,
JS::Handle<JSObject*> enclosingGlobal);
// Create the Global object for a ShadowRealm.
//
// This isn't directly specified, however at least in Gecko, in order to
// correctly implement HostInitializeShadowRealm, there are requirements
// placed on the global for the ShadowRealm.
//
// This callback should return a Global object compatible with the
// callback installed by SetShadowRealmInitializeGlobalCallback
extern JS_PUBLIC_API void SetShadowRealmGlobalCreationCallback(
JSContext* cx, GlobalCreationCallback callback);
} // namespace JS
#endif // js_ShadowReamCallbacks_h