- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.2k
[mono][HybridGlobalization] Fix ShortDatePattern year format to be "yyyy" #99908
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
[mono][HybridGlobalization] Fix ShortDatePattern year format to be "yyyy" #99908
Conversation
| Tagging subscribers to this area: @dotnet/area-system-globalization | 
| Tagging subscribers to 'os-ios': @steveisok, @akoeplinger, @kotlarmilos | 
This reverts commit bac0768.
| Thanks for fixing this so quickly. Can it be ruled out that the iOS native APIs return "yyyy" as the  | 
| 
 Yes, you are right. It seems that the iOS native APIs do return only "y"/"yy" for the tested scenarios but I will push a change so that we can be safe. | 
| I haven't looked too closely but why is  | 
| 
 Currently  runtime/src/libraries/System.Private.CoreLib/src/System/Globalization/CalendarData.Unix.cs Lines 16 to 19 in 589beb0 
 We can reuse FixDefaultShortDatePattern, but we will need to modify it as apple native api now returns "y" or "yy". | 
| 
 Yes, that is right. I was thinking about tinkering the  Let me know if you would prefer this approach and I can give it a go. | 
| @tarekgh we probably hit the issue that different Apple ICU version give different outputs you mentioned here #100240 (comment). I plan to find a set of "stable" locals that I would use for testing. Do you think it would make sense to find a small set that could be used for ICU (non-hybrid) as well so that we would have coverage across Globalization backends or should I only focus on Apple hybrid in this PR? (Note: I planned to backport this PR to .NET 8) | 
| @matouskozak if  | 
c1162e5    to
    71898da      
    Compare
  
            
          
                ...me/tests/System.Globalization.Tests/DateTimeFormatInfo/DateTimeFormatInfoShortDatePattern.cs
          
            Show resolved
            Hide resolved
        
      | /azp run runtime-extra-platforms | 
| Azure Pipelines successfully started running 1 pipeline(s). | 
| 
 Thanks. I tried invariant,  | 
| /backport to release/8.0-staging | 
| Started backporting to release/8.0-staging: https://github.com/dotnet/runtime/actions/runs/8611432872 | 
| @matouskozak an error occurred while backporting to release/8.0-staging, please check the run log for details! Error: @matouskozak is not a repo collaborator, backporting is not allowed. If you're a collaborator please make sure your dotnet team membership visibility is set to Public on https://github.com/orgs/dotnet/people?query=matouskozak | 
| Started backporting to release/8.0-staging: https://github.com/dotnet/runtime/actions/runs/8611432872 | 
| @matouskozak backporting to release/8.0-staging failed, the patch most likely resulted in conflicts: $ git am --3way --ignore-whitespace --keep-non-patch changes.patch
Applying: use yyyy year format for short date pattern
Applying: add test for yyyy short date pattern
Using index info to reconstruct a base tree...
A	src/libraries/System.Runtime/tests/System.Globalization.Tests/DateTimeFormatInfo/DateTimeFormatInfoShortDatePattern.cs
Falling back to patching base and 3-way merge...
CONFLICT (modify/delete): src/libraries/System.Runtime/tests/System.Globalization.Tests/DateTimeFormatInfo/DateTimeFormatInfoShortDatePattern.cs deleted in HEAD and modified in add test for yyyy short date pattern. Version add test for yyyy short date pattern of src/libraries/System.Runtime/tests/System.Globalization.Tests/DateTimeFormatInfo/DateTimeFormatInfoShortDatePattern.cs left in tree.
error: Failed to merge in the changes.
hint: Use 'git am --show-current-patch=diff' to see the failed patch
Patch failed at 0002 add test for yyyy short date pattern
When you have resolved this problem, run "git am --continue".
If you prefer to skip this patch, run "git am --skip" instead.
To restore the original branch and stop patching, run "git am --abort".
Error: The process '/usr/bin/git' failed with exit code 128Please backport manually! | 
| @matouskozak an error occurred while backporting to release/8.0-staging, please check the run log for details! Error: git am failed, most likely due to a merge conflict. | 
…yyy" (dotnet#99908) * use yyyy year format for short date pattern * add test for yyyy short date pattern --------- Co-authored-by: Ilona Tomkowicz <[email protected]>
The globalization
DateTimeFormat.ShortDatePatternAPI is returning short year format instead of "yyyy" format when Hybrid Globalization is enabled on iOS (previously discussed for Linux in #26088). This PR overwrites the short year format ("y"/"yy") with "yyyy".Fixes #99515. Needs backport to .NET 8.
Contributed: @mkhamoyan