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

Avoid strange name shadowing and simplify structure #174

Open
tfardet opened this issue Sep 5, 2023 · 2 comments
Open

Avoid strange name shadowing and simplify structure #174

tfardet opened this issue Sep 5, 2023 · 2 comments

Comments

@tfardet
Copy link
Collaborator

tfardet commented Sep 5, 2023

At the moment, pynsee is written with one file per class or function, with the files having the same name.
This seem to lead to name shadowing upon import (cf. #173) [1] and makes imports extremely cumbersome.

In my opinion, there is no good reason to have one file per function (especially not with the same name) as any good IDE will automatically locate definitions (even GitHub's web UI does this).

A simple way to do this with minimal changes would be to remove duplicate functions (no need to have get_geodata calling _get_geodata). So we can just keep _get_geodata.py which would contain get_geodata removing both one file, one function call, and the weird name shadowing issue.

For classes, we should follow the python convention and keep class files lowercase.


[1]: though this is not supposed to happen (declared variables are supposed to have precedence over modules) so I'm not really sure why this led to bugs in the CI

@hadrilec
Copy link
Contributor

hadrilec commented Sep 5, 2023

I agree that it is not really 'beautiful', the main reason of this split is to avoid circular dependencies. If you manage to put the functions next to another without any circular dependency then go for it!

@tfardet
Copy link
Collaborator Author

tfardet commented Sep 5, 2023

Roger that!
I'm not really worried about the beauty so much as about this very puzzling import issue so if we can simplify import and make sure that we don't run into this anymore, it would be a plus.

I'll have a look at it whenever I can.
In the meantime, I think we can at least move class files to lowercase, that won't hurt.

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

No branches or pull requests

2 participants