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

FR: uv init option to specify alternative filename to hello.py #7782

Open
nbbaier opened this issue Sep 29, 2024 · 5 comments · May be fixed by #10369
Open

FR: uv init option to specify alternative filename to hello.py #7782

nbbaier opened this issue Sep 29, 2024 · 5 comments · May be fixed by #10369
Labels
cli Related to the command line interface projects Related to project management capabilities

Comments

@nbbaier
Copy link

nbbaier commented Sep 29, 2024

When using uv init (or uv init --app), I find it kind of strange that entrypoint file generated is named hello.py and not main.py. Right, as far as I can tell, now the only solution is to manually change the filename.

It would be great to have an option to specify the entrypoint's filename, something like uv init --entrypoint main.py, or change the default to main.py instead of hello.py

@charliermarsh
Copy link
Member

My initial reaction is that adding an argument for this feels unnecessary. It’s almost as much work to provide the argument as it is to rename the file. I’m gonna defer to @zanieb on this one though.

@nbbaier
Copy link
Author

nbbaier commented Sep 29, 2024

Fair point. I think my preference here would actually be making uv init generate main.py over hello.py. Should have made that my request! For now, I've implemented this manually in my .zshrc with:

uvi() {
    uv init "$@"
    mv hello.py main.py
}

@bluss
Copy link
Contributor

bluss commented Sep 29, 2024

#7670 is similar but not the same, about picking more commonly preferred defaults

@zanieb
Copy link
Member

zanieb commented Sep 29, 2024

I think we could call it main.py instead — though having a function main in a file main and also having a __main__ file in some cases could be confusing. I'm not attached to the default name of hello.py though. It was mostly intended to be an example file that matched the other init kinds which have a hello command and function.

@zanieb zanieb added projects Related to project management capabilities cli Related to the command line interface labels Sep 29, 2024
@charliermarsh charliermarsh marked this as a duplicate of #10304 Jan 5, 2025
@edmorley
Copy link
Contributor

edmorley commented Jan 6, 2025

If it helps as a data-point: From the research I did for the Heroku Python buildpacks [1] (using metrics from many thousands of builds/apps), the most common filenames we see in "single .py file in the root directory" type projects are app.py and main.py. The latter I'm guessing due to guides like the FastAPI tutorial using main.py. The former I'm less certain about, but I know Flask does auto-detection if it finds an app.py - so perhaps that's the reason?

[1]: One of the features of Heroku is that users can git push arbitrary code to their app, and the Heroku build system via the buildpack detection feature will determine which language their app uses, and run the appropriate buildpack to build that app. Whilst the primary signal our Python buildpack checks for is the presence of a package manager file (such as requirements.txt, poetry.lock, and in the future uv.lock etc), it's not uncommon for users to have manually pip installed their dependencies locally and either not created a requirements file at all, or forgotten to Git commit it. So we use additional signals to determine the app's primary language is likely Python (bearing in mind apps can be multi-language, and users can have one-off Python scripts in the repo root that are for development use only), so we can then display a "the package manager file is missing" type error to those apps.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cli Related to the command line interface projects Related to project management capabilities
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants