diff options
author | Joe Wilm <joe@jwilm.com> | 2016-12-04 16:27:20 -0800 |
---|---|---|
committer | Joe Wilm <joe@jwilm.com> | 2016-12-11 20:23:41 -0800 |
commit | 01bb10885b8b80a2a4f9974e967dcdd774485950 (patch) | |
tree | 784e7304484c85b05307e754e764aa4f0335880e | |
parent | e2e98ed6c2671c28048c9356d61439c09c835b3d (diff) | |
download | alacritty-01bb10885b8b80a2a4f9974e967dcdd774485950.tar.gz alacritty-01bb10885b8b80a2a4f9974e967dcdd774485950.zip |
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.
-rw-r--r-- | src/cli.rs | 66 | ||||
-rw-r--r-- | src/main.rs | 43 |
2 files changed, 83 insertions, 26 deletions
diff --git a/src/cli.rs b/src/cli.rs new file mode 100644 index 00000000..b61d1054 --- /dev/null +++ b/src/cli.rs @@ -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 + } +} diff --git a/src/main.rs b/src/main.rs index fa184fbd..9cd4eabd 100644 --- a/src/main.rs +++ b/src/main.rs @@ -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(); |