Skip to content
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

Clipboard behaves different between net8 and net9 #12665

Closed
InlineAsm opened this issue Dec 20, 2024 · 7 comments · Fixed by #12738
Closed

Clipboard behaves different between net8 and net9 #12665

InlineAsm opened this issue Dec 20, 2024 · 7 comments · Fixed by #12738
Assignees
Labels
💥 regression-release Regression from a public release 🚧 work in progress Work that is current in progress

Comments

@InlineAsm
Copy link

.NET version

net9.0-windows

Did it work in .NET Framework?

Yes

Did it work in any of the earlier releases of .NET Core or .NET 5+?

It does work on net8.0

Issue description

The Clipboard method ContainsText returns false when a string is placed on the clipboard using SetDataObject. In previous versions of the runtime this method would return true.

Steps to reproduce

The following code returns true on net8.0 and returns false on net9.0

Clipboard.SetDataObject("TEXT");
var containsText = Clipboard.ContainsText();
@InlineAsm InlineAsm added the untriaged The team needs to look at this issue in the next triage label Dec 20, 2024
@Tanya-Solyanik Tanya-Solyanik added 💥 regression-release Regression from a public release and removed untriaged The team needs to look at this issue in the next triage labels Dec 20, 2024
@lonitra lonitra self-assigned this Dec 20, 2024
@lonitra
Copy link
Member

lonitra commented Dec 20, 2024

@LeafShi1 could your team take an initial look? My initial thought is perhaps we had accidentally changed something in Clipboard.ContainsText between .NET 8/9 - perhaps some sort of typo.

The codepath for Clipboard.ContainsText should eventually call IDataObject.GetDataPresent, which should go to our DataStore.GetDataPresent. where it should check to see if the format is there - though it is possible on .NET 8 that this goes to a different implementation we have of IDataObject.GetDataPresent. We should compare what the difference is between the codepath for .NET 8/9

@Epica3055
Copy link
Member

Epica3055 commented Jan 3, 2025

@lonitra
I think this issue might be caused by pr_10651

Before the pr

issues_12665_01.mp4

After the pr

issues_12665_02.mp4

@ricardobossan
Copy link
Member

I proceeded to do binary search on the issue and arrived at the same conclusion as @Epica3055 : The faulty commit is 64528f3e176738f7e621ed6959c4593b24db9453 (Convert Rest of Ole to Cswin32 (#10651))

Image

@lonitra
Copy link
Member

lonitra commented Jan 6, 2025

Calling Clipboard.GetDataObject().GetDataPresent(DataFormats.UnicodeText, autoConvert: true) instead of Clipboard.ContainsText() should work as a workaround while further investigation is done.

@Tanya-Solyanik
Copy link
Member

@ricardobossan - please add a unit test for this issue and create a PR with this test disabled, we'll enable when the fix is ready.

@dotnet-policy-service dotnet-policy-service bot added the 🚧 work in progress Work that is current in progress label Jan 9, 2025
@ricardobossan
Copy link
Member

@ricardobossan - please add a unit test for this issue and create a PR with this test disabled, we'll enable when the fix is ready.

@Tanya-Solyanik This is already been addressed by @lonitra on #12738 , class ClipboardTests.cs.

@lonitra
Copy link
Member

lonitra commented Jan 14, 2025

Fix will be available in 9.0.2 release

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
💥 regression-release Regression from a public release 🚧 work in progress Work that is current in progress
Projects
None yet
Development

Successfully merging a pull request may close this issue.

5 participants