Skip to content
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

Maintenance: Looking for maintainers #1865

Open
adisbladis opened this issue Nov 7, 2024 · 11 comments
Open

Maintenance: Looking for maintainers #1865

adisbladis opened this issue Nov 7, 2024 · 11 comments

Comments

@adisbladis
Copy link
Member

adisbladis commented Nov 7, 2024

I'm no longer using Poetry or Poetry2nix, and want to step down from poetry2nix maintenance.

Poetry has a number of upcoming large changes, which poetry2nix is unlikely to gain support for:

There are a number of poetry2nix specific challenges long-term:

  • Dependency solving isn't very good
    I started working on that in https://github.com/adisbladis/poetry2nix-v2, but with uv gaining a lock file I don't see the point any more.

  • Nixpkgs Python builders aren't good
    They should be replaced by https://pyproject-nix.github.io/pyproject.nix/build.html.

  • The whole API is misdesigned
    mkPoetry* shouldn't exist. A python2nix tool should generate an overlay to use with environment composition primitives.
    See uv2nix for prior art.
    Having a default choice between sdist or wheel was a mistake. Users should be responsible for making this choice themselves as it shapes your entire user experience.

  • Overrides
    This is my biggest annoyance in regards to maintenance, and was kind of accidental.

    I don't think python2nix tooling should come with overrides that taper over lock file deficiencies.
    Overrides are ephemeral in nature and bit-rot.
    It's better that external projects to take on this role, and let python2nix tooling focus on getting the semantics right.

Options

  • Switching to uv

    My personal recommendation is to use uv & uv2nix instead.
    Uv2nix is still marked as experimental and might still undergo some breaking API changes, so this has some risks attached.

  • Sticking with Poetry

    • Using nixpkgs dependencies

      If you're OK with using the Python package set from nixpkgs (ignoring poetry.lock) pyproject.nix is an option with it's Poetry pyproject.toml loader.
      This option is maintained and offers a migration path from Poetry to PEP-621.

    • Using dependencies from poetry.lock

      This is not currently a maintained use case anywhere.

  • Pay for maintenance

    I'm open for contract work.

@l0b0
Copy link
Contributor

l0b0 commented Nov 7, 2024

Thank you very much for your work on poetry2nix and its successors!

@adisbladis adisbladis pinned this issue Nov 7, 2024
@cpcloud
Copy link
Collaborator

cpcloud commented Nov 7, 2024

While I have enjoyed working on and helping maintain poetry2nix, I'm migrating my main motivation for its use to uv2nix, and so will also not be able to do much more here beyond merging the occasional PR.

Thanks for all your work here @adisbladis!

@TyberiusPrime
Copy link
Contributor

TyberiusPrime commented Nov 7, 2024

I'm also migrating my main stack to uv2nix the first chance I get,
because a) uv is so much faster and b) the uv maintainers appear open to 'lock the build systems down as well'.

Also @adisbladis work on uv2nix & pyproject.nix has just been stellar.

As for an override collection, come join the effort at https://github.com/TyberiusPrime/uv2nix_hammer_overrides/ which is an outgrowth of my stalled PR #1742, done better this time around.

edit: "first chance I get' probably means once nixpkgs 24.11 containing a newish uv is released.

@Nebucatnetzer
Copy link
Contributor

Nebucatnetzer commented Dec 6, 2024

Can we maybe get some sort of basic maintenance going?
I'm not the greatest Nix coder but I think I could help with looking at PRs for basic updates like hash overrides or something like this: #1876

@JAEarly
Copy link
Contributor

JAEarly commented Dec 6, 2024

Can we maybe get some sort of basic maintenance going? I'm not the greatest Nix coder but I think I could help with looking at PRs for basic updates like hash overrides or something like this: #1876

This would be super helpful! Also happy to assist with basic MRs

@elikoga
Copy link
Contributor

elikoga commented Dec 23, 2024

I can take over maintenance over the next few months since I depend on poetry2nix for thymis , at least until this whole python packaging thing is stabilized

@adisbladis
Copy link
Member Author

It's great that people are willing to step up to merge PRs and keep things on life-support, but I'm struggling with one very important point when it comes to delegation: trust.

@Nebucatnetzer has a handful contributions over a longer period of time. I've invited you to the nix-community org and added you to the poetry2nix team.

@Nebucatnetzer
Copy link
Contributor

I know what you mean, I have been thinking about that as well but more in general as Nix is such a small community and there is so much to do.

Anyway I think I can vouch for @elikoga as I have met him twice in person. Once at NixCon and then again in Rapperswil at the ZHF event.
In addition he gave this talk at NixCon: https://m.youtube.com/watch?v=RVitm6MPmT4
So I think he is well known enough that we can punch him if he does something stupid 😜.

@elikoga
Copy link
Contributor

elikoga commented Dec 24, 2024

We will rely on poetry2nix either way and I'd like to see some of the PRs merged so I can get rid of my current brittle overrides.

I think a good approach is for us to maintain a fork for us to get acquainted and we can pass maintenance of the nix-community repo around however feels useful

@Nebucatnetzer
Copy link
Contributor

I didn’t have the time yet to look at it but I don’t see a problem inviting you as an additional maintainer unless someone is really opposed to it.

@Nebucatnetzer
Copy link
Contributor

Ah never mind I don't have the rights to do that but if you @elikoga submit merge requests or review more complex merge requests I would really appreciate it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

7 participants