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

feat: add appimage build #11570

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

mutlusun
Copy link

Welcome to the quarto GitHub repo!

We are always happy to hear feedback from our users.

To file a pull request, please follow these instructions carefully: https://yihui.org/issue/#bug-reports

If you're a collaborator from outside quarto-dev making changes larger than a typo, please make sure you have filed an individual or corporate contributor agreement. You can send the signed copy to [email protected].

Also, please complete and keep the checklist below.

Description

This PR adds an appimage build to the release tarballs. Appimage is a packaging format that runs on linux and is able to provide all necessary files within one file/package. Users only need to download the file, make it executable, and can run the software. This eliminates the manual moving of the tarball to /opt/ what requires root privileges and symlinking, etc. (see the tarball installation guide).

Related issues: #4505

Checklist

I have (if applicable):

  • filed a contributor agreement.
  • referenced the GitHub issue this PR closes
  • updated the appropriate changelog in the PR
  • ensured the present test suite passes
  • added new tests
  • created a separate documentation PR in Quarto's website repo and linked it to this PR

I'm happy to file the contributor agreement, update the changelog, and open a documentation PR if you agree with the changes.

@cscheid
Copy link
Collaborator

cscheid commented Dec 2, 2024

Thanks for the PR. I'm a bit wary of adding additional maintenance burden in our installers, which is already non-trivial for us.

I'm in principle supportive, but I would like to test drive this a bit. Is there a way you can run this off of your own repo so we can verify that there are no hiccups as we upgrade dependencies, etc, and then we merge it here?

@mutlusun
Copy link
Author

mutlusun commented Dec 3, 2024

Thanks for your feedback!

I can understand that you hesitate to add another installer. I created in my repo a new branch that always builds the installers. You can access the artifacts here: https://github.com/mutlusun/quarto-cli/actions/runs/12142841341

If you want to, I can update the branch to your latest main branch. This way, you can see if something breaks or not.

@cscheid
Copy link
Collaborator

cscheid commented Dec 3, 2024

Let me propose to you the following. You run and maintain the appimage repo in your own branch for a few months, in a way that automatically builds new appimage installers when we do new releases, and we can check back in a few months to see if that's going smoothly? Then, we can consider integrating it into quarto-cli, with the expectation that you (or someone else familiar with appimage) could informally commit to maintaining it for a longer period of time.

@mutlusun
Copy link
Author

Thanks for your feedback! I'm sorry for my late reply.

I can provide appimage builds in a separate repository. However, then I will not try to stay on the main branch but create an empty repository that only has the relevant details for building quarto.

Would you be open to a contribution of this code to quarto-release-bundles? I think, appimage is also a release bundle / some kind of package management and it's probably easier for users to find it there instead of a private repository under my name.

Thanks for your consideration!

@cderv
Copy link
Collaborator

cderv commented Dec 13, 2024

Would you be open to a contribution of this code to quarto-release-bundles? I think, appimage is also a release bundle / some kind of package management and it's probably easier for users to find it there instead of a private repository under my name.

@cscheid I like this idea of having this new bundling in the other repo.

@cscheid
Copy link
Collaborator

cscheid commented Dec 13, 2024

I like this idea as well.

@cderv
Copy link
Collaborator

cderv commented Dec 13, 2024

@mutlusun please submit a PR in quarto-dev/quarto-release-bundles and I'll review it. THank you !

@cderv
Copy link
Collaborator

cderv commented Jan 14, 2025

@cscheid PR is up on quarto-release-bundle repo, but we did not thought about distribution.

Easiest way is a to add the appimage build into the tagged release we do in this repo. I could have the other repo, add to the release artifact here. But is there a benefit of having the build of appimage not in this repo then 🤷

Otherwise, we could start making also mirrored release in quarto-release-bundle repo, where we do upload there some artifact built in this other repo. However, it could be confusing.

This question comes because appimage does not have a central repo we can publish too like chocolatey or pipy.

I'll put the topic up for discussion in meeting.

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

Successfully merging this pull request may close these issues.

3 participants