@@ -77,6 +77,7 @@ fn enumerate_shells() -> Vec<Shell> {
7777 Box :: new( Bash ) ,
7878 Box :: new( Zsh ) ,
7979 Box :: new( Fish ) ,
80+ Box :: new( Nu ) ,
8081 ]
8182}
8283
@@ -255,6 +256,61 @@ impl UnixShell for Fish {
255256 }
256257}
257258
259+ struct Nu ;
260+
261+ impl UnixShell for Nu {
262+ fn does_exist ( & self , process : & Process ) -> bool {
263+ // nu has to either be the shell or be callable for nu setup.
264+ matches ! ( process. var( "SHELL" ) , Ok ( sh) if sh. contains( "nu" ) )
265+ || utils:: find_cmd ( & [ "nu" ] , process) . is_some ( )
266+ }
267+
268+ fn rcfiles ( & self , process : & Process ) -> Vec < PathBuf > {
269+ let p0: Vec < _ > = process
270+ . var ( "XDG_CONFIG_HOME" )
271+ . ok ( )
272+ . iter ( )
273+ . flat_map ( |p| {
274+ let path = PathBuf :: from ( p) . join ( "nushell/" ) ;
275+ [ path. join ( "env.nu" ) , path. join ( "config.nu" ) ]
276+ } )
277+ . collect ( ) ;
278+
279+ let p1: Vec < _ > = process
280+ . home_dir ( )
281+ . iter ( )
282+ . flat_map ( |p| {
283+ let path = PathBuf :: from ( p) . join ( ".config/nushell/" ) ;
284+ [ path. join ( "env.nu" ) , path. join ( "config.nu" ) ]
285+ } )
286+ . collect ( ) ;
287+
288+ [ p0, p1] . concat ( )
289+ }
290+
291+ fn update_rcs ( & self , process : & Process ) -> Vec < PathBuf > {
292+ let mut rcs = self . rcfiles ( process) ;
293+ if rcs. len ( ) == 4 {
294+ // The first two rcfile takes precedence (XDG_CONFIG_HOME).
295+ rcs. truncate ( 2 ) ;
296+ rcs
297+ } else {
298+ rcs
299+ }
300+ }
301+
302+ fn env_script ( & self ) -> ShellScript {
303+ ShellScript {
304+ name : "env.nu" ,
305+ content : include_str ! ( "env.nu" ) ,
306+ }
307+ }
308+
309+ fn source_string ( & self , process : & Process ) -> Result < String > {
310+ Ok ( format ! ( r#"source "{}/env.nu""# , cargo_home_str( process) ?) )
311+ }
312+ }
313+
258314pub ( crate ) fn legacy_paths ( process : & Process ) -> impl Iterator < Item = PathBuf > + ' _ {
259315 let zprofiles = Zsh :: zdotdir ( process)
260316 . into_iter ( )
0 commit comments