mirror of
https://github.com/sharkdp/bat
synced 2024-11-24 04:43:07 +00:00
Pass stdin as a generic BufRead, fix stdin tests
This commit is contained in:
parent
d5a31dc2ec
commit
1b8ce60054
3 changed files with 17 additions and 8 deletions
|
@ -271,7 +271,7 @@ mod tests {
|
|||
let syntax = self.assets.get_syntax(
|
||||
None,
|
||||
input_file,
|
||||
&mut input_file.get_reader(&io::stdin()).unwrap(),
|
||||
&mut input_file.get_reader(io::stdin().lock()).unwrap(),
|
||||
&self.syntax_mapping,
|
||||
);
|
||||
|
||||
|
@ -281,6 +281,17 @@ mod tests {
|
|||
fn syntax_for_file(&self, file_name: &str) -> String {
|
||||
self.syntax_for_file_with_content(file_name, "")
|
||||
}
|
||||
|
||||
fn syntax_for_stdin_with_content(&self, file_name: &str, content: &[u8]) -> String {
|
||||
let input_file = InputFile::StdIn(Some(OsStr::new(file_name)));
|
||||
let syntax = self.assets.get_syntax(
|
||||
None,
|
||||
input_file,
|
||||
&mut input_file.get_reader(content).unwrap(),
|
||||
&self.syntax_mapping,
|
||||
);
|
||||
syntax.name.clone()
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
@ -353,10 +364,10 @@ mod tests {
|
|||
let test = SyntaxDetectionTest::new();
|
||||
|
||||
// from file extension
|
||||
assert_eq!(test.syntax_for_file_with_content("test.cpp", ""), "C++");
|
||||
assert_eq!(test.syntax_for_stdin_with_content("test.cpp", b"a"), "C++");
|
||||
// from first line (fallback)
|
||||
assert_eq!(
|
||||
test.syntax_for_file_with_content("my_script", "#!/bin/bash"),
|
||||
test.syntax_for_stdin_with_content("my_script", b"#!/bin/bash"),
|
||||
"Bourne Again Shell (bash)"
|
||||
);
|
||||
}
|
||||
|
|
|
@ -56,10 +56,8 @@ impl<'b> Controller<'b> {
|
|||
let writer = output_type.handle()?;
|
||||
let mut no_errors: bool = true;
|
||||
|
||||
let stdin = io::stdin();
|
||||
|
||||
for input_file in self.config.files.iter() {
|
||||
match input_file.get_reader(&stdin) {
|
||||
match input_file.get_reader(io::stdin().lock()) {
|
||||
Err(error) => {
|
||||
handle_error(&error);
|
||||
no_errors = false;
|
||||
|
|
|
@ -86,9 +86,9 @@ pub enum InputFile<'a> {
|
|||
}
|
||||
|
||||
impl<'a> InputFile<'a> {
|
||||
pub(crate) fn get_reader(&self, stdin: &'a io::Stdin) -> Result<InputFileReader> {
|
||||
pub(crate) fn get_reader<R: BufRead + 'a>(&self, stdin: R) -> Result<InputFileReader> {
|
||||
match self {
|
||||
InputFile::StdIn(_) => Ok(InputFileReader::new(stdin.lock())),
|
||||
InputFile::StdIn(_) => Ok(InputFileReader::new(stdin)),
|
||||
InputFile::Ordinary(ofile) => {
|
||||
let file = File::open(ofile.path)
|
||||
.map_err(|e| format!("'{}': {}", ofile.path.to_string_lossy(), e))?;
|
||||
|
|
Loading…
Reference in a new issue