/* 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 https://mozilla.org/MPL/2.0/. */ use std::rc::Rc; use constellation_traits::ScriptToConstellationMessage; use dom_struct::dom_struct; use js::rust::HandleObject; use profile_traits::mem::MemoryReportResult; use script_bindings::interfaces::ServoInternalsHelpers; use script_bindings::script_runtime::JSContext; use crate::dom::bindings::codegen::Bindings::ServoInternalsBinding::ServoInternalsMethods; use crate::dom::bindings::error::Error; use crate::dom::bindings::reflector::{DomGlobal, Reflector, reflect_dom_object}; use crate::dom::bindings::root::DomRoot; use crate::dom::globalscope::GlobalScope; use crate::dom::promise::Promise; use crate::realms::{AlreadyInRealm, InRealm}; use crate::routed_promise::{RoutedPromiseListener, route_promise}; use crate::script_runtime::CanGc; #[dom_struct] pub(crate) struct ServoInternals { reflector_: Reflector, } impl ServoInternals { pub fn new_inherited() -> ServoInternals { ServoInternals { reflector_: Reflector::new(), } } pub(crate) fn new(global: &GlobalScope, can_gc: CanGc) -> DomRoot { reflect_dom_object(Box::new(ServoInternals::new_inherited()), global, can_gc) } } impl ServoInternalsMethods for ServoInternals { /// fn ReportMemory(&self, comp: InRealm, can_gc: CanGc) -> Rc { let global = &self.global(); let promise = Promise::new_in_current_realm(comp, can_gc); let sender = route_promise(&promise, self); let script_to_constellation_chan = global.script_to_constellation_chan(); if script_to_constellation_chan .send(ScriptToConstellationMessage::ReportMemory(sender)) .is_err() { promise.reject_error(Error::Operation, can_gc); } promise } } impl RoutedPromiseListener for ServoInternals { fn handle_response(&self, response: MemoryReportResult, promise: &Rc, can_gc: CanGc) { promise.resolve_native(&response.content, can_gc); } } impl ServoInternalsHelpers for ServoInternals { /// The navigator.servo api is only exposed to about: pages except about:blank #[allow(unsafe_code)] fn is_servo_internal(cx: JSContext, _global: HandleObject) -> bool { unsafe { let in_realm_proof = AlreadyInRealm::assert_for_cx(cx); let global_scope = GlobalScope::from_context(*cx, InRealm::Already(&in_realm_proof)); let url = global_scope.get_url(); url.scheme() == "about" && url.as_str() != "about:blank" } } }