Search Issue Tracker
By Design
Votes
0
Found in
5.3.4f1
Issue ID
840104
Regression
No
Default string comparer for Enumerable.OrderBy is wrong in webGL
Default string comparer for Enumerable.OrderBy is wrong in webGL
(new string[] { "abc", "XY", "CDE", "ijk" }).OrderBy(s => s).ToArray()
returns [abc, CDE, ijk, XY] on .NET, Unity and Mono, but returns [CDE, XY, abc, ijk] on Unity/webGL
It seems that the default string comparer should be case-insensitive, while it's currently case sensitive in webGL player.
I've tried an iOS build and it sorts correctly, so the issues seems to be confined to the webGL player implementation and not to IL2CPP.
To reproduce:
1. Build and run attached project for WebGL platform
2. Click Manual Test button
3. Notice that Enumerable.OrderBy returns wrong value
Reproducible: 5.5.0b7, 5.4.1.p4, 5.3.6p7
All about bugs
View bugs we have successfully reproduced, and vote for the bugs you want to see fixed most urgently.
Latest issues
- OnPostprocessAllAssets() is not called for a modified Prefab when another Asset is set Dirty in the same callback
- [Android] UIToolkit ClickEvent is fired when the device is rotated
- Compilation errors occur when "uintBitsToFloat(int)" gets used in OpenGLES
- User Reporting does not send reports when Managed Stripping Level is set to Low or higher
- Editor crashes and a window with "GetManagerFromContext: pointer to object of manager 'MonoManager' is NULL (table index 5)" error is thrown when launching a project with a corrupted library
Add comment