mirror of
				https://github.com/sharkdp/bat.git
				synced 2025-10-24 20:53:55 +01:00 
			
		
		
		
	Fix #1413 Can't use bat at all! (Error: Use of bat as a pager is disallowed...)
				
					
				
			Fixed by implementing the proposal by sharkdp: * Allow PAGER=bat, but ignore the setting in bat and simply default to less. Unless of course, BAT_PAGER or --pager is used to overwrite the value of PAGER. * Disallow the usage of bat within BAT_PAGER and --pager.
This commit is contained in:
		
				
					committed by
					
						 David Peter
						David Peter
					
				
			
			
				
	
			
			
			
						parent
						
							060b9981b5
						
					
				
				
					commit
					dd0d44bbb3
				
			
							
								
								
									
										18
									
								
								src/pager.rs
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								src/pager.rs
									
									
									
									
									
								
							| @@ -98,10 +98,20 @@ pub(crate) fn get_pager(config_pager: Option<&str>) -> Result<Option<Pager>, Par | |||||||
|         Some((bin, args)) => { |         Some((bin, args)) => { | ||||||
|             let kind = PagerKind::from_bin(bin); |             let kind = PagerKind::from_bin(bin); | ||||||
|  |  | ||||||
|             // 'more' and 'most' do not supports colors; automatically use 'less' instead |             let use_less_instead = match source { | ||||||
|             // if the problematic pager came from the generic PAGER env var |                 PagerSource::EnvVarPager => { | ||||||
|             let no_color_support = kind == PagerKind::More || kind == PagerKind::Most; |                     // 'more' and 'most' do not supports colors; automatically use 'less' instead | ||||||
|             let use_less_instead = no_color_support && source == PagerSource::EnvVarPager; |                     // if the problematic pager came from the generic PAGER env var | ||||||
|  |                     let no_color_support = kind == PagerKind::More || kind == PagerKind::Most; | ||||||
|  |  | ||||||
|  |                     // If PAGER=bat, silently use 'less' instead to prevent recursion ... | ||||||
|  |                     let is_self = kind == PagerKind::Bat; | ||||||
|  |  | ||||||
|  |                     no_color_support || is_self | ||||||
|  |                 }, | ||||||
|  |                 // Never silently replace with less if bat-specific means to set a pager is used | ||||||
|  |                 _ => false | ||||||
|  |             } ; | ||||||
|  |  | ||||||
|             Ok(Some(if use_less_instead { |             Ok(Some(if use_less_instead { | ||||||
|                 let no_args = vec![]; |                 let no_args = vec![]; | ||||||
|   | |||||||
| @@ -499,6 +499,28 @@ fn pager_disable() { | |||||||
|         .stdout(predicate::eq("hello world\n").normalize()); |         .stdout(predicate::eq("hello world\n").normalize()); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #[test] | ||||||
|  | fn env_var_pager_value_bat() { | ||||||
|  |     bat() | ||||||
|  |         .env("PAGER", "bat") | ||||||
|  |         .arg("--paging=always") | ||||||
|  |         .arg("test.txt") | ||||||
|  |         .assert() | ||||||
|  |         .success() | ||||||
|  |         .stdout(predicate::eq("hello world\n").normalize()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #[test] | ||||||
|  | fn env_var_bat_pager_value_bat() { | ||||||
|  |     bat() | ||||||
|  |         .env("BAT_PAGER", "bat") | ||||||
|  |         .arg("--paging=always") | ||||||
|  |         .arg("test.txt") | ||||||
|  |         .assert() | ||||||
|  |         .failure() | ||||||
|  |         .stderr(predicate::str::contains("bat as a pager is disallowed")); | ||||||
|  | } | ||||||
|  |  | ||||||
| #[test] | #[test] | ||||||
| fn pager_value_bat() { | fn pager_value_bat() { | ||||||
|     bat() |     bat() | ||||||
| @@ -506,7 +528,8 @@ fn pager_value_bat() { | |||||||
|         .arg("--paging=always") |         .arg("--paging=always") | ||||||
|         .arg("test.txt") |         .arg("test.txt") | ||||||
|         .assert() |         .assert() | ||||||
|         .failure(); |         .failure() | ||||||
|  |         .stderr(predicate::str::contains("bat as a pager is disallowed")); | ||||||
| } | } | ||||||
|  |  | ||||||
| /// We shall use less instead of most if PAGER is used since PAGER | /// We shall use less instead of most if PAGER is used since PAGER | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user