this post was submitted on 23 Nov 2024
11 points (92.3% liked)

Python

6470 readers
19 users here now

Welcome to the Python community on the programming.dev Lemmy instance!

πŸ“… Events

PastNovember 2023

October 2023

July 2023

August 2023

September 2023

🐍 Python project:
πŸ’“ Python Community:
✨ Python Ecosystem:
🌌 Fediverse
Communities
Projects
Feeds

founded 2 years ago
MODERATORS
 

In a requirements-*.in file, at the top of the file, are lines with -c and -r flags followed by a requirements-*.in file. Uses relative paths (ignoring URLs).

Say have docs/requirements-pip-tools.in

-r ../requirements/requirements-prod.in
-c ../requirements/requirements-pins-base.in
-c ../requirements/requirements-pins-cffi.in

...

The intent is compiling this would produce docs/requirements-pip-tool.txt

But there is confusion as to which flag to use. It's non-obvious.

constraint

Subset of requirements features. Intended to restrict package versions. Does not necessarily (might not) install the package!

Does not support:

  • editable mode (-e)

  • extras (e.g. coverage[toml])

Personal preference

  • always organize requirements files in folder(s)

  • don't prefix requirements files with requirements-, just doing it here

  • DRY principle applies; split out constraints which are shared.

you are viewing a single comment's thread
view the rest of the comments
[–] spoonbill 4 points 4 weeks ago (16 children)

Constraints are useful for restricting build dependencies of your dependencies, especially if they follow PEP-518.

[–] logging_strict 1 points 4 weeks ago (15 children)

Was working under the assumption that everyone considered constraints (-c) to be non-negotiable required feature.

If only have requirements (-r), in a centralized pyproject.toml, then how to tackle multiple specific dependency hell issues without causing a huge amount of interconnected clutter?

[–] spoonbill 2 points 4 weeks ago (1 children)

Why do you need to have a centralized pyproject.toml?

[–] logging_strict 1 points 4 weeks ago (2 children)

Within the context of resolving dependency conflicts, poetry decided pyproject.toml is a great place to put requirements.

This is what people know.

pyproject.toml or venv management should otherwise never come into the conversation.

My personal opinion is: venv, pip, pyenv, pip-tools, and tox are sufficient to manage venvs.

venvs are not required to manage requirement files. It's a convenience so dev tools are accessible.

Currently the options are: poetry or uv.

With honorable mention to pip-compile-multi, which locks dependencies.

poetry and uv manage venvs... Why?

[–] spoonbill 2 points 3 weeks ago (1 children)

I was asking why you need to have a centralized pyproject.toml file, which is apparently why you need constraint files? Most people don't have this workflow, so are not even aware of constraint files, much less see them as a must-have.

[–] logging_strict 1 points 3 weeks ago (1 children)

I totally agree with you. So not the best champion of the poetry approach. Someone else would need to step forward, even as devils advocate, and champion poetry. Even if tongue in cheek. Anyone?

Normally, there is no connection between constraint files and pyproject.toml

Python appears to be forever stuck with plain text requirement|constraint files. So putting them into pyproject.toml is just adding an extra layer of complexity.

[–] spoonbill 1 points 3 weeks ago (1 children)

If most people prefer pyproject.toml over requirements.txt, even if it does not support everything you need, isn't it more likely that you will have to change workflow rather than python remaining stuck with requirement.txt?

[–] logging_strict 1 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

more likely

That almost sounds like you might consider to jump on polymarket, initiate the prediction, put money down on that prediction creating a position, but need a little nudge.

Are you willing to make that bet? The size of the bet reflects how strongly you feel. Are you going to make this interesting?

The other side of that bet would be:

Could become that guy who extends the theory, makes a better way of doing it, and creates and publishes the package and docs.

And the world+dog recognizes the package amongst the other tools in this genre, rather than i conforming to existing tools (uv or poetry or pip-compile-multi).

In your favor, there are three tools. So three people/teams on this planet have presented a solution. Can count that on one hand with fingers to spare!

On the other hand, lets keep in mind, this is a Python specific forum and everyone here are skilled super talented coders and probably full on freak'n geniuses (lifts hand, pinky to closest edge of mouth, everyone looks around at one another and copies, then looks back at you with an errie almost coordinated synchronized eye brow raise). And i oddly posted about this exact topic. Literally anyone and everyone who has commented could be that guy.

scratches head

looks up with one eye to check star positions

rubs chin

occasional alternating strong eye brow movements ...

(with hand on chin) who is this guy, should i call his bluff by taking a position? Whats the likelihood he's secretly a closet poetry user and just some poser?

If you won, could you be sad?

If you lost, not get upset or ego hurt instead be much happier with the published tool over the money?

What are the odds looking like on this particular prediction?

Looking forward to you posting the URL to the prediction on polymarket then promoting the market to maximize your returns. First in and clean house. Rinse wash and repeat with this blowhard wannabe (referring to myself).

[–] spoonbill 1 points 3 weeks ago (2 children)

Here is another prediction: the volume of that bet would be nowhere near where it needs to be to make the bet interesting.

Disagree? Create the bet yourself and prove me wrong.

[–] logging_strict 0 points 3 weeks ago

Strategy --> deflection

Involve other people, not yourself; reframe the discussion.

So your predictions are worthless cuz you are unwilling to take on any risk.

Coding involves risk and those willing to take on risk. A gambling man you are not!

Can throw shade and FUD around all day long everyday without consequence or care. Cuz u offer nor put any skin in the game.

Just empty words like a secretary giving a language skill assessment.

So if i said, i see ghosts and dragons and can shit rainbows out of my butt, you'd be too weak to call the bluff.

[–] logging_strict 0 points 3 weeks ago* (last edited 3 weeks ago)

To make this interesting, you could have asked for a stipulation that i fund the other side of the bet. Oddly, you didn't insist on that. Once the bet is funded, drop the make it interesting claim, that's what a bet is.

If i were in your shoes

And believed strongly in your predictions i'd do due diligence.

  1. Read thru the persons github acnt. All the code and mercilessly, but fairly, do a public code review of all public packages, documentation, and commit style. What code quality does this person produce? Whats the likelihood this person could be prepared to possibly collaborate with others?

This is normally enough to evaluate someone. I've ripped people apart who've presented themselves as Python coders and were actually base amateurs.

Here is my github acnt. I submit to ur code review. Meaning, during the code review, any concerns you bring up, i have to defend my actions. Whatever public humiliation you have in store for me, cannot complain or retaliate.

Notice there are no code of conduct files in any of the packages. Free your inner troll and be merciless!

https://github.com/msftcangoblowm

While there, if you like a package, star it

  1. Understand the problem

What would it take to create a solution to this issue?

Does the person, with that github history, clearly understand the issue? Enough to come up with a viable solution?

If had doubts, would admit and say, not confident enough in the prediction any bet could possibly go very wrong. Could admit to having serious doubts without shame.

If had confidence in the prediction, having conducted due diligence, would call the bluff and take the guys money

You took the third option, get called out and proven a non-risk taker and someone who doesn't bother doing their own research. But doesn't mind throwing shade at everyone and everything.

[–] [email protected] 1 points 3 weeks ago (1 children)

are you really asking why use 1 tool instead of 5?

venvs and dependency management are such interconnected concepts, I don't even know how you could sustainably handle them separately.

[–] logging_strict 1 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

UNIX philosophy. One tool that does one thing well

Best to have a damn good reason when breaking this principle (e.g. vendoring) or be funded by Money McBags

requirements files are requirements files, not venvs. They may install into venv, but they are not venvs themselves. The only thing a venv provides that is of interest to ur requirements files are: the relative folder path (e.g. '.venv') and python interpreter path. Nothing more. When using tox, the py version is hardcoded, so only need to provide the relative folder path.

The venv management tools we have are sufficient. the problem is not the venv, it's managing the requirements files.

Your 1 tool suacks just as much as my 5 tools when it comes to managing requirement files. None of them do the job.

[–] [email protected] 2 points 3 weeks ago (1 children)

The Python env has been trying this multiple tools approach for decades and consistently delivering a worse experience than languages that pack most things in one tool.

Rust is a bliss to use, largely thanks to cargo that takes care of build, dependencies, locking, tests, publishing etc. You say do one thing and do it well. In my experience they often do one thing in a mediocre way, while forcing users to understand which and how to combine dozens of possible tools in a development environment that keeps changing. It's messy, slow, error prone, and requires constant developer attention.

[–] logging_strict 1 points 3 weeks ago (1 children)

Most languages don't support packages containing multiple languages (C/C++, Cython, and Python). So Python situation is much more complex.

distutils

setuptools is complex

pip is complex

requirements files are complex

space aliens wrote pytest (and pluggy)

publishing and dependencies are super centralized, depending on pypi.org way too much.

Comparing Rust vs Python is nonsense. Rust is a stricter compiler on top of C. It has to deal with legacy C libraries. It has it very very easy.

[–] [email protected] 1 points 3 weeks ago (1 children)

and despite those differences, uv is essentially cargo for Python, showing it is possible.

[–] logging_strict 1 points 3 weeks ago

Which begets the question, why inject an additional toolchain into package when not skilled at all in that toolchain. Can't support issues caused by that toolchain.

load more comments (13 replies)
load more comments (13 replies)