You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Create a new abstraction for "localization providers" and make IpInfo generic over that type. If the spirit of this change is accepted we can also begin to improve the status-quo regarding excessive use of .clone() in IpInfo. This could look like making the following change (I'm working through experiments at https://github.com/Alextopher/ipinfo/tree/memory)
pubtraitLocalization{fncountry_name(&self,country_code:&str) -> Option<&str>;fnis_eu(&self,country_code:&str) -> bool;fnflag(&self,country_code:&str) -> Option<&CountryFlag>;fncurrency(&self,country_code:&str) -> Option<&CountryCurrency>;fncontinent(&self,country_code:&str) -> Option<&Continent>;}// Where `StaticTables` is a crate provided Localization. It is a good default and improvement on the status-quo // See: https://github.com/Alextopher/ipinfo/blob/memory/src/localization.rs#L78pubstructIpInfo<T:Localization = StaticTables>{url:String,token:Option<String>,client: reqwest::Client,cache:LruCache<String,IpDetails>,localization:T,}
Motivation
There are some key API guidelines that inspires this kind of change.
Using a trait and generics here minimizes our assumptions on how localization data can be provided. #42 called for the replacement of remote resources with tables baked into the library. If IpInfo was generic then we could support both workflows. C-GENERIC
IpInfo only uses shared references to localization data. Because of this we should only require users to provide shared references. Then we can empower users to handle memory management themselves. C-CALLER-CONTROL
Downsides
This proposal is suggesting making a breaking change. Using a good default type parameter (StaticTables) means anyone who hasn't used localization (and just used ..Default::default() won't have a trouble updating.
The text was updated successfully, but these errors were encountered:
@Alextopher thanks again for all your contributions! My reading here, as you also mention, is that this will be a breaking change for users doing custom localization. Secondly, I suspect this will add extra work for users to achieve the same end. So for these two reasons I doubt that it will be worthwhile for users to migrate.
But nevertheless we can evaluate how big of an improvement we can achieve in performance. Do you have any before/after numbers around this?
Proposed Change
Create a new abstraction for "localization providers" and make
IpInfo
generic over that type. If the spirit of this change is accepted we can also begin to improve the status-quo regarding excessive use of.clone()
inIpInfo
. This could look like making the following change (I'm working through experiments at https://github.com/Alextopher/ipinfo/tree/memory)Motivation
There are some key API guidelines that inspires this kind of change.
Using a trait and generics here minimizes our assumptions on how localization data can be provided. #42 called for the replacement of remote resources with tables baked into the library. If
IpInfo
was generic then we could support both workflows. C-GENERICIpInfo
only uses shared references to localization data. Because of this we should only require users to provide shared references. Then we can empower users to handle memory management themselves. C-CALLER-CONTROLDownsides
This proposal is suggesting making a breaking change. Using a good default type parameter (
StaticTables
) means anyone who hasn't used localization (and just used..Default::default()
won't have a trouble updating.The text was updated successfully, but these errors were encountered: