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

GL: Cleanup std::string usage in Shader/AbstractShaderProgram #608

Closed
wants to merge 1 commit into from

Conversation

hugoam
Copy link

@hugoam hugoam commented Nov 23, 2022

I stumbled on this remaining usage of std::string, std::vector and std::pair so I'm giving a shot at migrating it.

Not sure exactly yet what's the backwards compatibility strategy to employ here, so I'm kind of opening this PR to figure it out, hope it's not too much of a bother!

@hugoam hugoam force-pushed the cleanup-shader-std-string branch 5 times, most recently from 464fad1 to 0b5f72b Compare November 23, 2022 15:46
@hugoam hugoam force-pushed the cleanup-shader-std-string branch from 0b5f72b to a0dc144 Compare November 23, 2022 15:47
@mosra
Copy link
Owner

mosra commented Nov 23, 2022

Umm, I have a WIP branch with very similar changes already (#499), just haven't gotten around to finish it because so many things to do.

Which means, my review of this PR would be basically making it look exactly the same as my local WIP changes, so ... 😅 ... to save us both time, can you just wait until I finish #499?

EDIT: Just the backwards compatibility considerations re std::pair in particular are a big task on its own, and I don't even know how to handle that yet. Probably will do that only once all std::string backwards compat is finished everywhere, to avoid having too many breaking changes at once.

@mosra mosra added this to the 2022.0a milestone Dec 30, 2022
@mosra
Copy link
Owner

mosra commented Jan 2, 2023

This is now integrated in db2cb49 and d0e18e1 as part of #499. It ended up being significantly different from your changes (especially the copy-avoiding internals in GL::Shader), but since you spent the time on this anyway, I added you as a co-author at least :)

@mosra mosra closed this Jan 2, 2023
@hugoam
Copy link
Author

hugoam commented Jan 3, 2023

Amazing that this got merged, and that you added me as co-author, hehe, I didn't expect that much ! 😄

@mosra
Copy link
Owner

mosra commented Jan 3, 2023

Yeah sorry the cleanup took so long, on the other hand it relies heavily on quite recent features such as the StringIterable or the Global flag getting preserved in a String, which just weren't there back in March 2021 when I started #499 :)

@hugoam
Copy link
Author

hugoam commented Jan 3, 2023

I also just realised the Utility::String namespace still contains some useful functions which are std::string based like replaceAll(). Are there some alternatives to those already elsewhere, or is the intention to port those to String one day?

@mosra
Copy link
Owner

mosra commented Jan 3, 2023

The intention is to port those to String eventually, yes. I didn't do that yet because some of these need growable support in String first -- i.e., replaceAll() could be done in two passes where I first find all occurences, calculate the output size, and then fill it in a second pass, but it would be much slower than just finding & populating a growable output in one go. (Though it could internally abuse a growable Array for now and then the memory be transferred to a String, maybe I'll do just that.) What was easy to port is ported already, either as a new overload in Utility::String or directly on the Containers::String[View] class (such as the trimming, splitting and joinint APIs).

I'm painfully aware of all remaining yet-unported locations -- there's still PluginMetadata, Arguments the whole Configuration class and (ugh) the Text library, but for all of those I still need to figure out some design questions first, neither of them is a trivial port. Next I hope I'll tackle the Arguments, and Configuration after that.

@hugoam
Copy link
Author

hugoam commented Jan 4, 2023

I see. Another one I just noticed: the setFileCallback callbacks in AbstractImporter, AbstractFont, etc.
I'm wondering, isn't it theoretically easy to fix those in a backwards compatible way by just replacing with StringView and including StringStl.h in those headers when building with DEPRECATED=1? I was assuming the implicit conversions will work, probably even for callbacks?
One problem I see is probably plugins implementers but maybe some breakage could be accepted there?
If you think that's indeed as simple one that I could tackle as opposed to the ones you cited, maybe I can help with that

@mosra
Copy link
Owner

mosra commented Jan 4, 2023

Those can't be changed in a backwards-compatible way, as it'd be a different function signature. But I solved the exact same problem for GL::DebugOutput::setOutputCallback() already in d89b882 (keeping the old signature but marking it deprecated, and delegating to it from the new one) so this would be similar, nothing complicated.

The main reason I didn't change those yet was that the callbacks need an upgrade anyway, to support what AbstractImporter::openMemory() allows, i.e. being able to tell the importer that the file contents are guaranteed to stay in scope (so the importer doesn't need to make copy), or, conversely, that the importer should make a copy of them, or even some way to transfer the data ownership to the importer. And similarly in the other direction, the importer asking for something like "give me the contents so I can directly reference them without making a copy if possible, and tell me if you weren't able". Basically to support something like what's outlined in #240, but in a generic way. Currently it's possible only for the top-level file via openMemory(), but not for subsequent files, and that's limiting.

Yeah so I didn't change those yet because when I would update them to implement the above, it would be a second breakage for the users, forcing them to adapt all their callback function signatures yet again. Better to just break once than twice, in my opinion.

Sorry that there isn't any low-hanging fruit left 😅

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

2 participants