mirror of
https://github.com/servo/servo.git
synced 2025-08-05 05:30:08 +01:00
Move OpaqueNode
to style_traits
This commit is contained in:
parent
d988b4c943
commit
cbcf83fc65
4 changed files with 34 additions and 20 deletions
|
@ -90,6 +90,12 @@ malloc_size_of_is_0!(UntrustedNodeAddress);
|
||||||
#[allow(unsafe_code)]
|
#[allow(unsafe_code)]
|
||||||
unsafe impl Send for UntrustedNodeAddress {}
|
unsafe impl Send for UntrustedNodeAddress {}
|
||||||
|
|
||||||
|
impl From<style_traits::dom::OpaqueNode> for UntrustedNodeAddress {
|
||||||
|
fn from(o: style_traits::dom::OpaqueNode) -> Self {
|
||||||
|
UntrustedNodeAddress(o.0 as *const c_void)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Serialize for UntrustedNodeAddress {
|
impl Serialize for UntrustedNodeAddress {
|
||||||
fn serialize<S: Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
|
fn serialize<S: Serializer>(&self, s: S) -> Result<S::Ok, S::Error> {
|
||||||
(self.0 as usize).serialize(s)
|
(self.0 as usize).serialize(s)
|
||||||
|
|
|
@ -32,26 +32,7 @@ use std::fmt::Debug;
|
||||||
use std::hash::Hash;
|
use std::hash::Hash;
|
||||||
use std::ops::Deref;
|
use std::ops::Deref;
|
||||||
|
|
||||||
/// An opaque handle to a node, which, unlike UnsafeNode, cannot be transformed
|
pub use style_traits::dom::OpaqueNode;
|
||||||
/// back into a non-opaque representation. The only safe operation that can be
|
|
||||||
/// performed on this node is to compare it to another opaque handle or to another
|
|
||||||
/// OpaqueNode.
|
|
||||||
///
|
|
||||||
/// Layout and Graphics use this to safely represent nodes for comparison purposes.
|
|
||||||
/// Because the script task's GC does not trace layout, node data cannot be safely stored in layout
|
|
||||||
/// data structures. Also, layout code tends to be faster when the DOM is not being accessed, for
|
|
||||||
/// locality reasons. Using `OpaqueNode` enforces this invariant.
|
|
||||||
#[derive(Clone, Copy, Debug, Eq, Hash, PartialEq)]
|
|
||||||
#[cfg_attr(feature = "servo", derive(MallocSizeOf, Deserialize, Serialize))]
|
|
||||||
pub struct OpaqueNode(pub usize);
|
|
||||||
|
|
||||||
impl OpaqueNode {
|
|
||||||
/// Returns the address of this node, for debugging purposes.
|
|
||||||
#[inline]
|
|
||||||
pub fn id(&self) -> usize {
|
|
||||||
self.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Simple trait to provide basic information about the type of an element.
|
/// Simple trait to provide basic information about the type of an element.
|
||||||
///
|
///
|
||||||
|
|
26
components/style_traits/dom.rs
Normal file
26
components/style_traits/dom.rs
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
/* 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/. */
|
||||||
|
|
||||||
|
//! Types used to access the DOM from style calculation.
|
||||||
|
|
||||||
|
/// An opaque handle to a node, which, unlike UnsafeNode, cannot be transformed
|
||||||
|
/// back into a non-opaque representation. The only safe operation that can be
|
||||||
|
/// performed on this node is to compare it to another opaque handle or to another
|
||||||
|
/// OpaqueNode.
|
||||||
|
///
|
||||||
|
/// Layout and Graphics use this to safely represent nodes for comparison purposes.
|
||||||
|
/// Because the script task's GC does not trace layout, node data cannot be safely stored in layout
|
||||||
|
/// data structures. Also, layout code tends to be faster when the DOM is not being accessed, for
|
||||||
|
/// locality reasons. Using `OpaqueNode` enforces this invariant.
|
||||||
|
#[derive(Clone, Copy, Debug, Eq, Hash, PartialEq)]
|
||||||
|
#[cfg_attr(feature = "servo", derive(MallocSizeOf, Deserialize, Serialize))]
|
||||||
|
pub struct OpaqueNode(pub usize);
|
||||||
|
|
||||||
|
impl OpaqueNode {
|
||||||
|
/// Returns the address of this node, for debugging purposes.
|
||||||
|
#[inline]
|
||||||
|
pub fn id(&self) -> usize {
|
||||||
|
self.0
|
||||||
|
}
|
||||||
|
}
|
|
@ -86,6 +86,7 @@ pub enum CSSPixel {}
|
||||||
// / desktop_zoom => CSSPixel
|
// / desktop_zoom => CSSPixel
|
||||||
|
|
||||||
pub mod arc_slice;
|
pub mod arc_slice;
|
||||||
|
pub mod dom;
|
||||||
pub mod specified_value_info;
|
pub mod specified_value_info;
|
||||||
#[macro_use]
|
#[macro_use]
|
||||||
pub mod values;
|
pub mod values;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue