mirror of
https://github.com/servo/servo.git
synced 2025-08-04 05:00:08 +01:00
Auto merge of #5527 - jagtalon:jag/multiple-urls, r=mbrubeck
Switched from opts.urls from being of type Vec to type String and changing the name to `url` as well. Changed the other files that are using opts.urls accordingly.
This commit is contained in:
commit
df57af1fc4
5 changed files with 28 additions and 38 deletions
|
@ -119,23 +119,20 @@ impl Browser {
|
||||||
|
|
||||||
// Send the URL command to the constellation.
|
// Send the URL command to the constellation.
|
||||||
let cwd = env::current_dir().unwrap();
|
let cwd = env::current_dir().unwrap();
|
||||||
for url in opts.urls.iter() {
|
let url = match url::Url::parse(&opts.url) {
|
||||||
let url = match url::Url::parse(&*url) {
|
Ok(url) => url,
|
||||||
Ok(url) => url,
|
Err(url::ParseError::RelativeUrlWithoutBase)
|
||||||
Err(url::ParseError::RelativeUrlWithoutBase)
|
=> url::Url::from_file_path(&*cwd.join(&opts.url)).unwrap(),
|
||||||
=> url::Url::from_file_path(&*cwd.join(&*url)).unwrap(),
|
Err(_) => panic!("URL parsing failed"),
|
||||||
Err(_) => panic!("URL parsing failed"),
|
};
|
||||||
};
|
|
||||||
|
|
||||||
let ConstellationChan(ref chan) = constellation_chan;
|
let ConstellationChan(ref chan) = constellation_chan;
|
||||||
chan.send(ConstellationMsg::InitLoadUrl(url)).unwrap();
|
chan.send(ConstellationMsg::InitLoadUrl(url)).unwrap();
|
||||||
}
|
|
||||||
|
|
||||||
debug!("preparing to enter main loop");
|
|
||||||
let compositor = CompositorTask::create(window,
|
let compositor = CompositorTask::create(window,
|
||||||
compositor_proxy,
|
compositor_proxy,
|
||||||
compositor_receiver,
|
compositor_receiver,
|
||||||
constellation_chan,
|
constellation_chan.clone(),
|
||||||
time_profiler_chan,
|
time_profiler_chan,
|
||||||
mem_profiler_chan);
|
mem_profiler_chan);
|
||||||
|
|
||||||
|
@ -164,4 +161,3 @@ impl Browser {
|
||||||
self.compositor.shutdown();
|
self.compositor.shutdown();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,8 +22,8 @@ use std::rt;
|
||||||
/// Global flags for Servo, currently set on the command line.
|
/// Global flags for Servo, currently set on the command line.
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct Opts {
|
pub struct Opts {
|
||||||
/// The initial URLs to load.
|
/// The initial URL to load.
|
||||||
pub urls: Vec<String>,
|
pub url: String,
|
||||||
|
|
||||||
/// How many threads to use for CPU painting (`-t`).
|
/// How many threads to use for CPU painting (`-t`).
|
||||||
///
|
///
|
||||||
|
@ -183,7 +183,7 @@ static FORCE_CPU_PAINTING: bool = false;
|
||||||
|
|
||||||
pub fn default_opts() -> Opts {
|
pub fn default_opts() -> Opts {
|
||||||
Opts {
|
Opts {
|
||||||
urls: vec!(),
|
url: String::new(),
|
||||||
paint_threads: 1,
|
paint_threads: 1,
|
||||||
gpu_painting: false,
|
gpu_painting: false,
|
||||||
tile_size: 512,
|
tile_size: 512,
|
||||||
|
@ -277,12 +277,12 @@ pub fn from_cmdline_args(args: &[String]) -> bool {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
let urls = if opt_match.free.is_empty() {
|
let url = if opt_match.free.is_empty() {
|
||||||
print_usage(app_name.as_slice(), opts.as_slice());
|
print_usage(app_name.as_slice(), opts.as_slice());
|
||||||
args_fail("servo asks that you provide 1 or more URLs");
|
args_fail("servo asks that you provide a URL");
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
opt_match.free.clone()
|
opt_match.free[0].clone()
|
||||||
};
|
};
|
||||||
|
|
||||||
let tile_size: usize = match opt_match.opt_str("s") {
|
let tile_size: usize = match opt_match.opt_str("s") {
|
||||||
|
@ -344,7 +344,7 @@ pub fn from_cmdline_args(args: &[String]) -> bool {
|
||||||
};
|
};
|
||||||
|
|
||||||
let opts = Opts {
|
let opts = Opts {
|
||||||
urls: urls,
|
url: url,
|
||||||
paint_threads: paint_threads,
|
paint_threads: paint_threads,
|
||||||
gpu_painting: gpu_painting,
|
gpu_painting: gpu_painting,
|
||||||
tile_size: tile_size,
|
tile_size: tile_size,
|
||||||
|
|
|
@ -204,10 +204,9 @@ fn browser_host_create(window_info: &cef_window_info_t,
|
||||||
client: CefClient,
|
client: CefClient,
|
||||||
callback_executed: bool)
|
callback_executed: bool)
|
||||||
-> CefBrowser {
|
-> CefBrowser {
|
||||||
let mut urls = Vec::new();
|
let url = "http://s27.postimg.org/vqbtrolyr/servo.jpg".to_owned();
|
||||||
urls.push("http://s27.postimg.org/vqbtrolyr/servo.jpg".to_owned());
|
|
||||||
let mut opts = opts::default_opts();
|
let mut opts = opts::default_opts();
|
||||||
opts.urls = urls;
|
opts.url = url;
|
||||||
let browser = ServoCefBrowser::new(window_info, client).as_cef_interface();
|
let browser = ServoCefBrowser::new(window_info, client).as_cef_interface();
|
||||||
browser.init(window_info);
|
browser.init(window_info);
|
||||||
if callback_executed {
|
if callback_executed {
|
||||||
|
@ -246,4 +245,3 @@ cef_static_method_impls! {
|
||||||
browser_host_create(window_info, client, true)
|
browser_host_create(window_info, client, true)
|
||||||
}}
|
}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -70,7 +70,7 @@ pub extern "C" fn cef_initialize(args: *const cef_main_args_t,
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut temp_opts = opts::default_opts();
|
let mut temp_opts = opts::default_opts();
|
||||||
temp_opts.urls = vec![HOME_URL.to_owned()];
|
temp_opts.url = HOME_URL.to_owned();
|
||||||
temp_opts.paint_threads = rendering_threads;
|
temp_opts.paint_threads = rendering_threads;
|
||||||
temp_opts.layout_threads = rendering_threads;
|
temp_opts.layout_threads = rendering_threads;
|
||||||
temp_opts.headless = false;
|
temp_opts.headless = false;
|
||||||
|
@ -137,4 +137,3 @@ pub extern "C" fn cef_log(_file: *const c_char,
|
||||||
pub extern "C" fn cef_get_min_log_level() -> c_int {
|
pub extern "C" fn cef_get_min_log_level() -> c_int {
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -113,23 +113,20 @@ impl Browser {
|
||||||
|
|
||||||
// Send the URL command to the constellation.
|
// Send the URL command to the constellation.
|
||||||
let cwd = env::current_dir().unwrap();
|
let cwd = env::current_dir().unwrap();
|
||||||
for url in opts.urls.iter() {
|
let url = match url::Url::parse(&opts.url) {
|
||||||
let url = match url::Url::parse(&*url) {
|
Ok(url) => url,
|
||||||
Ok(url) => url,
|
Err(url::ParseError::RelativeUrlWithoutBase)
|
||||||
Err(url::ParseError::RelativeUrlWithoutBase)
|
=> url::Url::from_file_path(&*cwd.join(&opts.url)).unwrap(),
|
||||||
=> url::Url::from_file_path(&*cwd.join(&*url)).unwrap(),
|
Err(_) => panic!("URL parsing failed"),
|
||||||
Err(_) => panic!("URL parsing failed"),
|
};
|
||||||
};
|
|
||||||
|
|
||||||
let ConstellationChan(ref chan) = constellation_chan;
|
let ConstellationChan(ref chan) = constellation_chan;
|
||||||
chan.send(ConstellationMsg::InitLoadUrl(url)).unwrap();
|
chan.send(ConstellationMsg::InitLoadUrl(url)).unwrap();
|
||||||
}
|
|
||||||
|
|
||||||
debug!("preparing to enter main loop");
|
|
||||||
let compositor = CompositorTask::create(window,
|
let compositor = CompositorTask::create(window,
|
||||||
compositor_proxy,
|
compositor_proxy,
|
||||||
compositor_receiver,
|
compositor_receiver,
|
||||||
constellation_chan,
|
constellation_chan.clone(),
|
||||||
time_profiler_chan,
|
time_profiler_chan,
|
||||||
mem_profiler_chan);
|
mem_profiler_chan);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue