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

Why not make it a git repo? #402

Open
oxinabox opened this issue Aug 13, 2024 · 3 comments
Open

Why not make it a git repo? #402

oxinabox opened this issue Aug 13, 2024 · 3 comments
Labels
template: add Addition suggestion, i.e., a new file or option usage docs Related to documentation on how to use the package or template

Comments

@oxinabox
Copy link
Contributor

Description

The docs say:

The resulting folder will not be a git package yet (to avoid trust issues), so you need to handle that yourself. You should see a short guide on screen, but here it is again

What are these trust issues? (I am already running arbitrary code that is in this package after all)

@oxinabox oxinabox added the usage docs Related to documentation on how to use the package or template label Aug 13, 2024
@abelsiqueira
Copy link
Collaborator

TL;DR: to decrease maintenance burden.

Trust issues are from the copier side. To execute commands in the generated repo, you have to use --trust or --unsafe on copier.

For new packages, we could run git commands from the Julia side to create the repo, but I've been trying to keep it light (maintenance). From your experience, does it involves many corner cases?
Also, pre-commit should be run (when added) between some git commands, so in addition to running git commands, we would need to run pre-commit as well, which adds more corner cases.

For existing packages, the user has to look at the result and decide what to add/restore, so no automatic commands.

Thanks for the question and let me know what you think of the reasoning.

@oxinabox
Copy link
Contributor Author

I guess my question then becomes why does this involve more trust for copier?
Maybe we can just always run copier with those flags?

I haven't found that git has caused much maintainance burden
I think this is the only one I personally have hit: JuliaCI/PkgTemplates.jl#327
And browsing the others: https://github.com/JuliaCI/PkgTemplates.jl/issues?q=is%3Aissue+git
I can't remember any being too burdensome.
Nothing has forced me to look at the code for this, so I don't actually know how it works.
Which itself is an argument for it not being too bad

@abelsiqueira
Copy link
Collaborator

When you run copier copy URL here/, you are implicitly trusting copier, but not the template in URL, so you don't run the tasks that the URL template defines by default. Trusting in this context means allowing the tasks in URL to run.
Here we mix both, since the template is also the package.

I'm still on the fence, but we can split into two issues:

  1. Implement optional automatic repo creation with git
  2. Whether to make it the default

I'm not picking this up right now, but for someone wanting to pick up 1, I think the following is needed:

  • Implement option in Copier.yml
  • If AddPrecommit is also true, run pre-commit before committing
  • Test all combinations

@abelsiqueira abelsiqueira added the template: add Addition suggestion, i.e., a new file or option label Aug 14, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
template: add Addition suggestion, i.e., a new file or option usage docs Related to documentation on how to use the package or template
Projects
None yet
Development

No branches or pull requests

2 participants