-
-
Notifications
You must be signed in to change notification settings - Fork 510
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
SPKG that only build executables or data: Replace spkg-install
by conda
#35583
Comments
I don't think the criterion should be whether an spkg is only used by calling its executable. It also matters which libraries are link dependencies of the executable. A self-contained binary distribution, like our macOS binary, cannot include an executable which depends on a library unless it also includes that library. And that could require being forced to include multiple versions of the same library, possibly a large one. For example the frobby executable is linked against libgmp and libgmpxx, as are many spkgs that are not on that list. If you are going to copy the frobby executable binary from conda you will need to be sure that Sage and conda are using the same version of libgmp. You will probably also need to adjust the rpath of the executable, although that is something that we already have to do in order to make the macOS app relocatable. Incidentally, the rpath situation in Sage on macOS is a total mess. almost all executables end up being built with two or three copies of the same rpath, sometimes with other, incorrect, rpaths mixed in. I think this plan is teetering on the brink of that dark place known as DLL Hell. We should proceed with caution. |
We're not copying binaries from conda; we have a conda environment in Yes, there will likely be two copies of basic libraries such as libgmp. The size of the duplication should certainly be one of the criteria for deciding which packages we get from conda instead of building them ourselves. |
I would just like to introduce the two elephants I see in this room. The first elephant is the maxim "If it ain't broke then don't fix it." Or, as paraphased by Matthias, "Best practices dictate to not create real problems by addressing imaginary problems." An spkg which builds without issues and works correctly is not broken and should not be "fixed". Especially, it should not be "fixed" under the guise of reducing maintenance. No maintenance is the least amount of maintenance possible. The wise thing to do is to wait until an optional package actually causes trouble before you change it. The second elephant is the principle, a core principle of the sage project I am told, that including multiple copies or, worse, versions of the same library is evil. Why else would it be so important to the project to try to use system versions of libraries whenever possible. I remember, long ago, when I proposed statically linking cypari with gmp and pari in order to make it self-contained and installable as a binary package from pip. (That is how cypari works now, and is the primary reason that you can install it on Windows as well as on unix.) The blowback when I suggested that was immediate and intense. Including two copies of pari (even though one would be embedded and 1not available from the filesystem) was unthinkable. (It turns out that importing cypari and cypari2 into sage causes no problems, as far as I know.) I am not particularly a supporter of this principle, although I do worry about using up too much disk space. But I am surprised to see no reaction at all to this proposed demotion of it. |
Exactly. Of course, #35585 violates this principle – for didactical reasons:
|
Inspired by the discussion in https://groups.google.com/g/sage-devel/c/AvH3xq2bCfo:
A subset of our SPKGs is only used by calling their executables, not linking to libraries.
For such executables, there are no concerns about library / toolchain incompatibilities: We can take the executables from conda.
So we can create an isolated conda environment somewhere within SAGE_LOCAL; perhaps
$SAGE_LOCAL/var/lib/sage/conda
. This could be implemented without user-visible changes in the installation process.Examples of such SPKGs:
benzene
buckygen
cmake
csdp
(?)database_...
(but these may be better to change to pip-installable packages, see Meta-ticket: Create upstream repositories, pip-installable packages for database packages #30914)deformation
ffmpeg
(currently dummy package)frobby
gap3
gdb
gengetopt
gfan
(to be checked: vendoring situation with singular)git
(currently dummy package)github_cli
imagemagick
(currently dummy package)info
jmol
latte_int
/lidia
lie
mathjax
(?)meson
(but notmeson-python
)palp
/polytope_db...
pandoc
(currently dummy package)patch
patchelf
pdf2svg
(currently dummy package)python3
qepcad
/saclib
rubiks
surf
tachyon
texlive
(currently dummy package)topcom
Separately: Python packages that run in separate Python processes. (Can install with conda or with pip.)
tox
/virtualenv
and their dependenciesThis could also a solution for some packages of:
The text was updated successfully, but these errors were encountered: