On 22/11/2009, at 1:20 PM, [hidden email] wrote:
> Author: jleroux > Date: Sun Nov 22 00:20:12 2009 > New Revision: 883017 > > URL: http://svn.apache.org/viewvc?rev=883017&view=rev > Log: > A modified patch from Marco Risailit " Add the possibility to filter > the list of available countries from the drop down." (https://issues.apache.org/jira/browse/OFBIZ-3192 > ) - OFBIZ-3192 > I have used StringUtil.split() and enhanced for loops instead > > Modified: > ofbiz/trunk/framework/common/src/org/ofbiz/common/ > CommonWorkers.java > > Modified: ofbiz/trunk/framework/common/src/org/ofbiz/common/ > CommonWorkers.java > URL: http://svn.apache.org/viewvc/ofbiz/trunk/framework/common/src/org/ofbiz/common/CommonWorkers.java?rev=883017&r1=883016&r2=883017&view=diff > = > = > = > = > = > = > = > = > ====================================================================== > --- ofbiz/trunk/framework/common/src/org/ofbiz/common/ > CommonWorkers.java (original) > +++ ofbiz/trunk/framework/common/src/org/ofbiz/common/ > CommonWorkers.java Sun Nov 22 00:20:12 2009 > + List<String> countriesList = FastList.newInstance(); > + List<String> countriesAvailable = > StringUtil > .split(UtilProperties.getPropertyValue("general.properties", > "countries.geo.id.available"), ","); > + if (countriesAvailable != null) { > + for(String country : countriesAvailable) { > + GenericValue geoCountry = null; > + try { > + geoCountry = delegator.findOne("Geo", > UtilMisc.toMap("geoId", country.trim()), true); > + } catch (GenericEntityException e) { > + Debug.logError(e, "The country specified into > countries.geo.id.available does not exists in Geo", module); > + } > + if (geoCountry != null) { > + countriesList.add(country); > + } > + } > + } grabbing each Geo just to make sure it exists and then in the next block retrieving them all again? Somewhat pointless to have them all, throw them away and then grab them again. [snip] > + /* remove the default geo to avoid double rows in > the drop-down */ > + int idx = 0; > + for (GenericValue geo : countryGeoList) { > + if (geo.get("geoId") != null && > defaultGeo.get("geoId") != null && > + > geo.get("geoId").equals(defaultGeo.get("geoId"))) { > + countryGeoList.remove(idx); > + } > + idx += 1; > + } > geoList.addAll(countryGeoList); > } else { > geoList = countryGeoList; you do actually need to know the index during iteration. Also the geoId null checks are somewhat superfluous considering that geoId is the primary key. smime.p7s (4K) Download Attachment |
Administrator
|
Hi Scott,
1st I find Marco's idea very good! And I'd like to apply it also to languages. Who needs all languages ? Of course if you use only one language (English ;o) you can't see that as a drawback, but when you have continuously to change from one language to English, it can be boring... So OOTB we should even restrain to languages we currently support (a dozen I guess). I hope to apply the concept soon... Now about implementation, inline... From: "Scott Gray" <[hidden email]> > [snip] >> + List<String> countriesList = FastList.newInstance(); >> + List<String> countriesAvailable = StringUtil .split(UtilProperties.getPropertyValue("general.properties", >> "countries.geo.id.available"), ","); >> + if (countriesAvailable != null) { >> + for(String country : countriesAvailable) { >> + GenericValue geoCountry = null; >> + try { >> + geoCountry = delegator.findOne("Geo", UtilMisc.toMap("geoId", country.trim()), true); >> + } catch (GenericEntityException e) { >> + Debug.logError(e, "The country specified into countries.geo.id.available does not exists in Geo", module); >> + } >> + if (geoCountry != null) { >> + countriesList.add(country); >> + } >> + } >> + } > > You do realize that you are going through the list of countries and grabbing each Geo just to make sure it exists and then in the > next block retrieving them all again? Somewhat pointless to have them all, throw them away and then grab them again. Even in worse cases (246 countries OOTB), for practical purpose I guess nobody would have noticed anything on UI level. But I agree we can do better so I tried to do it in another, faster way: commited at r884317 BTW, you did not mention anyting about if (countriesAvailable != null) { This would be my main concern. I want to refactor StringUtil .split (and uses) so that it renders an empty list when now it's rendering null. To avoid this useless check when using an enhanced for loop (lists often use enhanced for loops) and mostly because it's cleaner IMO. I have to check current uses though... > [snip] >> + /* remove the default geo to avoid double rows in the drop-down */ >> + int idx = 0; >> + for (GenericValue geo : countryGeoList) { >> + if (geo.get("geoId") != null && defaultGeo.get("geoId") != null && >> + geo.get("geoId").equals(defaultGeo.get("geoId"))) { >> + countryGeoList.remove(idx); >> + } >> + idx += 1; >> + } >> geoList.addAll(countryGeoList); >> } else { >> geoList = countryGeoList; > > Enhanced for loops are great but they're not really appropriate when you do actually need to know the index during iteration. I mostly prefer them because I like the concept, it's easier to write, to read and that's important points to me. I agree that it's maybe less efficient than a for loop with index on list for this case, or rather ListIterator wich would have been perfect. > Also the geoId null checks are somewhat superfluous considering that geoId is the primary key. Thanks for the geoId the primary key spot, good idea indeed, lesson learned. Even more now that we guarantee a primary key can't be null (since r835303) Thanks Jacques |
Administrator
|
From: "Jacques Le Roux" <[hidden email]>
> Hi Scott, > > 1st I find Marco's idea very good! > And I'd like to apply it also to languages. Who needs all languages ? Of course if you use only one language (English ;o) you > can't > see that as a drawback, but when you have continuously to change from one language to English, it can be boring... > So OOTB we should even restrain to languages we currently support (a dozen I guess). I hope to apply the concept soon... Sorry for the noise, I thought there was a problem with UtilMisc.java.availableLocales() in backend, but it works as well as in eCommerce actually, certainly browser caches.... Jacques |
Administrator
|
In reply to this post by Jacques Le Roux
From: "Jacques Le Roux" <[hidden email]>
> BTW, you did not mention anyting about > if (countriesAvailable != null) { > This would be my main concern. I want to refactor StringUtil .split (and uses) so that it renders an empty list when now it's > rendering null. To avoid this useless check when using an enhanced for loop (lists often use enhanced for loops) and mostly > because it's cleaner IMO. I have to check current uses though... 136 occurences, on the 1st teen I looked at, only one relies "on ==null", but anyway it's too much work and risk for what it is worth Jacques |
Jacques Le Roux wrote:
> From: "Jacques Le Roux" <[hidden email]> >> BTW, you did not mention anyting about >> if (countriesAvailable != null) { >> This would be my main concern. I want to refactor StringUtil .split >> (and uses) so that it renders an empty list when now it's >> rendering null. To avoid this useless check when using an enhanced for >> loop (lists often use enhanced for loops) and mostly because it's >> cleaner IMO. I have to check current uses though... > > 136 occurences, on the 1st teen I looked at, only one relies "on > ==null", but anyway it's too much work and risk for what it is worth Not to mention it is slower. The enhanced for is not defined to do an isEmpty check on the Collection or the array. In all likely hood, it probably always creates the Iterator, just to then do an do-nothing hasNext call. The real question then becomes whether the normal for each call site is to have an empty list, or a null list. And that might be hard to answer. |
Free forum by Nabble | Edit this page |