summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoe Wilm <joe@jwilm.com>2016-12-04 16:27:20 -0800
committerJoe Wilm <joe@jwilm.com>2016-12-11 20:23:41 -0800
commit01bb10885b8b80a2a4f9974e967dcdd774485950 (patch)
tree784e7304484c85b05307e754e764aa4f0335880e
parente2e98ed6c2671c28048c9356d61439c09c835b3d (diff)
downloadalacritty-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.rs66
-rw-r--r--src/main.rs43
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();