-
Notifications
You must be signed in to change notification settings - Fork 72
Can't install via homebrew-neovim if luarocks path is set explicitly #149
Comments
@justinmk I've tried a full reinstall (including clearing the cache completely), and it does not help. mpack currently doesn't install on OSX for me, and I suspect that's the underlying problem. |
Left a comment at libmpack/libmpack#2. I think we require one of luajit or lua 5.1 for now. |
luajit could still be trouble since if I'm reading the build output from above correctly, when it attempts to use luajit, that fails because of lpeg. (But maybe I'm misunderstanding what's happening at that point in the build.)
|
@justinmk Per your request in Gitter, here's a verbose log: https://gist.github.com/telemachus/fe078934942bdcc2a0e86319de5e1148 |
After uninstalling everything related to Lua, I was finally able to build neovim. I'm still not sure what happened to my environment, but I'll close this for now. |
@telemachus Thanks for followup. |
@justinmk et al. I've just reopened this, because after some more testing I'm very confused. Here's where things stand right now: I can install neovim, but only if I uninstall everything else related to Lua first. I don't think that should be required, and obviously, the Travis CI testing won't catch it, since (I assume) each Travis build starts with a fresh clean image without a previous Lua install. So, in a nutshell, my question is this: Is it expected that neovim should fail if you already have Lua installed on OSX? If not, what can I test in order to see what's wrong with my setup? Thanks. |
Jumping in here real quick. I would say no, it's not expected. In fact, we got through some trouble to make sure that our deps are picked up before system ones. Looking at your verbose log, it appears that something went wrong when checking for the necessary modules or the lpeg module was not built correctly for some reason:
It tried to use our toolchain first, but something isn't right with the lpeg package. And it looks like it built:
So maybe something is wrong with our detection scheme or maybe lpeg is not being loaded correctly with the new toolchain. It could be that a dependency needs to be updated, or there is something that needs to be fixed upstream. I would start there first. |
@jszakmeister To clarify: you're suggesting that I post this directly to neovim rather than here? That's fine if so, I just want to be sure. (My obvious worry being that they will simply say "Oh that must be related to hombrew or OSX...") Thanks. |
Not necessarily. I don't think we can say either way yet. Homebrew alters the build environment pretty substantially, and it could be something Homebrew is doing too. What I'm suggesting is that you dig in a little and see if you can figure a little more out about what is failing in the lpeg detection. This might mean building Neovim yourself so you can capture a bit more about what is going on. If it's too much to ask, then hopefully someone else can come along and help figure it out. Bandwidth is limited though, so any help you can provide is useful. |
FWIW, I just updated, installed Lua via Homebrew, and then installed Neovim via Homebrew with 0 issues. It detected my interpreter just fine:
|
@jszakmeister Ah, ok, I'm fine trying whatever, but to be honest I'm not sure how I would dig in myself. But I can start with what you suggest: building neovim itself (outside of homebrew) with lua installed via homebrew. Now that I think of it, I can also check what happens if I have lua installed but not lpeg. I can say right away that I tried manually building neovim over last weekend (when this problem began for me), and the build failed then too. So I suspect it's probably also an upstream problem. If I can confirm that kind of failure, I'll report directly to neovim and cc this issue. For the moment, though, I'm going to leave this open since other people may find it helpful if they see failed builds with lua (and lpeg) installed. Re: your update, maybe try uninstalling neovim, installing lpeg, and then reinstall neovim again? EDIT: Nope, it's worse than that. I have lua and only lpeg, and neovim will still build. It must be some larger combination of the rocks I had installed. I'll keep experimenting today and over the weekend and update this if I figure out anything. |
I wish I had more advice to give here. Often I start in the same boat and just keep scratching at the problem until flakes start coming off. :-)
I don't think it will help. It finds the deps-provided Lua first, and it satisfies everything, so it doesn't even look at the other Lua I installed. (time passes) So I tried it anyways, and I saw no difference. I picks up our Lua first as I suspected. |
@jszakmeister I appreciate your taking the time. This is very tedious and no fun. I'm now in the process of going through the rocks I normally have installed one by one, trying to figure out what gums up the works—though I can't for the life of me see how a rock could break a separate build. |
@justinmk @jszakmeister Ok, I solved my problem. (I'm changing the title again, hopefully for the last time, to focus on the problem.) The issue was this in my bash profile:
That was set, per advice of I'm not going to immediately close this though, because maybe this is something that homebrew's and/or neovim's build process should handle. That is, as part of clearing away a user's personal environment, maybe one (or both) should also handle the In any case, thanks for your patience and all your help. |
I struggle with the concept of the build system clearing away the personal environment. One reason is because there's no easy way for us to do it, but another is because I'm not sure it's always the right thing to do. Distros pass quite a lot through the environment building packages, and we'd potentially get in the way of that. The downside is that things can misbehave. In short, I'm not sure how we want to handle this, or if we even do want to handle it. Perhaps if the lua interpreter that we pick is our deps version, maybe we could clear the associated environment variable?
I'm really not sure what would have changed here that caused it to be picked up all of a sudden. :-(
You're welcome! And likewise: thanks for sticking to it and figuring it out. I'm sure it will help someone down the road at the very least. |
@telemachus Maybe try
|
I'm facing the same issue. ~ $ brew install neovim
==> Installing neovim from neovim/neovim
==> Downloading https://github.com/neovim/neovim/archive/v0.1.7.tar.gz
Already downloaded: /Users/owais/Library/Caches/Homebrew/neovim-0.1.7.tar.gz
==> Downloading https://github.com/luvit/luv/archive/146f1ce4c08c3b67f604c9ee1e124b1cf5c15cf3.tar.gz
Already downloaded: /Users/owais/Library/Caches/Homebrew/neovim--luv-3.tar.gz
==> Downloading https://raw.githubusercontent.com/neovim/deps/master/opt/LuaJIT-2.0.4.tar.gz
Already downloaded: /Users/owais/Library/Caches/Homebrew/neovim--luajit-2.0.4.tar.gz
==> Downloading https://github.com/keplerproject/luarocks/archive/5d8a16526573b36d5b22aa74866120c998466697.tar.gz
Already downloaded: /Users/owais/Library/Caches/Homebrew/neovim--luarocks-998466697.tar.gz
==> Building third-party dependencies.
==> cmake ../third-party -DUSE_BUNDLED_BUSTED=OFF -DUSE_BUNDLED_GPERF=OFF -DUSE_BUNDLED_LIBUV=OFF -DUSE_BUNDLED_MSGPACK=OFF -DUSE_BUNDLED_UNIBILIUM=OFF -
==> make VERBOSE=1
Last 15 lines from /Users/owais/Library/Logs/Homebrew/neovim/02.make:
make[3]: *** [all] Error 2
make[2]: *** [build/src/luv-static-stamp/luv-static-build] Error 2
make[1]: *** [CMakeFiles/luv-static.dir/all] Error 2
make[1]: *** Waiting for unfinished jobs....
No existing manifest. Attempting to rebuild...
Updating manifest for /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/usr/lib/luarocks/rocks
luarocks scm-1 is now built and installed in /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/usr (license: MIT/X11)
cd /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/build/src/luarocks && /usr/local/Cellar/cmake/3.7.1/bin/cmake -E touch /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/build/src/luarocks-stamp/luarocks-install
[ 81%] Completed 'luarocks'
/usr/local/Cellar/cmake/3.7.1/bin/cmake -E make_directory /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/CMakeFiles
/usr/local/Cellar/cmake/3.7.1/bin/cmake -E touch /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/CMakeFiles/luarocks-complete
/usr/local/Cellar/cmake/3.7.1/bin/cmake -E touch /tmp/neovim-20170103-37840-162fxtv/neovim-0.1.7/deps-build/build/src/luarocks-stamp/luarocks-done
[ 81%] Built target luarocks
make: *** [all] Error 2
If reporting this issue please do so at (not Homebrew/brew or Homebrew/core):
https://github.com/neovim/homebrew-neovim/issues
These open issues may also help:
Can't install via homebrew-neovim if luarocks path is set explicitly https://github.com/neovim/homebrew-neovim/issues/149
~ $ |
Turning up verbosity revealed that luv build was failing because of missing brew uninstall libuv
brew install libuv |
for what it's worth i |
I had to |
@RichardJohnn @amckinlay That was my experience too. |
Certainly we should do that in the brew formula at least. Even in core cmake it should be fine to do that , just print some info message mentioning it. |
I believe that this is related to the following two issues, but I wanted to post it here as well, in case other people are seeing the same problems.
Related issues:
Failied build output:
The text was updated successfully, but these errors were encountered: