This PR removes public fields from all (hope I didn't miss any) DOM structs. Should |Page| be privatized as well? This PR additionally introduces a #[privatize] lint to ensure nobody accidentally re-introduces a public field. All changesets compile separately if applied in the same order. Hope that helps reviewing but I can of course squash them before merging. Source-Repo: https://github.com/servo/servo Source-Revision: f350879574194bb612eac88e21d0920e9827afa7
48 lines
1.2 KiB
Rust
48 lines
1.2 KiB
Rust
/* 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/. */
|
|
|
|
use dom::bindings::codegen::Bindings::ScreenBinding;
|
|
use dom::bindings::codegen::Bindings::ScreenBinding::ScreenMethods;
|
|
use dom::bindings::global;
|
|
use dom::bindings::js::{JSRef, Temporary};
|
|
use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
|
|
use dom::window::Window;
|
|
|
|
#[jstraceable]
|
|
#[must_root]
|
|
#[privatize]
|
|
pub struct Screen {
|
|
reflector_: Reflector,
|
|
}
|
|
|
|
impl Screen {
|
|
fn new_inherited() -> Screen {
|
|
Screen {
|
|
reflector_: Reflector::new(),
|
|
}
|
|
}
|
|
|
|
pub fn new(window: JSRef<Window>) -> Temporary<Screen> {
|
|
reflect_dom_object(box Screen::new_inherited(),
|
|
&global::Window(window),
|
|
ScreenBinding::Wrap)
|
|
}
|
|
}
|
|
|
|
impl<'a> ScreenMethods for JSRef<'a, Screen> {
|
|
fn ColorDepth(self) -> u32 {
|
|
24
|
|
}
|
|
|
|
fn PixelDepth(self) -> u32 {
|
|
24
|
|
}
|
|
}
|
|
|
|
impl Reflectable for Screen {
|
|
fn reflector<'a>(&'a self) -> &'a Reflector {
|
|
&self.reflector_
|
|
}
|
|
}
|