• PenisWenisGenius@lemmynsfw.com
        link
        fedilink
        arrow-up
        7
        ·
        edit-2
        2 months ago

        I don’t know what the solution is but like 50% of everything on github that’s in python is broken from dependencies and of those, half of them are fixable if you put a substantial amount of effort into it. It sucks. I’ve spent 2 entire days trying to get any AI tts to work and have gotten nowhere. I’ve tried 'em all, just about. None of them work on Debian.

      • richieadler@lemmy.myserv.one
        link
        fedilink
        arrow-up
        6
        ·
        2 months ago

        … except for the part where the dependency definition doesn’t follow the latest approved PEP, and the default constraint with ^ add an upper limit that causes problems.

        I moved to PDM.

          • richieadler@lemmy.myserv.one
            link
            fedilink
            arrow-up
            2
            ·
            2 months ago

            Given the glacial pace I’ve been seeing, I would’t be so sure… But understandable if you have many repos and need to reach consensus.

            You can reduce some impacts adding explicit >= constraints instead of ^.

            • sugar_in_your_tea@sh.itjust.works
              link
              fedilink
              arrow-up
              2
              ·
              2 months ago

              The thing is, things are working reasonably well right now, so updating to be in sync with the latest PEP isn’t super impactful, whereas switching from requirements.txt -> poetry and pyproject.toml was a big change. So we’ll probably switch eventually, but since we have over a dozen repos and several teams across timezones, it isn’t a priority.

              I’ll certainly take a look though.

    • flying_sheep@lemmy.ml
      link
      fedilink
      arrow-up
      4
      ·
      2 months ago

      I agree, although it undersells hatch and has a title that made me roll my eyes. Very well researched, none of the usual hot takes and clichés.

      • best_username_ever@sh.itjust.works
        link
        fedilink
        arrow-up
        3
        ·
        2 months ago

        Not OP. I ended up using hatch to make packages because it’s simple and does everything without feeling like a jumbled mess of tools like Poetry. It feels unix-like and didn’t prevent from doing my job.

        • flying_sheep@lemmy.ml
          link
          fedilink
          arrow-up
          1
          ·
          edit-2
          2 months ago

          Hatch is great. It’s easy to get started but I wouldn’t call it simple. Flit is simple, because it’s limited.

          Hatch is complex enough to allow you to override everything, which makes it not simple, but also not complicated.

    • demizerone@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      1 month ago

      I landed on hatch. The way it handles venvs and python versioning is awesome, and can also use UV. I haven’t used UV yet tho.

  • unalivejoy@lemm.ee
    link
    fedilink
    English
    arrow-up
    9
    ·
    edit-2
    2 months ago

    Unfortunately, PEP 582 was rejected, so PDM has deprecated the functionality. But it does support PEP 621, which can’t be said for Poetry. There’s a PR.

    • Eager Eagle@lemmy.world
      link
      fedilink
      English
      arrow-up
      8
      ·
      2 months ago

      Poetry’s compatibility with PEP 621 is underway, but it’ll likely be delayed to version 2.

      Poetry provides a lot of the same functionality for quite some time now, which complicates the quick adoption, but it’ll happen.

    • NostraDavid@programming.dev
      link
      fedilink
      arrow-up
      2
      ·
      edit-2
      2 months ago

      It comes with built-in ruff and uv, and can handle Python versioning for you!

      Not sure if they want to eventually dissolve Rye into uv or what, but for now it’s one of the best (better than Poetry, IMO)

      edit: it also uses the pypoetry.toml standard, something Poetry doesn’t (because Poetry predates pyproject.toml becoming a standard).

      One possible downside: I’ve heard Rye doesn’t honor XDG, which means it has its own location for its config. I don’t mind, but perhaps you do.

      A second possible downside is that Rye doesn’t let you centralize your venvs, so each .venv goes into each project folder, so no using virtualenvwrapper with workon to jump between projects. zoxide can alleviate that problem, or presuming you have a ~/dev folder or similar, you could write a bash function that ls’ that folder and lets you select a folder via fzf? Go ask ChatGPT about it or something.

      edit2: link: https://rye.astral.sh/guide/installation/

  • rutrum@lm.paradisus.day
    link
    fedilink
    English
    arrow-up
    4
    ·
    2 months ago

    I would love similar movement with regards to doc comment standards. My company uses numpy and its too verbose, and the style guide makes zero mention of type hints so we keep winging it. And with not many tools for enforcing the standards (like what type to actual write for a parameter) its an ongoing battle among the team.

  • onlinepersona@programming.dev
    link
    fedilink
    English
    arrow-up
    7
    arrow-down
    4
    ·
    2 months ago

    I’d rather have too many options than the bullshit situation C/C++ has and has had for decades. Open any C++ project and try to get all the dependencies easily using the standard tooling. It’ll vary on every distro and OS.

    Anti Commercial-AI license

      • callcc@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        2 months ago

        Interesting. I might have a look. Actually I don’t have a problem with speed though. I spend most time not dealing with pip and pip-tools but reading docs, programming and fixing the weirdest bugs

      • ericjmorey@programming.dev
        link
        fedilink
        arrow-up
        1
        ·
        edit-2
        2 months ago

        I’m hoping uv is able to make itself to Python what Cargo is to rust.

        Seems like Pixi is close but confined to the Conda ecosystem.

  • corsicanguppy@lemmy.ca
    link
    fedilink
    English
    arrow-up
    4
    arrow-down
    5
    ·
    2 months ago

    … and every one of them destroys single source of truth for installed state. Most of them have no validation potential, and most of them are imperfect upgrades/downgrades.

    If you don’t know why all that’s important, just remember why fired all our mentor types 20 years ago after the Y2K bust and so you had noone to teach you why. Mistakes like lennart’s Cancer didn’t grow in the light of rich knowledge sharing.