by Michael S. Kaplan, published on 2005/10/16 03:01 -04:00, original URI: http://blogs.msdn.com/b/michkap/archive/2005/10/16/481447.aspx
One of the problems with sort weights that had to fixed in Vista is the various stroke count sorts.
You see, everyone wanted to add more ideographs, but the original weights left no room for additions. So there was no way to add them and still have them be valid stroke count sorts! But we can't just do nothing, not only because of those customer requests but because the bulk of the ideographs people wanted to add had default weights -- so the perceived behavior from customers is broken sorts (several bugs came in descriving such problems, over the years). We obviously had to do something for people.
Ok, so we have to declare a new major version and then make sure to assign weights in a way that leaves room for the future. This is a trap to not get caught in again, believe me.
But what was fascinating was looking at the source data from each of the subsidiary contacts -- each one of them had a different method of doing the stroke counts:
Looking to the future when new characters might need to be added, room has to be left for such additions in each case. Which is what we ended up doing.
Of course inevitably the question came up -- would we expose this information in some way? Or even should we? I mean who is the customer who needs that level of detail? It obviously does not make sense to give it to competitors, any more than a map maker allows people to copy their maps and resell them. And we do not even have the luxury that the map makers have of adding fictional streets to the map to catch the copiers!
Well, maybe there is some form in which the information would be useful on the platform. It is always worthwhile to think about such things.
Of course even if it made sense to do, the problems in doing so are obviously not trivial -- what generic function could be written that would provide all of that information, when you consider the vast array of different sources and methods?
And doesn't the same issue exist in other languages? I mean obviously the issues are different, but there might still be a commonality, a reason to expose more than we do today to support some type of functionality.
This is a conversation that spans versions and definitely is one for beyond Vista. It might fit into a sensible area for providing functionality in the future. What makes sense to expose, exactly? Perhaps knowing the answer to the WHAT question might lead to sensible answers for the HOW and WHEN questions....
This port brought to you by "𠂉" (U+20089, a CJK Extension B ideograph that looks a bit like a circle)
# Michael Dunn_ on 16 Oct 2005 4:12 AM:
# Michael S. Kaplan on 16 Oct 2005 4:38 AM:
# Vorn on 18 Oct 2005 1:33 AM: