Merge pull request #2486 from Kingtous/master
opt: display server detection in env without loginctl
This commit is contained in:
		
						commit
						06510ffa22
					
				| @ -363,8 +363,6 @@ class FileModel extends ChangeNotifier { | ||||
|     if (_currentRemoteDir.path.isEmpty) { | ||||
|       openDirectory(_remoteOption.home, isLocal: false); | ||||
|     } | ||||
|     // load last transfer jobs | ||||
|     await bind.sessionLoadLastTransferJobs(id: '${parent.target?.id}'); | ||||
|   } | ||||
| 
 | ||||
|   Future<void> onClose() async { | ||||
|  | ||||
| @ -43,7 +43,8 @@ pub fn get_display_server() -> String { | ||||
| } | ||||
| 
 | ||||
| fn get_display_server_of_session(session: &str) -> String { | ||||
|     if let Ok(output) = run_loginctl(Some(vec!["show-session", "-p", "Type", session])) | ||||
|     let mut display_server = if let Ok(output) = | ||||
|         run_loginctl(Some(vec!["show-session", "-p", "Type", session])) | ||||
|     // Check session type of the session
 | ||||
|     { | ||||
|         let display_server = String::from_utf8_lossy(&output.stdout) | ||||
| @ -76,17 +77,20 @@ fn get_display_server_of_session(session: &str) -> String { | ||||
|                 display_server | ||||
|             } | ||||
|         } else { | ||||
|             // loginctl has not given the expected output.  try something else.
 | ||||
|             if let Ok(sestype) = std::env::var("XDG_SESSION_TYPE") { | ||||
|                 return sestype.to_owned(); | ||||
|             } | ||||
|             // If the session is not a tty, then just return the type as usual
 | ||||
|             display_server | ||||
|             "".to_owned() | ||||
|         } | ||||
|     } else { | ||||
|         "".to_owned() | ||||
|     }; | ||||
|     if display_server.is_empty() { | ||||
|         // loginctl has not given the expected output.  try something else.
 | ||||
|         if let Ok(sestype) = std::env::var("XDG_SESSION_TYPE") { | ||||
|             display_server = sestype; | ||||
|         } | ||||
|     } | ||||
|     // If the session is not a tty, then just return the type as usual
 | ||||
|     display_server | ||||
| } | ||||
| 
 | ||||
| pub fn get_values_of_seat0(indices: Vec<usize>) -> Vec<String> { | ||||
|     if let Ok(output) = run_loginctl(None) { | ||||
| @ -126,8 +130,7 @@ pub fn get_values_of_seat0(indices: Vec<usize>) -> Vec<String> { | ||||
| } | ||||
| 
 | ||||
| fn is_active(sid: &str) -> bool { | ||||
|     if let Ok(output) = run_loginctl(Some(vec!["show-session", "-p", "State", sid])) | ||||
|     { | ||||
|     if let Ok(output) = run_loginctl(Some(vec!["show-session", "-p", "State", sid])) { | ||||
|         String::from_utf8_lossy(&output.stdout).contains("active") | ||||
|     } else { | ||||
|         false | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user