After installing Rust and Cargo via the following command...
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
I ran cargo build
on a tiny "Hello World" Rust project and got the following error:
= note: ld: library not found for -liconv
collect2: error: ld returned 1 exit status
error: could not compile `hello_world` due to previous error
I've tried rustup self uninstall
then installing Rust and Cargo via brew
, but I get the same error when attempting to build.
I'm running macOS Big Sur 11.6.4.
First step is to install libiconv
via Homebrew:
brew install libiconv
Notice that the output is saying something weird:
==> Caveats
libiconv is keg-only, which means it was not symlinked into /opt/homebrew,
because macOS already provides this software and installing another version in
parallel can cause all kinds of trouble.
If you need to have libiconv first in your PATH, run:
echo 'export PATH="/opt/homebrew/opt/libiconv/bin:$PATH"' >> ~/.zshrc
For compilers to find libiconv you may need to set:
export LDFLAGS="-L/opt/homebrew/opt/libiconv/lib"
export CPPFLAGS="-I/opt/homebrew/opt/libiconv/include"
I haven't been able to piece together a complete explanation, but it is something to do with libiconv
being provided by MacOS in a version that has the wrong symbols. On my system libiconv
can't be found (is it a M1 thing?); nevertheless, brew refuses to step on the OSes' toes, which seems a reasonable decision.
These variables do not apply to cargo
however.
The best way to solve the problem (that I found) is to modify your LIBRARY_PATH
variable to provide path to iconv. You might have already had to modify your LIBRARY_PATH
(see e.g. https://apple.stackexchange.com/questions/40704/homebrew-installed-libraries-how-do-i-use-them).
What I did was to add the following line to my ~/.zshrc
:
export LIBRARY_PATH=$LIBRARY_PATH:$(brew --prefix)/lib:$(brew --prefix)/opt/libiconv/lib
Afterwards libiconv
is detected correctly.