aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/util/opts.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/util/opts.rs')
-rw-r--r--src/components/util/opts.rs235
1 files changed, 0 insertions, 235 deletions
diff --git a/src/components/util/opts.rs b/src/components/util/opts.rs
deleted file mode 100644
index 40da68632d8..00000000000
--- a/src/components/util/opts.rs
+++ /dev/null
@@ -1,235 +0,0 @@
-/* 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/. */
-
-//! Configuration options for a single run of the servo application. Created
-//! from command line arguments.
-
-use geometry::ScreenPx;
-
-use azure::azure_hl::{BackendType, CairoBackend, CoreGraphicsBackend};
-use azure::azure_hl::{CoreGraphicsAcceleratedBackend, Direct2DBackend, SkiaBackend};
-use geom::scale_factor::ScaleFactor;
-use layers::geometry::DevicePixel;
-use getopts;
-use std::cmp;
-use std::io;
-use std::os;
-use std::rt;
-
-/// Global flags for Servo, currently set on the command line.
-#[deriving(Clone)]
-pub struct Opts {
- /// The initial URLs to load.
- pub urls: Vec<String>,
-
- /// The rendering backend to use (`-r`).
- pub render_backend: BackendType,
-
- /// How many threads to use for CPU rendering (`-t`).
- ///
- /// FIXME(pcwalton): This is not currently used. All rendering is sequential.
- pub n_render_threads: uint,
-
- /// True to use CPU painting, false to use GPU painting via Skia-GL (`-c`). Note that
- /// compositing is always done on the GPU.
- pub cpu_painting: bool,
-
- /// The maximum size of each tile in pixels (`-s`).
- pub tile_size: uint,
-
- /// The ratio of device pixels per px at the default scale. If unspecified, will use the
- /// platform default setting.
- pub device_pixels_per_px: Option<ScaleFactor<ScreenPx, DevicePixel, f32>>,
-
- /// `None` to disable the time profiler or `Some` with an interval in seconds to enable it and
- /// cause it to produce output on that interval (`-p`).
- pub time_profiler_period: Option<f64>,
-
- /// `None` to disable the memory profiler or `Some` with an interval in seconds to enable it
- /// and cause it to produce output on that interval (`-m`).
- pub memory_profiler_period: Option<f64>,
-
- /// Enable experimental web features (`-e`).
- pub enable_experimental: bool,
-
- /// The number of threads to use for layout (`-y`). Defaults to 1, which results in a recursive
- /// sequential algorithm.
- pub layout_threads: uint,
-
- /// True to exit after the page load (`-x`).
- pub exit_after_load: bool,
-
- pub output_file: Option<String>,
- pub headless: bool,
- pub hard_fail: bool,
-
- /// True if we should bubble intrinsic widths sequentially (`-b`). If this is true, then
- /// intrinsic widths are computed as a separate pass instead of during flow construction. You
- /// may wish to turn this flag on in order to benchmark style recalculation against other
- /// browser engines.
- pub bubble_inline_sizes_separately: bool,
-
- /// True if we should show borders on all layers and tiles for
- /// debugging purposes (`--show-debug-borders`).
- pub show_debug_borders: bool,
-
- /// If set with --disable-text-aa, disable antialiasing on fonts. This is primarily useful for reftests
- /// where pixel perfect results are required when using fonts such as the Ahem
- /// font for layout tests.
- pub enable_text_antialiasing: bool,
-
- /// True if each step of layout is traced to an external JSON file
- /// for debugging purposes. Settings this implies sequential layout
- /// and render.
- pub trace_layout: bool,
-}
-
-fn print_usage(app: &str, opts: &[getopts::OptGroup]) {
- let message = format!("Usage: {} [ options ... ] [URL]\n\twhere options include", app);
- println!("{}", getopts::usage(message.as_slice(), opts));
-}
-
-fn args_fail(msg: &str) {
- io::stderr().write_line(msg).unwrap();
- os::set_exit_status(1);
-}
-
-pub fn from_cmdline_args(args: &[String]) -> Option<Opts> {
- let app_name = args[0].to_string();
- let args = args.tail();
-
- let opts = vec!(
- getopts::optflag("c", "cpu", "CPU rendering"),
- getopts::optopt("o", "output", "Output file", "output.png"),
- getopts::optopt("r", "rendering", "Rendering backend", "direct2d|core-graphics|core-graphics-accelerated|cairo|skia."),
- getopts::optopt("s", "size", "Size of tiles", "512"),
- getopts::optopt("", "device-pixel-ratio", "Device pixels per px", ""),
- getopts::optflag("e", "experimental", "Enable experimental web features"),
- getopts::optopt("t", "threads", "Number of render threads", "1"),
- getopts::optflagopt("p", "profile", "Profiler flag and output interval", "10"),
- getopts::optflagopt("m", "memory-profile", "Memory profiler flag and output interval", "10"),
- getopts::optflag("x", "exit", "Exit after load flag"),
- getopts::optopt("y", "layout-threads", "Number of threads to use for layout", "1"),
- getopts::optflag("z", "headless", "Headless mode"),
- getopts::optflag("f", "hard-fail", "Exit on task failure instead of displaying about:failure"),
- getopts::optflag("b", "bubble-widths", "Bubble intrinsic widths separately like other engines"),
- getopts::optflag("", "show-debug-borders", "Show debugging borders on layers and tiles."),
- getopts::optflag("", "disable-text-aa", "Disable antialiasing for text rendering."),
- getopts::optflag("", "trace-layout", "Write layout trace to external file for debugging."),
- getopts::optflag("h", "help", "Print this message")
- );
-
- let opt_match = match getopts::getopts(args, opts.as_slice()) {
- Ok(m) => m,
- Err(f) => {
- args_fail(format!("{}", f).as_slice());
- return None;
- }
- };
-
- if opt_match.opt_present("h") || opt_match.opt_present("help") {
- print_usage(app_name.as_slice(), opts.as_slice());
- return None;
- };
-
- let urls = if opt_match.free.is_empty() {
- print_usage(app_name.as_slice(), opts.as_slice());
- args_fail("servo asks that you provide 1 or more URLs");
- return None;
- } else {
- opt_match.free.clone()
- };
-
- let render_backend = match opt_match.opt_str("r") {
- Some(backend_str) => {
- if "direct2d" == backend_str.as_slice() {
- Direct2DBackend
- } else if "core-graphics" == backend_str.as_slice() {
- CoreGraphicsBackend
- } else if "core-graphics-accelerated" == backend_str.as_slice() {
- CoreGraphicsAcceleratedBackend
- } else if "cairo" == backend_str.as_slice() {
- CairoBackend
- } else if "skia" == backend_str.as_slice() {
- SkiaBackend
- } else {
- fail!("unknown backend type")
- }
- }
- None => SkiaBackend
- };
-
- let tile_size: uint = match opt_match.opt_str("s") {
- Some(tile_size_str) => from_str(tile_size_str.as_slice()).unwrap(),
- None => 512,
- };
-
- let device_pixels_per_px = opt_match.opt_str("device-pixel-ratio").map(|dppx_str|
- ScaleFactor(from_str(dppx_str.as_slice()).unwrap())
- );
-
- let mut n_render_threads: uint = match opt_match.opt_str("t") {
- Some(n_render_threads_str) => from_str(n_render_threads_str.as_slice()).unwrap(),
- None => 1, // FIXME: Number of cores.
- };
-
- // If only the flag is present, default to a 5 second period for both profilers.
- let time_profiler_period = opt_match.opt_default("p", "5").map(|period| {
- from_str(period.as_slice()).unwrap()
- });
- let memory_profiler_period = opt_match.opt_default("m", "5").map(|period| {
- from_str(period.as_slice()).unwrap()
- });
-
- let cpu_painting = opt_match.opt_present("c");
-
- let mut layout_threads: uint = match opt_match.opt_str("y") {
- Some(layout_threads_str) => from_str(layout_threads_str.as_slice()).unwrap(),
- None => cmp::max(rt::default_sched_threads() * 3 / 4, 1),
- };
-
- let mut bubble_inline_sizes_separately = opt_match.opt_present("b");
-
- let trace_layout = opt_match.opt_present("trace-layout");
- if trace_layout {
- n_render_threads = 1;
- layout_threads = 1;
- bubble_inline_sizes_separately = true;
- }
-
- Some(Opts {
- urls: urls,
- render_backend: render_backend,
- n_render_threads: n_render_threads,
- cpu_painting: cpu_painting,
- tile_size: tile_size,
- device_pixels_per_px: device_pixels_per_px,
- time_profiler_period: time_profiler_period,
- memory_profiler_period: memory_profiler_period,
- enable_experimental: opt_match.opt_present("e"),
- layout_threads: layout_threads,
- exit_after_load: opt_match.opt_present("x"),
- output_file: opt_match.opt_str("o"),
- headless: opt_match.opt_present("z"),
- hard_fail: opt_match.opt_present("f"),
- bubble_inline_sizes_separately: bubble_inline_sizes_separately,
- show_debug_borders: opt_match.opt_present("show-debug-borders"),
- enable_text_antialiasing: !opt_match.opt_present("disable-text-aa"),
- trace_layout: trace_layout,
- })
-}
-
-static mut EXPERIMENTAL_ENABLED: bool = false;
-
-pub fn set_experimental_enabled(new_value: bool) {
- unsafe {
- EXPERIMENTAL_ENABLED = new_value;
- }
-}
-
-pub fn experimental_enabled() -> bool {
- unsafe {
- EXPERIMENTAL_ENABLED
- }
-}