-
Notifications
You must be signed in to change notification settings - Fork 127
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
chore(transport): remove module_name_repetitions
#2284
Comments
I'll start working on this! Are there any places where we don't want to get rid of the module name repetitions? As far as I can see we allow them in a lot of modules, just going by this quick search. Maybe it makes sense to remove the crate-wide |
@mansf-osk I suggest starting with a single module, e.g. Small pull requests reduce the likelihood of merge conflicts and make reviewing easier.
Happy for the crate-wide |
Just so I understand, we would rename e.g. |
It would be defined as: // neqo-transport/src/ecn.rs
pub struct Info {
// ...
} and it would be used as: // Some other file.
use ecn;
fn my_func() {
let ecn_info = ecn::Info::new();
} Just like in the standard library where it is Does that make sense @larseggert? |
I'd like some feedback on the following before eventually tackling more of this refactor! The way we did it in #2311 (like in Max's example above) we would eventually end up losing lots of explicit imports that we have right now. I'm not that big a fan of that personally, so I'd like to use aliases instead, as is also suggested in the discussions around that lint's RFC. I especially like the following sentiment in that comment: "Essentially, this pushes resolving overlaps between names to the client of an API (where the overlaps are actually created) rather than the provider of an API (who would otherwise have to guess at which overlaps will occur)." Going by the example above it would look like that: use ecn::{Info as EcnInfo, Config as EcnConfig}
fn my_func() {
let ecn_info = EcnInfo::new();
let ecn_config = EcnConfig::new();
// ...
} That way we still have the prefix for clarity where we consume the API while also adhering to the lint and not losing all our explicit imports. As I see it this is the most canonical way to implement that lint. Thoughts? |
WFM, but it requires the importer to not be lazy and leave the import named as-is. If the importer was lazy, your example would look like this, which I think would be bad: use ecn::{Info, Config}
fn my_func() {
let ecn_info = Info::new();
let ecn_config = Config::new();
// ...
} |
I don't think "losing lots of explicit imports" is a problem. In my eyes importing a module (e.g. use ecn;
fn my_func() {
let ecn_info = ecn::Info::new();
let ecn_config = ecn::Config::new();
} than the aliasing: use ecn::{Info as EcnInfo, Config as EcnConfig}
fn my_func() {
let ecn_info = EcnInfo::new();
let ecn_config = EcnConfig::new();
} |
Thanks for the feedback, I'll keep it as is then. Will put the refactor in my backlog and chip away at it when I have bandwidth. |
We allow the clippy lint
module_name_repetitions
:neqo/neqo-transport/src/lib.rs
Line 7 in a758177
We e.g. prefix various types in the
ecn
module withEcn
:neqo/neqo-transport/src/ecn.rs
Lines 18 to 30 in 3001a3a
As discussed in #2270 (comment), I suggest removing the allow and instead fix the module name repetition.
The text was updated successfully, but these errors were encountered: