Cleanup cli option parsing

This introduces the `cli` module and the `cli::Options` type. This type
holds all the options passable on the command line in addition to
providing arg parsing.
This commit is contained in:
Joe Wilm 2016-12-04 16:27:20 -08:00
parent e2e98ed6c2
commit 01bb10885b
2 changed files with 83 additions and 26 deletions

66
src/cli.rs Normal file
View File

@ -0,0 +1,66 @@
// Copyright 2016 Joe Wilm, The Alacritty Project Contributors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
use std::env;
use alacritty::index::{Line, Column};
/// Options specified on the command line
pub struct Options {
pub ref_test: bool,
pub columns: Column,
pub lines: Line,
}
impl Default for Options {
fn default() -> Options {
Options {
ref_test: false,
columns: Column(80),
lines: Line(24),
}
}
}
impl Options {
/// Iterate through env::args() to build `Options`
pub fn load() -> Options {
let mut options = Options::default();
let mut args_iter = env::args();
while let Some(arg) = args_iter.next() {
match &arg[..] {
// Generate ref test
"--ref-test" => options.ref_test = true,
// Set dimensions
"-d" | "--dimensions" => {
args_iter.next()
.map(|w| w.parse().map(|w| options.columns = Column(w)));
args_iter.next()
.map(|h| h.parse().map(|h| options.lines = Line(h)));
},
// ignore unexpected
_ => (),
}
}
options
}
pub fn lines_u32(&self) -> u32 {
self.lines.0 as u32
}
pub fn columns_u32(&self) -> u32 {
self.columns.0 as u32
}
}

View File

@ -70,38 +70,29 @@ fn window_resize_handler(width: u32, height: u32) {
}
}
mod cli;
fn main() {
// Load configuration
let (config, config_path) = match Config::load() {
// Error loading config
Err(err) => match err {
// Use default config when not found
config::Error::NotFound => (Config::default(), None),
// Exit when there's a problem with it
config::Error::NotFound => {
err_println!("Config file not found; using defaults");
(Config::default(), None)
},
// If there's a problem with the config file, print an error
// and exit.
_ => die!("{}", err),
},
// Successfully loaded config from file
Ok((config, path)) => (config, Some(path)),
};
let mut ref_test = false;
let mut columns = 80;
let mut lines = 24;
let mut args_iter = ::std::env::args();
while let Some(arg) = args_iter.next() {
match &arg[..] {
// Generate ref test
"--ref-test" => ref_test = true,
// Set dimensions
"-d" | "--dimensions" => {
args_iter.next()
.map(|w| w.parse().map(|w| columns = w));
args_iter.next()
.map(|h| h.parse().map(|h| lines = h));
},
// ignore unexpected
_ => (),
}
}
let options = cli::Options::load();
let font = config.font();
let dpi = config.dpi();
@ -154,8 +145,8 @@ fn main() {
let cell_height = (metrics.line_height + font.offset().y() as f64) as u32;
// Resize window to be 80 col x 24 lines
let width = cell_width * columns + 4;
let height = cell_height * lines + 4;
let width = cell_width * options.columns_u32() + 4;
let height = cell_height * options.lines_u32() + 4;
println!("set_inner_size: {} x {}", width, height);
// Is this in points?
let width_pts = (width as f32 / dpr) as u32;
@ -206,7 +197,7 @@ fn main() {
window.create_window_proxy(),
signal_flag.clone(),
pty_io,
ref_test,
options.ref_test,
);
let loop_tx = event_loop.channel();
@ -228,7 +219,7 @@ fn main() {
terminal.clone(),
tx,
&config,
ref_test,
options.ref_test,
);
let (config_tx, config_rx) = mpsc::channel();