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

jsr publish --fix #15

Open
lucacasonato opened this issue Feb 28, 2024 · 5 comments
Open

jsr publish --fix #15

lucacasonato opened this issue Feb 28, 2024 · 5 comments
Labels
feature New feature or request

Comments

@lucacasonato
Copy link
Member

I think that we can auto fix the majority of slow types diagnostics (missing return types, and explicit class types) by using TSC inference and then fixing up the source code with the explicit types gotten from TSC.

This is a bit of work, but would make supporting types in your package a matter of jsr publish --fix (or deno lint --fix). Right now the wall of slow types errors could be a bit daunting.

@lucacasonato lucacasonato added the feature New feature or request label Feb 28, 2024
@KnorpelSenf
Copy link

Why would --fix not be the default?

@lucacasonato lucacasonato added this to JSR Mar 4, 2024
@github-project-automation github-project-automation bot moved this to Needs Triage in JSR Mar 4, 2024
@lucacasonato lucacasonato moved this from Needs Triage to Ready in JSR Mar 4, 2024
@paulmillr
Copy link

paulmillr commented Apr 26, 2024

@KnorpelSenf I don't want jsr to mess with my shit by default

@vwkd
Copy link

vwkd commented May 5, 2024

Not necessarily implied by the description, but I too suspect modifying code on-the-fly while publishing might not be a good idea.

This could open a can of worms where the code in the repo and the published code start to diverge, if not all modifications are bijective transformations and the published code is ever used as the repo code. Maybe unlikely to occur, but one could imagine some scenario where the published code is used to restore a repo that was somehow deleted or lost. Maintaining this subtle contract might be difficult as TypeScript and JavaScript evolve over the years, as it takes only one non-bijective transformation to break it.

I'd prefer if it modified the local copy of the code such that it can be committed to the repo and publish can remain a simple upload of the exact local code.

@KnorpelSenf
Copy link

So it seems like implementing this in deno lint --fix would be the best option

@Swimburger
Copy link

So it seems like implementing this in deno lint --fix would be the best option

If the jsr publish command does linting, there should also be a jsr lint or jsr publish lint, including a --fix argument.
deno lint --fix also makes sense, but jsr users should not have to install deno.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature New feature or request
Projects
Status: Ready
Development

No branches or pull requests

5 participants