mirror of
https://github.com/servo/servo.git
synced 2025-08-02 20:20:14 +01:00
Move non-gfx things out of gfx_traits
and create a base
crate (#32296)
For a long time, `gfx_traits` has held a lot of things unrelated to graphics and also unrelated to the `gfx` crate (which is mostly about fonts). This is a cleanup which does a few things: 1. Move non `gfx` crate things out of `gfx_traits`. This is important in order to prevent dependency cycles with a different integration between layout, script, and fonts. 2. Rename the `msg` crate to `base`. It didn't really contain anything to do with messages and instead mostly holds ids, which are used across many different crates in Servo. This new crate will hold the *rare* data types that are widely used. Details: - All BackgroundHangMonitor-related things from base to a new `background_hang_monitor_api` crate. - Moved `TraversalDirection` to `script_traits` - Moved `Epoch`-related things from `gfx_traits` to `base`. - Moved `PrintTree` to base. This should be widely useful in Servo. - Moved `WebrenderApi` from `base` to `webrender_traits` and renamed it to `WebRenderFontApi`.
This commit is contained in:
parent
1017533297
commit
3398fc017b
163 changed files with 709 additions and 632 deletions
45
components/shared/base/lib.rs
Normal file
45
components/shared/base/lib.rs
Normal file
|
@ -0,0 +1,45 @@
|
|||
/* 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/. */
|
||||
|
||||
#![deny(unsafe_code)]
|
||||
|
||||
//! A crate to hold very common types in Servo.
|
||||
//!
|
||||
//! You should almost never need to add a data type to this crate. Instead look for
|
||||
//! a more shared crate that has fewer dependents.
|
||||
|
||||
use serde::{Deserialize, Serialize};
|
||||
|
||||
pub mod id;
|
||||
pub mod print_tree;
|
||||
use webrender_api::Epoch as WebRenderEpoch;
|
||||
|
||||
/// A struct for denoting the age of messages; prevents race conditions.
|
||||
#[derive(Clone, Copy, Debug, Deserialize, Eq, Hash, Ord, PartialEq, PartialOrd, Serialize)]
|
||||
pub struct Epoch(pub u32);
|
||||
|
||||
impl Epoch {
|
||||
pub fn next(&mut self) {
|
||||
self.0 += 1;
|
||||
}
|
||||
}
|
||||
|
||||
impl From<Epoch> for WebRenderEpoch {
|
||||
fn from(val: Epoch) -> Self {
|
||||
WebRenderEpoch(val.0)
|
||||
}
|
||||
}
|
||||
|
||||
pub trait WebRenderEpochToU16 {
|
||||
fn as_u16(&self) -> u16;
|
||||
}
|
||||
|
||||
impl WebRenderEpochToU16 for WebRenderEpoch {
|
||||
/// The value of this [`Epoch`] as a u16 value. Note that if this Epoch's
|
||||
/// value is more than u16::MAX, then the return value will be modulo
|
||||
/// u16::MAX.
|
||||
fn as_u16(&self) -> u16 {
|
||||
(self.0 % u16::MAX as u32) as u16
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue