Move Config,PagingMode from app.rs into lib.rs

This commit is contained in:
Fahmi Akbar Wildana 2019-10-06 08:44:14 +07:00 committed by David Peter
parent a2ee753b25
commit 26439b41d2
6 changed files with 75 additions and 73 deletions

View File

@ -24,70 +24,9 @@ use bat::{
style::{OutputComponent, OutputComponents, OutputWrap}, style::{OutputComponent, OutputComponents, OutputWrap},
syntax_mapping::SyntaxMapping, syntax_mapping::SyntaxMapping,
util::transpose, util::transpose,
Config, PagingMode,
}; };
#[derive(Debug, Clone, Copy, PartialEq)]
pub enum PagingMode {
Always,
QuitIfOneScreen,
Never,
}
#[derive(Clone)]
pub struct Config<'a> {
/// List of files to print
pub files: Vec<InputFile<'a>>,
/// The explicitly configured language, if any
pub language: Option<&'a str>,
/// Whether or not to show/replace non-printable characters like space, tab and newline.
pub show_nonprintable: bool,
/// The character width of the terminal
pub term_width: usize,
/// The width of tab characters.
/// Currently, a value of 0 will cause tabs to be passed through without expanding them.
pub tab_width: usize,
/// Whether or not to simply loop through all input (`cat` mode)
pub loop_through: bool,
/// Whether or not the output should be colorized
pub colored_output: bool,
/// Whether or not the output terminal supports true color
pub true_color: bool,
/// Style elements (grid, line numbers, ...)
pub output_components: OutputComponents,
/// Text wrapping mode
pub output_wrap: OutputWrap,
/// Pager or STDOUT
pub paging_mode: PagingMode,
/// Specifies the lines that should be printed
pub line_ranges: LineRanges,
/// The syntax highlighting theme
pub theme: String,
/// File extension/name mappings
pub syntax_mapping: SyntaxMapping,
/// Command to start the pager
pub pager: Option<&'a str>,
/// Whether or not to use ANSI italics
pub use_italic_text: bool,
/// Lines to highlight
pub highlight_lines: Vec<usize>,
}
fn is_truecolor_terminal() -> bool { fn is_truecolor_terminal() -> bool {
env::var("COLORTERM") env::var("COLORTERM")
.map(|colorterm| colorterm == "truecolor" || colorterm == "24bit") .map(|colorterm| colorterm == "truecolor" || colorterm == "24bit")

View File

@ -2,7 +2,6 @@ use std::io::{self, Write};
use std::path::Path; use std::path::Path;
use crate::{ use crate::{
app::{Config, PagingMode},
output::OutputType, output::OutputType,
printer::{InteractivePrinter, Printer, SimplePrinter}, printer::{InteractivePrinter, Printer, SimplePrinter},
}; };
@ -12,6 +11,7 @@ use bat::{
errors::*, errors::*,
inputfile::{InputFile, InputFileReader}, inputfile::{InputFile, InputFileReader},
line_range::{LineRanges, RangeCheckResult}, line_range::{LineRanges, RangeCheckResult},
Config, PagingMode,
}; };
pub struct Controller<'a> { pub struct Controller<'a> {

View File

@ -21,17 +21,14 @@ use std::process;
use ansi_term::Colour::Green; use ansi_term::Colour::Green;
use ansi_term::Style; use ansi_term::Style;
use crate::{ use crate::{app::App, config::config_file, controller::Controller};
app::{App, Config},
config::config_file,
controller::Controller,
};
use bat::{ use bat::{
assets::{cache_dir, clear_assets, config_dir, HighlightingAssets}, assets::{cache_dir, clear_assets, config_dir, HighlightingAssets},
errors::*, errors::*,
inputfile::InputFile, inputfile::InputFile,
style::{OutputComponent, OutputComponents}, style::{OutputComponent, OutputComponents},
Config,
}; };
fn run_cache_subcommand(matches: &clap::ArgMatches) -> Result<()> { fn run_cache_subcommand(matches: &clap::ArgMatches) -> Result<()> {

View File

@ -6,8 +6,7 @@ use std::process::{Child, Command, Stdio};
use shell_words; use shell_words;
use crate::app::PagingMode; use bat::{errors::*, PagingMode};
use bat::errors::*;
pub enum OutputType { pub enum OutputType {
Pager(Child), Pager(Child),

View File

@ -16,9 +16,8 @@ use content_inspector::ContentType;
use encoding::all::{UTF_16BE, UTF_16LE}; use encoding::all::{UTF_16BE, UTF_16LE};
use encoding::{DecoderTrap, Encoding}; use encoding::{DecoderTrap, Encoding};
use crate::{ use crate::decorations::{
app::Config, Decoration, GridBorderDecoration, LineChangesDecoration, LineNumberDecoration,
decorations::{Decoration, GridBorderDecoration, LineChangesDecoration, LineNumberDecoration},
}; };
use bat::{ use bat::{
@ -30,6 +29,7 @@ use bat::{
preprocessor::{expand_tabs, replace_nonprintable}, preprocessor::{expand_tabs, replace_nonprintable},
style::OutputWrap, style::OutputWrap,
terminal::{as_terminal_escaped, to_ansi_color}, terminal::{as_terminal_escaped, to_ansi_color},
Config,
}; };
pub trait Printer { pub trait Printer {

View File

@ -53,3 +53,70 @@ pub mod errors {
}; };
} }
} }
#[derive(Debug, Clone, Copy, PartialEq)]
pub enum PagingMode {
Always,
QuitIfOneScreen,
Never,
}
use inputfile::InputFile;
use line_range::LineRanges;
use style::{OutputComponents, OutputWrap};
use syntax_mapping::SyntaxMapping;
#[derive(Clone)]
pub struct Config<'a> {
/// List of files to print
pub files: Vec<InputFile<'a>>,
/// The explicitly configured language, if any
pub language: Option<&'a str>,
/// Whether or not to show/replace non-printable characters like space, tab and newline.
pub show_nonprintable: bool,
/// The character width of the terminal
pub term_width: usize,
/// The width of tab characters.
/// Currently, a value of 0 will cause tabs to be passed through without expanding them.
pub tab_width: usize,
/// Whether or not to simply loop through all input (`cat` mode)
pub loop_through: bool,
/// Whether or not the output should be colorized
pub colored_output: bool,
/// Whether or not the output terminal supports true color
pub true_color: bool,
/// Style elements (grid, line numbers, ...)
pub output_components: OutputComponents,
/// Text wrapping mode
pub output_wrap: OutputWrap,
/// Pager or STDOUT
pub paging_mode: PagingMode,
/// Specifies the lines that should be printed
pub line_ranges: LineRanges,
/// The syntax highlighting theme
pub theme: String,
/// File extension/name mappings
pub syntax_mapping: SyntaxMapping,
/// Command to start the pager
pub pager: Option<&'a str>,
/// Whether or not to use ANSI italics
pub use_italic_text: bool,
/// Lines to highlight
pub highlight_lines: Vec<usize>,
}