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

Use wrapper type for CFUUID #4032

Merged
merged 4 commits into from
Jan 17, 2025
Merged

Conversation

killercup
Copy link
Contributor

This no longer exposes CGDisplayCreateUUIDFromDisplayID and instead offers a new CfUuid type that can be created from a display ID and also cleans itself up on drop.

Closes #4031


  • Tested on all platforms changed
    • Tested examples on macOS 15.1.1
  • Added an entry to the changelog module if knowledge of this change could be valuable to users
  • Updated documentation to reflect any user-facing changes, including notes of platform-specific behavior
  • Created or updated an example program if it would help users understand this functionality

@killercup killercup requested a review from madsmtm as a code owner December 4, 2024 15:35
@killercup
Copy link
Contributor Author

Saw #4031 randomly and thought I'd take stab at it. I'm not sure this is releasing the right thing but it seems to work without issues. Please someone double check :)

Copy link
Member

@madsmtm madsmtm left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think such wrappers actually already exist? Use core_foundation::uuid::CFUUID and CFUUID::wrap_under_create_rule?

@madsmtm madsmtm added B - bug Dang, that shouldn't have happened DS - macos labels Dec 4, 2024
@madsmtm
Copy link
Member

madsmtm commented Dec 4, 2024

Also, I was a bit unsure, but read the docs on ARC does seem to suggest that since the function contains Create in the name, it should definitely be released afterwards.

@killercup
Copy link
Contributor Author

I think such wrappers actually already exist? Use core_foundation::uuid::CFUUID and CFUUID::wrap_under_create_rule?

Oh nice, didn't know about this! Also took me look into the source to confirm it calls release :) It doesn't seem to derive Hash, PartialOrd, and Ord, though… I can try to get this added upstream but I'm not even sure if treating these UUIDs as Ord makes sense?

@madsmtm
Copy link
Member

madsmtm commented Dec 6, 2024

UUIDs are definitely Ord. But I think you can use CFUUIDGetUUIDBytes to get the actual values of the UUID, and then compare that instead?

@madsmtm
Copy link
Member

madsmtm commented Dec 8, 2024

But I'd also be fine with converting them to a pointer, and implementing Ord by comparing the pointer addresses (that's what we're currently doing).

This no longer exposes `CGDisplayCreateUUIDFromDisplayID` and instead
offers a new `CfUuid` type that can be created from a display ID and
also cleans itself up on drop.

Closes rust-windowing#4031
@killercup
Copy link
Contributor Author

Sorry, had other stuff going on. I've updated it to compare/hash/sort by UUID bytes. It's not the most concise but does the job.

Copy link
Member

@madsmtm madsmtm left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good, only a small nit

@@ -133,15 +134,43 @@ impl VideoModeHandle {
#[derive(Clone)]
pub struct MonitorHandle(CGDirectDisplayID);

#[derive(Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
struct MonitorUuid([u8; 16]);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You shouldn't need this, you can just use [u8; 16] (or if you really want, type MonitorUuid = [u8; 16]).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I usually go for explicit newtypes, and even had an implementation where this had From<CFUUIDBytes> but I didn't want to overdo it. I'll swap it for the type alias :)

Copy link
Member

@madsmtm madsmtm left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks again!

Comment on lines +146 to +163
MonitorUuid::from([
uuid.byte0,
uuid.byte1,
uuid.byte2,
uuid.byte3,
uuid.byte4,
uuid.byte5,
uuid.byte6,
uuid.byte7,
uuid.byte8,
uuid.byte9,
uuid.byte10,
uuid.byte11,
uuid.byte12,
uuid.byte13,
uuid.byte14,
uuid.byte15,
])
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've implemented this conversion in madsmtm/objc2@933f49c too, so this should be simpler in Winit once we upgrade to the next version

@madsmtm madsmtm merged commit 24c2264 into rust-windowing:master Jan 17, 2025
58 checks passed
raphamorim added a commit to raphamorim/rio that referenced this pull request Jan 19, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
B - bug Dang, that shouldn't have happened DS - macos
Development

Successfully merging this pull request may close these issues.

CGDisplayCreateUUIDFromDisplayID may be leaking?
2 participants