-
Notifications
You must be signed in to change notification settings - Fork 291
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
WIP: Packaging with Meson #363
WIP: Packaging with Meson #363
Conversation
3a5884c
to
ee901ab
Compare
Thanks for the PR; I was also in the middle of working on this last weekend 👍. Other stuff came up so I didn't get to finish it. Understanding that this is still WIP, just a couple of requests:
I explained in a previous PR, but the reason we haven't made the full transition yet was to allow for parallel compilation, which the |
2b922a2
to
c9b7877
Compare
fccc77f
to
d3889f6
Compare
e6447d1
to
468f565
Compare
Hi @ye11owSub , I haven't been following too closely, but I was curious about what added benefit of having meson build here replacing CMake. The changes seem pretty widespread across all of the python module directories, and changing all of these would also need to applied to Incentive PyMOL as well to maintain parity, which would be a lot more work for us as well considering we also have other dependencies that are not visible here. With regards to scope of the change for migrating away from |
468f565
to
6b1ea7c
Compare
c678ceb
to
939ba74
Compare
Hi @JarrettSJohnson! No, this is not necessary when switching to project.toml. However, it seems like a reasonable step to update the project in this direction. I've tried to explain my perspective in more detail in the description |
fb12a49
to
0797c6e
Compare
0797c6e
to
0a7ffb0
Compare
Thanks for updating your description. I've spoken to others about this; and we really do appreciate a lot of work that you've put in to the PR draft so far. Though, I just wanted to state this before getting too deep with progressing with Meson. Because of the large surface area of which this affects not only this codebase but other proprietary, internal ones, we would need to first take some time to investigate and develop for it first before changes like this can be propagated to this public repository. I think it's perhaps prudent to split this work into at least two PRs:
|
I tried to build a project using setuptools as the backend, but I encountered several issues:
If you would like to try it out for yourself, please feel free to use this PR. What do you think about it? |
Thanks! I haven't forgotten about this, but will briefly be unavailable until July. I'll review this afterward. Thanks! |
Would it be possible to get the pyproject.toml working and post wheels on pypi? a "pip install pymol" and "pip install -e ." for the repo, would enable more broad use of the project because it could be installed like a normal python project without too much special OS-specific treatment or needing to dive into docs and copy paste a bunch of commands and the editable install can enable developers to tinker and see results immediately and contribute those results upstream when they are good if anyone needs it, here is an install script which works on ubuntu 22.04 on wsl2 with python 3.12 today, and should be fairly easy to get working on mac #!/bin/bash
# this script is designed to for DEBIAN/UBUNTU and MAC
# windows is too hard, sorry
# https://pymolwiki.org/index.php/MAC_Install
# backup plan for MAC:
# brew install brewsci/bio/pymol
# TODO: Select your profile file to use
PROFILE_FILE="$HOME/.bash_profile"
# PROFILE_FILE="$HOME/.bashrc"
# default shell on newer MAC computers is zsh
# PROFILE_FILE="$HOME/.zshrc"
# Debian/Ubuntu/Mint
sudo apt-get install git build-essential python3-dev libglew-dev \
libpng-dev libfreetype6-dev libxml2-dev \
libmsgpack-dev python3-pyqt5.qtopengl libglm-dev libnetcdf-dev
# for mac, this might not work but
# brew install git pkg-config python3 glew libpng freetype libxml2 msgpack pyqt5 glm netcdf
# Set the path to the PyMOL build directory
PYMOL_BUILD_DIR="$HOME/hax/externals/pymol/build"
# Create the ~/hax/externals directory if it doesn't exist
if [ ! -d "\$HOME/hax/externals" ]; then
mkdir -p "\$HOME/hax/externals"
fi
# Change to the externals directory
cd "$HOME/hax/externals"
# Create the pymol directory if it doesn't exist
mkdir -p pymol
# Change to the pymol directory
cd pymol
# Clone the PyMOL repository if it doesn't exist
if [ ! -d pymol-open-source ]; then
gh repo clone schrodinger/pymol-open-source
fi
# Clone the mmtf-cpp repository if it doesn't exist
if [ ! -d mmtf-cpp ]; then
gh repo clone rcsb/mmtf-cpp
fi
# Move the mmtf-cpp header files to the PyMOL include directory
mv mmtf-cpp/include/mmtf* pymol-open-source/include/
# Change to the PyMOL directory
cd pymol-open-source
# Install PyMOL using the setup.py script
# Set the install command based on the operating system
if [ "$(uname -s)" = "Darwin" ]; then
INSTALL_CMD="python setup.py install --prefix \"$PYMOL_BUILD_DIR\" --osx-frameworks"
else
INSTALL_CMD="python setup.py install --prefix \"$PYMOL_BUILD_DIR\""
fi
# Install PyMOL using the install command
eval "$INSTALL_CMD"
# Check if the directory is already included in the profile file
if ! grep -q "$PYMOL_BUILD_DIR/lib/python3.12/site-packages" "$PROFILE_FILE"; then
# If the directory is not already included, add it to the profile file
echo "" >> "$PROFILE_FILE"
echo "if [[ \":\$PYTHONPATH:\" != *\":$PYMOL_BUILD_DIR/lib/python3.12/site-packages:\"* ]]; then" >> "$PROFILE_FILE"
echo " export PYTHONPATH=\"$PYMOL_BUILD_DIR/lib/python3.12/site-packages:\$PYTHONPATH\"" >> "$PROFILE_FILE"
echo "fi" >> "$PROFILE_FILE"
fi
# Source the profile to make the change to PYTHONPATH take effect
source "$PROFILE_FILE"
# Test that PyMOL is installed correctly
python -c "from pymol import cmd, util; print('pymol.cmd:', dir(cmd)); print('pymol.util:', dir(util))"
python -c "import pymol; print('pymol is installed and works on this machine.')" my bad, removed |
@bionicles I would like to achieve this exact result, but at the moment, it is not possible due to a lack of a clear list of dependencies. However, in theory, with the migration to Meson, this goal could be achieved |
My major motivation to moving to Conda Forge package: |
I'm confused, you're saying PyMol is "third party" and won't be maintained? |
I moved the build process to use the pyproject.toml file
Why it needs to be done:
Why has the current project form become a problem:
I've chosen Meson because: