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

Remove direct dependency on Python #111

Open
mizdebsk opened this issue Sep 27, 2024 · 2 comments
Open

Remove direct dependency on Python #111

mizdebsk opened this issue Sep 27, 2024 · 2 comments

Comments

@mizdebsk
Copy link
Member

Python served us well for the past years, but it's time to move away from it.
We, Java package mainainers, are not proficient with Python programming and the Python code in Javapackages has become a technical debt for us.
Moreover, Python is no longer installed by default in Fedora/RHEL as DNF is no longer implemented in Python.
Therefore Javapackages should no longer directly use Python by default.

Depends on:

@fridrich
Copy link
Contributor

I am a tad uneasy about the dependency generators. Are they such a bother?

@mizdebsk
Copy link
Member Author

Keeping the generators and other scripts written in Python wouldn't be a big issue, if they were kept in maintenance-only mode. But doing major changes or adding new features is not easy as I'm not proficient in Python programming and I'm not familiar with currently-used Python frameworks and other practices.

There are 3 new generators that needed to be added:

  • JPMS -- it generates provides and requires for JPMS modules, similarly to provides/requires for OSGi bundles
  • filesystem -- that one generates requires on javpackages-filesystem for all packages that install files in Java-related directories; for performance reasons it needs to be using the new RPM multifile protocol
  • script -- generates appropriate requires for scripts generated by %jpackage_script

Moreover, Maven 4 is soon to be released. It is coming with a new model version that will require changes to maven generators. I don't want to reimplement the Maven model parser in Python, but I'd rather start reusing existing Maven code, which will be easy for generators written in Java.

I'm fine to keep javapackages generators and let someone else maintain them. I am also fine to extract the generators as a separate project where they could be maintained by someone else. In any case I'm not planning to do any non-trivial changes to the Python code in the javapackages project (except for code removal).

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

No branches or pull requests

2 participants