mirror of
https://github.com/sharkdp/bat.git
synced 2025-01-11 16:18:21 +01:00
Move Config,PagingMode from app.rs into lib.rs
This commit is contained in:
parent
a2ee753b25
commit
26439b41d2
@ -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")
|
||||||
|
@ -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> {
|
||||||
|
@ -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<()> {
|
||||||
|
@ -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),
|
||||||
|
@ -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 {
|
||||||
|
67
src/lib.rs
67
src/lib.rs
@ -52,4 +52,71 @@ 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>,
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user