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

Project fails to build on macOS Sonoma 14.1.1 (arm64) #60

Open
2 tasks
Nezteb opened this issue Dec 9, 2023 · 5 comments
Open
2 tasks

Project fails to build on macOS Sonoma 14.1.1 (arm64) #60

Nezteb opened this issue Dec 9, 2023 · 5 comments
Labels
bug Something isn't working

Comments

@Nezteb
Copy link

Nezteb commented Dec 9, 2023

Bug report

  • I confirm this is a bug with Supabase, not with my own application.
  • I confirm I have searched the Docs, GitHub Discussions, and Discord.

FYI to the maintainers, the above bullet points for this issue template still reference Supabase directly, not postgres_lsp. 😄

Describe the bug

I was trying to follow the "building from source" section of the docs:

  • I ran git submodule update --init --recursive and verified the submodule was populated correctly.
  • Then I ran cargo xtask install but it eventually errored; see output below.
❯ cargo xtask install
...
...
...
$ cargo install --path crates/postgres_lsp --locked --force
...
...
...
error[E0554]: `#![feature]` may not be used on the stable release channel
  --> crates/parser/src/lib.rs:18:12
   |
18 | #![feature(lazy_cell, is_sorted)]
   |            ^^^^^^^^^

error[E0554]: `#![feature]` may not be used on the stable release channel
  --> crates/parser/src/lib.rs:18:23
   |
18 | #![feature(lazy_cell, is_sorted)]
   |                       ^^^^^^^^^

For more information about this error, try `rustc --explain E0554`.
error: could not compile `parser` (lib) due to 2 previous errors
warning: build failed, waiting for other jobs to finish...
error: failed to compile `postgres_lsp v0.0.0 (/Users/noah/Git/postgres_lsp/crates/postgres_lsp)`, intermediate artifacts can be found at `/Users/noah/Git/postgres_lsp/target`
Error: install server

Caused by:
    command exited with non-zero code `cargo install --path crates/postgres_lsp --locked --force`: 101

I'm relatively unfamiliar with Rust and its tooling; I found an SO thread online but the suggested fix is to just install the nightly version of Rust/cargo? That feels odd to me, so I'll wait for maintainer feedback. 😅

System information

  • macOS Sonoma 14.1.1
  • asdf package manager with asdf-rust plugin
❯ asdf plugin list --refs --urls
╭────┬────────────┬─────────────────────────────────────────────────────┬────────┬─────────╮
│  # │    name    │                     repository                      │ branch │   ref   │
├────┼────────────┼─────────────────────────────────────────────────────┼────────┼─────────┤
│  0 │ nodejs     │ https://github.com/asdf-vm/asdf-nodejs.git          │ master │ 150ec5d │
│  1 │ rust       │ https://github.com/code-lever/asdf-rust.git         │ master │ 95acf4f │
╰────┴────────────┴─────────────────────────────────────────────────────┴────────┴─────────╯
❯ rustc --version
rustc 1.71.1 (eb26296b5 2023-08-03)

❯ cargo --version
cargo 1.71.1 (7f1d04c00 2023-07-29)

❯ node --version
v18.15.0

Additional context

I ended up here because I was reminded about postgres_lsp from a related HN thread posted today.

@Nezteb Nezteb added the bug Something isn't working label Dec 9, 2023
@Nezteb
Copy link
Author

Nezteb commented Dec 9, 2023

Reading more, I'm guessing this project requires the nightly Rust build for the time being and that's just how it is. Keyword is "guessing", hence why I'm not closing this issue yet. 😄

As for how to prevent newcomers from hitting this in the future, I did find docs about how to specify which Rust release channel to use for a project.

@psteinroe
Copy link
Collaborator

Hey @Nezteb, thanks for opening the issue. You are right, we are currently using two nightly features of rust and thereby require the nightly channel to be used. It seems like I forgot to update the Readme. Will do so later. For now, first install rustup. You can then install nightly rust with
rustup-init --default-toolchain nightly -y.

@nicoabie
Copy link

nicoabie commented Dec 15, 2023

This is very interesting. I installed rustup

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

I had no issues running the commands in the readme but if I try to run rustup-init says command not found

rustup is a command but not rustup-init

@psteinroe
Copy link
Collaborator

hey @nicoabie, can you check if cargo or rustc are available on your system? I have installed rustup with homebrew and it works fine - maybe you need some additional setup when installing it via curl.

@nicoabie
Copy link

I have both cargo and rustc.

The difference relies in that it seems you installed rustup with homebrew and I followed the instructions on the website
https://www.rust-lang.org/learn/get-started

The website does not tell you to use homebrew.

Probably the homebrew formula is old and has the deprecated rustup-init command

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants