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

Make Stream's destructor public. #183

Merged

Conversation

PieroV
Copy link
Contributor

@PieroV PieroV commented Oct 19, 2024

This commit makes ozz::io::Stream's destructor public.

The use case is having a function that returns a generic std::unique_ptr<ozz::io::Stream> which will be automatically destructed when the consumer is done with it without having to make assumption on the stream type.

If the constructor is protected/private, also std::unique_ptr cannot access it and the program fails to build.

A public destructor is needed to move around streams with their
interface pointers (or std::unique_ptr<Stream>) instead of the specific
implementation.
@PieroV PieroV force-pushed the stream-public-destructor branch from 47baf3d to d520c6a Compare October 19, 2024 07:57
@PieroV PieroV changed the base branch from master to develop October 19, 2024 07:57
@guillaumeblanc
Copy link
Owner

Hi,
this makes sense indeed.
Thanks for submitting the PR.
Cheers,
Guillaume

@guillaumeblanc guillaumeblanc merged commit bfafca7 into guillaumeblanc:develop Jan 3, 2025
40 of 42 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants