Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can't find nix-shell after installationon mac OS X #2280

Open
bergmark opened this issue Jul 6, 2018 · 28 comments
Open

Can't find nix-shell after installationon mac OS X #2280

bergmark opened this issue Jul 6, 2018 · 28 comments

Comments

@bergmark
Copy link

bergmark commented Jul 6, 2018

On Mac OS X (10.11.6) I ran curl https://nixos.org/nix/install | sh which downloaded https://nixos.org/releases/nix/nix-2.0.4/nix-2.0.4-x86_64-darwin.tar.bz2

On completion this was printed:

Before Nix will work in your existing shells, you'll need to close
them and open them again. Other than that, you should be ready to go.

Try it! Open a new terminal, and type:

  $ nix-shell -p nix-info --run "nix-info -m"

I started a new shell but nix-shell is not on my PATH in fish nor in bash

$ nix-shell
fish: Unknown command 'nix-shell'
$ bash
$ nix-shell
bash: nix-shell: command not found

I found nix-shell in /nix but could not start it:

$ /nix/store/771l8i0mz4c8kry8cz3sz8rr3alalckg-nix-2.0.4/bin/nix-shell -p nix-info --run "nix-info -m"
error: file 'nixpkgs' was not found in the Nix search path (add it using $NIX_PATH or -I), at (string):1:13

Should the post-install instructions be updated? Are there any additional steps needed to get nix-shell to run?

@neon64
Copy link

neon64 commented Jul 8, 2018

I'm struggling with this issue too. As far as I'm aware, when a login shell starts, it loads certain init scripts like /etc/bashrc or /etc/profile. The nix installer adds new stuff to these scripts so that nix tools like nix-shell can be found. This means:

  1. you need to open a new terminal window for these init scripts to be run again
  2. these scripts are specific to the type of shell you're running. It appears as if nix has built in support for bash and zsh, but not fish: see Installing doesnt work under fish shell #1512 for previous discussion on this.

@zenspider
Copy link

Same boat, but I'm using bash as my shell. It seems to never actually modify PATH and other things aren't quite working right either. I eventually "uninstalled", even tho that's not a thing either. It would be nice if there was a real cleanup script in the base.

@2mol
Copy link

2mol commented Aug 5, 2018

Same problem here, and I'm running bash. I figured out after a while that the ~/.nix-profile was missing or broken (~/.nix-profile/bin is supposed to be added to your PATH).

You can hack-fix it by symlinking to /nix/var/nix/profiles/default, but no guarantee that that results in a clean install.

Seems kinda related to #2295

@janek
Copy link

janek commented Mar 27, 2019

Is this currently still broken? Are there any good workarounds?

@zenspider
Copy link

Dunno. After zero support here and anti-support in IRC I gave up. Just not worth the apathy and hostility to deal with it.

@ryanorendorff
Copy link

ryanorendorff commented Apr 22, 2019

There seems to be a case where the installer script modifies .profile but that file is not sourced correctly. For my case, after installation I got this message (with $HOME filled in).

Installation finished!  To ensure that the necessary environment
variables are set, either log in again, or type

  . $HOME/.nix-profile/etc/profile.d/nix.sh

in your shell.

However I am using zsh, which does not load .profile automatically. Hence I had to add the line . $HOME/.nix-profile/etc/profile.d/nix.sh to something zsh executes (.zshrc).

The installer script seems to assume you are using bash. The culprit appears to be this line, which doesn't look for any other shells than bash (and only specific bash files that aren't guaranteed to be there) or shells that source .profile.

for i in .bash_profile .bash_login .profile; do

Below is the problem line in context for the macOS installer.

if [ -z "$NIX_INSTALLER_NO_MODIFY_PROFILE" ]; then

    # Make the shell source nix.sh during login.
    p=$HOME/.nix-profile/etc/profile.d/nix.sh

    for i in .bash_profile .bash_login .profile; do # <-- This is the problematic line
        fn="$HOME/$i"
        if [ -w "$fn" ]; then
            if ! grep -q "$p" "$fn"; then
                echo "modifying $fn..." >&2
                echo "if [ -e $p ]; then . $p; fi # added by Nix installer" >> "$fn"
            fi
            added=1
            break
        fi
    done

fi

@zenspider Hopefully this helps.

@rreimche
Copy link

I've had the same problem on a fresh Ubuntu 19.10 and the problem was gone as soon as I've rebooted.

@xeruf
Copy link

xeruf commented Oct 20, 2020

Yep, similar thing here. On my system the /etc/zshrc doesn't exist, so opening a new terminal or zsh session didn't help.

Instead, I had to log out and back in, which loaded the appropriate PATH from /etc/profile.d/nix.sh

@stale
Copy link

stale bot commented Jun 3, 2021

I marked this as stale due to inactivity. → More info

@stale stale bot added the stale label Jun 3, 2021
@xeruf
Copy link

xeruf commented Jun 3, 2021

Should be fixable by adjusting the PATH after finishing installation

@jimmy-jos
Copy link

https://stackoverflow.com/a/54087505/6341943
This seems to work for me

@drod3763
Copy link

However I am using zsh, which does not load .profile automatically. Hence I had to add the line . $HOME/.nix-profile/etc/profile.d/nix.sh to something zsh executes (.zshrc).

This is what got it to work for me. I think that the installer script just assumes you use bash and doesn't account for the files loaded by zsh.

@keithy
Copy link

keithy commented Mar 17, 2022

zsh is standard on mac OS now

@didier-ivado
Copy link

I had this issue after upgrading my macOS version. Personally, I am using home-manager with flake (not 100% sure what it means). To solve my issue, I needed to add the below snippet at the bottom of /etc/zshrc

# Nix
if [ -e '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' ]; then
  . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'
fi
# End Nix

@CMCDragonkai
Copy link
Member

You must use sudo vim /etc/zshrc to add it. I think a recent macos update replaced the /etc/zshrc, so it has to added in again.

@joelparkerhenderson
Copy link

Same issue on macOS 12.5.1 with typical zsh shell.

$ nix-shell
zsh: command not found: nix-shell

I verified the Nix installer appended the file /etc/zshrc:

$ tail /etc/zshrc
# Nix
if [ -e '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' ]; then
  . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'
fi
# End Nix

I verified the Nix installer created the file:

$ ls /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh
/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh

I verified the Nix daemon is running:

$ ps aux | grep nix-daemon
root             14409   0.0  0.0 409085616  21568   ??  Ss    1:07PM   0:00.06 /nix/var/nix/profiles/default/bin/nix-daemon

What's next please?

@99Percent
Copy link

if you have used nix itself to install zsh and ran the install script within zsh you will need to go back to editing the .bashrc and add the nix-daemon.sh line since you will be using bash instead of zsh again

@sjbodzo
Copy link

sjbodzo commented Oct 4, 2022

In case anyone else stumbles upon this after a MacOS upgrade (it hit me upgrading to Monterey 12.6), in the install/uninstall documentation it mentions the file to source, as shown above: https://nixos.org/manual/nix/stable/installation/installing-binary.html#macos

# Nix
if [ -e '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' ]; then
  . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'
fi
# End Nix

My preference is to override any system-wide setting with my user $HOME/.zshrc.

@half0wl
Copy link

half0wl commented Apr 24, 2023

I have the same issue on macOS Ventura 13.2 (22D49) + zsh on a fresh install through $ sh <(curl -L https://nixos.org/nix/install).

I've confirmed that:

  • nix-daemon is running
  • /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh exists
  • nix-daemon.sh is sourced in both /etc/zshrc and $HOME/zsh.rc.

I've tried:

  • rebooting
  • restarting Terminal
  • re-installing (uninstalled using instructions in https://nixos.org/manual/nix/stable/installation/installing-binary.html#macos)
  • changing . to source:
    - . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'
    + source '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'
  • source-ing manually:
    $ source /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh
    $ nix-shell
    zsh: command not found: nix-shell
    $ . /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh
    $ nix-shell
    zsh: command not found: nix-shell
  • adding /nix/var/nix/profiles/default/bin to $PATH:
    $ nix-shell
    error: getting status of '/Users/me/default.nix': No such file or directory
  • using bash, same issue
  • using stock Terminal.app, same issue

Any ideas on what next?

edit

I fixed this by commenting out the lines that short-circuits on __ETC_PROFILE_NIX_SOURCED=1 in /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh:

# file: /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh

# Only execute this file once per shell.
- if [ -n "${__ETC_PROFILE_NIX_SOURCED:-}" ]; then return; fi
- __ETC_PROFILE_NIX_SOURCED=1
+ # if [ -n "${__ETC_PROFILE_NIX_SOURCED:-}" ]; then return; fi
+ # __ETC_PROFILE_NIX_SOURCED=1

Unsure why this happens 🤷🏻‍♂️ __ETC_PROFILE_NIX_SOURCED probably got unintendedly set to 1 somewhere along the line.

@webpro
Copy link

webpro commented May 23, 2023

Just chiming in to say adding this your PATH somewhere might be enough, without editing /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh:

export PATH="$NIX_LINK/bin:/nix/var/nix/profiles/default/bin:$PATH"

@dylanarmstrong
Copy link

dylanarmstrong commented Jun 28, 2023

Also chiming in to say I fixed it by adding it to my local zshrc and adding this UNSET line:

# Nix
if [ -e '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh' ]; then
  unset __ETC_PROFILE_NIX_SOURCED
  . '/nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh'
fi
# End Nix

@zchdeepak
Copy link

I had the same issue after upgrading to macOS ventura 13.5, and fixed it by adding the following line:

source $HOME/.nix-profile/etc/profile.d/nix.sh to my .zprofile (you can also add it to .zshrc)

I got this from the docs: https://nixos.org/manual/nix/stable/installation/env-variables#environment-variables

@sourcec0de
Copy link

I would recommend re-running the Nix installer.
It walks through cleaning up system files from previous installations and brings the system back into the correct state.
In my case, I actually lost $HOME/.nix-profile/etc/.

@chevdor
Copy link

chevdor commented Oct 16, 2023

Ran into this as well and the hints from answers above (@2mol @ryanorendorff) did help me move forward.

Short version:

  • after install (MacOS Sonoma + zsh) , nix-shell is not found
  • ln -s /nix/var/nix/profiles/default ~/.nix-profile
  • edit your .bashrc or .zshrc with: . $HOME/.nix-profile/etc/profile.d/nix.sh

now nix-shell -p nix-info --run "nix-info -m" (assuming you have internet connection) does run

@tbarbugli
Copy link

tbarbugli commented Oct 18, 2023

same issue for me, @chevdor solution worked for me. I use OSX 13.4.1 and zsh and used sh <(curl -L https://nixos.org/nix/install) to install nix and got no errors/warnings from it (TBH the install tools is so verbose that it would be easy to miss important information)

@fred-snyder
Copy link

I would recommend re-running the Nix installer. It walks through cleaning up system files from previous installations and brings the system back into the correct state. In my case, I actually lost $HOME/.nix-profile/etc/.

I upgraded macOS from version 13 to 14, and I confirm that reinstalling restored my Nix environment. Thanks!

@hsteinshiromoto
Copy link

https://stackoverflow.com/a/54087505/6341943 This seems to work for me

The answer https://stackoverflow.com/a/73799336 from this question solved my problem.

@craigfurman
Copy link

I had this issue because my ~/.zshrc was unsetting PATH, thereby undoing the nix path setup in /nix/var/nix/profiles/default/etc/profile.d/nix-daemon.sh, sourced by /etc/zshrc after the installer modified that file.

Specifically, I had this stanza:

if [ -x /usr/libexec/path_helper ]; then
  unset PATH
  unset MANPATH
  eval `/usr/libexec/path_helper -s`
fi

I have absolutely no idea why, and have no memory of writing this. Maybe it's a default on mac, oh-my-zsh, something else? Either way, if you have unset PATH in a shell profile that executes after /etc/zshrc, consider removing it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests