this post was submitted on 13 Oct 2023
268 points (100.0% liked)

Programmer Humor

853 readers
18 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
 

Sorry Python but it is what it is.

you are viewing a single comment's thread
view the rest of the comments
[–] Ascyron@lemmy.one 6 points 1 year ago (2 children)

Bruh idk why the difference... Educate me?

[–] ExLisper@linux.community 7 points 1 year ago (1 children)

cargo just works, it's great and everyone loves it.

npm has a lot of issues but in general does the job. When docs say do 'npm install X' you do it and it works.

pip is a mess. In my experience doing 'pip install X' will maybe install something but it will not work because some dependencies will be screwed up. Using it to distribute software is pointless.

[–] krimson@feddit.nl 18 points 1 year ago (2 children)

I use pip extensively and have zero issues.

npm pulls in a million dependencies for even the simplest functionality.

[–] QuazarOmega@lemy.lol 5 points 1 year ago (1 children)

Is that really the fault of the package manager or is it of the libraries you decide to use?

[–] ninpnin@sopuli.xyz 5 points 1 year ago (1 children)

Fault of the libraries you decide to use, i.e. any and all node libraries

[–] QuazarOmega@lemy.lol 1 points 1 year ago

Well if that's the case, can't argue with that lol

[–] ExLisper@linux.community 3 points 1 year ago

It probably works for your own local project. After using it for couple of days to install some 3rd party tool my conclusion is that it has no idea about dependencies. It just downloads some dependencies in some random versions and than it never works. Completely useless.

[–] theFibonacciEffect@feddit.de 5 points 1 year ago (2 children)

Pip stores everything inside of some random txt file that doesn't differentiate between packages and dependencies.

[–] JakobDev@feddit.de 10 points 1 year ago (1 children)

Pip stores nothing in a text file

[–] theFibonacciEffect@feddit.de 7 points 1 year ago (2 children)

If you want to export your local environment, isn't usually a requirements.txt used?

[–] JakobDev@feddit.de 7 points 1 year ago (1 children)

Yes, but this file is created by you and not pip. It's not like package.json from npm. You don't even need to create this file.

[–] theFibonacciEffect@feddit.de 2 points 1 year ago (1 children)

Well if the file would be created by hand, that's very cumbersome.

But what is sometimes done to create it automatically is using

pip freeze > requirements. txt

inside your virtual environment.

You said I don't need to create this file? How else will I distribute my environment so that it can be easily used? There are a lot of other standard, like setup.py etc, so it's only one possibility. But the fact that there are multiple competing standard shows that how pip handles this is kinds bad.

[–] JakobDev@feddit.de 1 points 1 year ago

If you try to keep your depencies low, it's not very cumbersome. I usually do that.

A setup.py/pyproject.toml can replace requirements. txt, but it is for creating packages and does way more than just installing dependencies, so they are not really competing.

For scripts which have just 1 or 2 packges as depencies it's also usuall to just tell people to run pip install .

[–] farent@lemmy.scam-mail.me 6 points 1 year ago

Isn't it called a requirements.txt because it's used to export your project requirements (dependencies), not all packages installed in your local pip environment?

[–] SSUPII@sopuli.xyz 5 points 1 year ago (1 children)

Honestly its a simple and straightforward solution. What's wrong with it?

[–] theFibonacciEffect@feddit.de 1 points 1 year ago* (last edited 1 year ago)

If newer versions are released and dependencies change you would still install the old dependencies. And if the dependencies are not stored you can't reproduce the exact same environment.