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

[email protected] does not disable tkinter on gnu+linux #202570

Closed
4 tasks done
ipatch opened this issue Dec 27, 2024 · 5 comments · Fixed by #203210
Closed
4 tasks done

[email protected] does not disable tkinter on gnu+linux #202570

ipatch opened this issue Dec 27, 2024 · 5 comments · Fixed by #203210
Labels
bug Reproducible Homebrew/homebrew-core bug

Comments

@ipatch
Copy link
Contributor

ipatch commented Dec 27, 2024

brew gist-logs <formula> link OR brew config AND brew doctor output

na

Verification

  • My brew doctor output says Your system is ready to brew. and am still able to reproduce my issue.
  • I ran brew update and am still able to reproduce my issue.
  • I have resolved all warnings from brew doctor and that did not fix my problem.
  • I searched for recent similar issues at https://github.com/Homebrew/homebrew-core/issues?q=is%3Aissue and found no duplicates.

What were you trying to do (and why)?

with my homebrew install on arch linux i run homebrew in a non standard prefix ie. ~/homebrew that said, i believe this issue could effect standard prefix installations of homebrew as well.

What happened (include all command output)?

running brew install [email protected] -v -s will fail.

i think the homebrew ci is able to produce a working bottle because it sets up a fresh homebrew installation to where tcl-tk is not installed in the environment. that said if someone has explicitly installed tcl-tk and then installs [email protected] from source the configure script for python will pick up on the tcl-tk install in the path and attempt to configure [email protected] with tcl-tk support thus running into the tkinter build / linking error.

in the [email protected] formula file there is the below snippet,

 # Disabled modules - provided in separate formulae
    args += %w[
      py_cv_module__tkinter=disabled
    ]

# Disabled modules - provided in separate formulae
args += %w[
py_cv_module__tkinter=disabled
]

that snippet essentially does nothing. one can verify by running the below command,

note: tcl-tk should be installed, ie. brew install tcl-tk

run,

brew install --interactive -v [email protected] -s

open up the config.log do a search for tkinter and notice the values set within the config.log


i ended up using the same technique that macports uses for disabling tcl-tk ie. seen below,

https://github.com/Homebrew/homebrew-core/blob/5024d5b785db171580f43ce223e0eb6a3b6a0c45/patches/python-3.12-disable-tkinter.patch

What did you expect to happen?

a working python installation, ie. a configure build link of python without failure.

Step-by-step reproduction instructions (by running brew commands)

previously mentioned
@ipatch ipatch added the bug Reproducible Homebrew/homebrew-core bug label Dec 27, 2024
@Bo98
Copy link
Member

Bo98 commented Dec 27, 2024

Does n/a work instead of disabled?

@ipatch
Copy link
Contributor Author

ipatch commented Dec 27, 2024

Does n/a work instead of disabled?

hunh? 🤨

@cho-m
Copy link
Member

cho-m commented Jan 1, 2025

Does n/a work instead of disabled?

Should work.


Alternatively/Additionally could always set PKG_CONFIG_LIBDIR on Linux to ignore the default path, e.g.

$ pkg-config tcl --path
/home/linuxbrew/.linuxbrew/lib/pkgconfig/tcl.pc

$ PKG_CONFIG_LIBDIR= pkg-config tcl --path

$ PKG_CONFIG_LIBDIR= PKG_CONFIG_PATH=/home/linuxbrew/.linuxbrew/opt/tcl-tk/lib/pkgconfig pkg-config tcl --path
/home/linuxbrew/.linuxbrew/opt/tcl-tk/lib/pkgconfig/tcl.pc

We do already set this environment variable on macOS, which may be why we experience less opportunistic linkage compared to Linux.

@cho-m
Copy link
Member

cho-m commented Jan 1, 2025

Alternatively/Additionally could always set PKG_CONFIG_LIBDIR on Linux to ignore the default path

Added this to brew in Homebrew/brew#19023. Works for me to prevent unexpected detection of both tcl-tk and util-linux.

Note that some formulae may need to be rebuilt to drop opportunistic linkage (e.g. saw this for freetype when built with brotli already installed).

@cho-m
Copy link
Member

cho-m commented Jan 4, 2025

Adding n/a in #203210, which should ignore all TCL/Tk detection.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Reproducible Homebrew/homebrew-core bug
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants