-
Notifications
You must be signed in to change notification settings - Fork 337
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
rez-pip with custom package.py #1871
Comments
I believe That being said, my preference would be not to use rez-pip for releasing your internal packages. If keeping your dependencies list in one location, you could try what I did and use a @early()
def requires():
import os
with open(os.path.join(os.getcwd(), 'requirements.txt'), 'r') as f:
requires = [
_to_rez_pkg(str(line.rstrip()))
for line in f.readlines()
if not line.startswith('#')
]
return requires
def _to_rez_pkg(string):
from rez.utils.pip import packaging_req_to_rez_req, normalize_requirement
return packaging_req_to_rez_req(normalize_requirement(string)[0]).safe_str() For installing the deps, you can create a pre build command with This idea would work only for building, as it relies on |
We release pure-python packages through rez-pip, everything else as rez packages. For DCC integrations we usually split packages that are pure python for functionality and packages that need special treatment (e.g. to boostrap/integrate with DCCs or contain non-python parts like plugins. |
I agree 100%. I would also love a configuration option to default python packages to a different location. In my case, any pip packages go to separate location, making organization just a bit easier. Knowing that any package in that directory is a package from pypi is quite nice. I do like the general idea of your approach. Instead of using # package.py
python_package = True
def commands() -> None:
.... If @JeanChristopheMorinPerso # package.py
from rez.configuration import BaseConfiguration
class Configuration(BaseConfiguration):
name = 'nuke'
version = '14.0.0'
tools = ('nuke', 'nukex')
...
def commands(self) -> None:
super().commands()
self.env.PATH.prepend(f'{self.root}/nuke/bin') Or like this for a package using pyproject.toml: # package.py
from rez.configuration import PythonConfiguration
class Configuration(PythonConfiguration):
def commands(self) -> None:
super().commands()
self.env.PATH.prepend(f'{self.root}/my_custom_bin') |
Could you share a bit of info why that helps (i personally stopped caring altogeher where packages came from. We split by life cycle not source or package type. With packages being immutable by design i don't spend a lot of time in repositories directly)
package.py files are declarative in nature and their contents are translated to package attributes and for the commands() function are converted to shell code using rex. I have not dabbled with this part of rez a lot myself, maybe someone else from the TSC can share some more insight? I am not even sure this would work for many of the things rez currently does under the hood (e.g. caching, making sure packages are both self-contained and not rez-version dependent whenever possible etc. |
I'd say this is purely for organization/clean up purposes. When I took over the pipeline department at the current place, I needed a way to clean up the hundreds of installed packages because there was just too make space being used up to efficiently sync things. The nature of rez is that it is very easy to accumulate lots of data in the packages directory. Having that separation made it easier to run custom clean scripts that would remove unused packages.
I wasn't aware of |
I think the way to solve your problems for rez-pip to add an attribute in the released package to mark it as "created by rez-pip". This is what rez-pip2 does. See https://rez-pip.readthedocs.io/en/stable/metadata.html#extra-metadata-added-by-rez-pip. |
Thank you, this would help separate pip isntall packages and rez installed packages. But this wouldn't allow me to set custom environment variables. For that I guess I will follow #1871 (comment). I created a separate issue for the package definition topic I brought up: #1880 |
Indeed, it doesn't answer the initial question. Custom definitions could be handled via plugins maybe. There is a PR in rez-pip2 that adds a plugin system. It has a hook to modify the metadata (the package definition). See JeanChristopheMorinPerso/rez-pip#91. Would that work for you? I didn't put a lot of thought into your use case and would love to get feedback on the implementation! |
FYI, you can see the plugins docs in a rendered state at https://rez-pip--91.org.readthedocs.build/en/91/plugins.html#metadata. |
The current rez-pip also marks packages from pip. See Line 437 in c039654
You also get an attribute to tell if a package is pure python. Just for the sake of completeness. In my mind rez-pip serves a clearly defined purpose: Turning pypi packages into rez packages with as little change and loss as possible. Injecting custom logic feels out of scope for me. |
Hello,
I recently started transitioning a lot of our internal packages to pure python packages to be installed with
rez-pip
instead ofrez-release
. This allows us to automatically install all the pip dependencies usingrez-pip
and we don't have to double up the requirements in thepyproject.toml
and thepackage.py
file. Great!The Issue
Some features of the package definition are now missing and I'm curious how others solve this.
For example, packages that rely on environment variables or even use some of the more advanced features in the package definition file now need another way to define those settings. How can environment variables be set?
Possible Workarounds
pyproject.toml
and updaterez-pip
to read that information from there, and insert inrez/src/rez/pip.py
Line 404 in c039654
package.py
and updaterez-pip
to mergepyproject.toml
with the custompackage.py
into a newpackage.py
.I'd be happy to implement something like this if this makes any sense.
How are other people solving this? I would love to hear other workflows!
The text was updated successfully, but these errors were encountered: