Use BAT_PAGER and PAGER environment variables, closes #158

This commit is contained in:
sharkdp 2018-07-23 22:49:25 +02:00 committed by David Peter
parent 268577c6f9
commit d179693d1d

View File

@ -1,5 +1,6 @@
use app::PagingMode; use app::PagingMode;
use errors::*; use errors::*;
use std::env;
use std::io::{self, Write}; use std::io::{self, Write};
use std::process::{Child, Command, Stdio}; use std::process::{Child, Command, Stdio};
@ -20,13 +21,24 @@ impl OutputType {
/// Try to launch the pager. Fall back to stdout in case of errors. /// Try to launch the pager. Fall back to stdout in case of errors.
fn try_pager(quit_if_one_screen: bool) -> Self { fn try_pager(quit_if_one_screen: bool) -> Self {
let mut args = vec!["--RAW-CONTROL-CHARS", "--no-init"]; let pager = env::var("BAT_PAGER")
if quit_if_one_screen { .or_else(|_| env::var("PAGER"))
args.push("--quit-if-one-screen"); .unwrap_or(String::from("less"));
}
Command::new("less") let mut process = if pager == "less" {
.args(&args) let mut args = vec!["--RAW-CONTROL-CHARS", "--no-init"];
.env("LESSCHARSET", "UTF-8") if quit_if_one_screen {
args.push("--quit-if-one-screen");
}
let mut p = Command::new("less");
p.args(&args).env("LESSCHARSET", "UTF-8");
p
} else {
Command::new(pager)
};
process
.stdin(Stdio::piped()) .stdin(Stdio::piped())
.spawn() .spawn()
.map(OutputType::Pager) .map(OutputType::Pager)