mirror of
https://github.com/servo/servo.git
synced 2025-08-03 20:50:07 +01:00
style: Expose stylist::set_device() for gecko
MozReview-Commit-ID: L655tvOwyKH
This commit is contained in:
parent
bcddb19eb8
commit
4b096486e7
5 changed files with 1097 additions and 591 deletions
|
@ -1982,6 +1982,11 @@ extern "C" {
|
|||
viewport_units_used:
|
||||
*mut bool) -> u8;
|
||||
}
|
||||
extern "C" {
|
||||
pub fn Servo_StyleSet_SetDevice(set: RawServoStyleSetBorrowed,
|
||||
pres_context: RawGeckoPresContextOwned)
|
||||
-> u8;
|
||||
}
|
||||
extern "C" {
|
||||
pub fn Servo_StyleSet_CompatModeChanged(raw_data:
|
||||
RawServoStyleSetBorrowed);
|
||||
|
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -1070,17 +1070,14 @@ impl Stylist {
|
|||
/// Also, the device that arrives here may need to take the viewport rules
|
||||
/// into account.
|
||||
///
|
||||
/// feature = "servo" because gecko only has one device, and manually tracks
|
||||
/// when the device is dirty.
|
||||
///
|
||||
/// FIXME(emilio): The semantics of the device for Servo and Gecko are
|
||||
/// different enough we may want to unify them.
|
||||
#[cfg(feature = "servo")]
|
||||
/// For Gecko, this is called when XBL bindings are used by different
|
||||
/// documents.
|
||||
pub fn set_device(
|
||||
&mut self,
|
||||
mut device: Device,
|
||||
guard: &SharedRwLockReadGuard,
|
||||
) -> OriginSet {
|
||||
if viewport_rule::enabled() {
|
||||
let cascaded_rule = {
|
||||
let stylesheets = self.stylesheets.iter();
|
||||
|
||||
|
@ -1099,6 +1096,7 @@ impl Stylist {
|
|||
if let Some(ref constraints) = self.viewport_constraints {
|
||||
device.account_for_viewport_rule(constraints);
|
||||
}
|
||||
}
|
||||
|
||||
self.device = device;
|
||||
self.media_features_change_changed_style(guard)
|
||||
|
|
|
@ -102,7 +102,7 @@ use style::gecko_bindings::sugar::ownership::{HasSimpleFFI, Strong};
|
|||
use style::gecko_bindings::sugar::refptr::RefPtr;
|
||||
use style::gecko_properties::style_structs;
|
||||
use style::invalidation::element::restyle_hints;
|
||||
use style::media_queries::{MediaList, parse_media_query_list};
|
||||
use style::media_queries::{Device, MediaList, parse_media_query_list};
|
||||
use style::parser::{ParserContext, self};
|
||||
use style::properties::{CascadeFlags, ComputedValues, Importance};
|
||||
use style::properties::{IS_FIELDSET_CONTENT, IS_LINK, IS_VISITED_LINK, LonghandIdSet};
|
||||
|
@ -948,6 +948,25 @@ pub extern "C" fn Servo_StyleSet_MediumFeaturesChanged(
|
|||
OriginFlags::from(origins_in_which_rules_changed).0
|
||||
}
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn Servo_StyleSet_SetDevice(
|
||||
raw_data: RawServoStyleSetBorrowed,
|
||||
pres_context: RawGeckoPresContextOwned
|
||||
) -> u8 {
|
||||
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||
let guard = global_style_data.shared_lock.read();
|
||||
|
||||
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
|
||||
let device = Device::new(pres_context);
|
||||
let origins_in_which_rules_changed =
|
||||
data.stylist.set_device(device, &guard);
|
||||
|
||||
// We'd like to return `OriginFlags` here, but bindgen bitfield enums don't
|
||||
// work as return values with the Linux 32-bit ABI at the moment because
|
||||
// they wrap the value in a struct, so for now just unwrap it.
|
||||
OriginFlags::from(origins_in_which_rules_changed).0
|
||||
}
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn Servo_StyleSet_PrependStyleSheet(
|
||||
raw_data: RawServoStyleSetBorrowed,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue