Improve error handling for AssetServer::add_async#13745
Merged
alice-i-cecile merged 4 commits intobevyengine:mainfrom Jun 10, 2024
Merged
Improve error handling for AssetServer::add_async#13745alice-i-cecile merged 4 commits intobevyengine:mainfrom
AssetServer::add_async#13745alice-i-cecile merged 4 commits intobevyengine:mainfrom
Conversation
alice-i-cecile
approved these changes
Jun 8, 2024
Contributor
|
It looks like your PR is a breaking change, but you didn't provide a migration guide. Could you add some context on what users should update when this change get released in a new version of Bevy? |
Member
|
I've added this to the 0.14 milestone: it's a breaking change compared to the release candidate, but I think this is important to make the added functionality actually useful. |
mockersf
pushed a commit
that referenced
this pull request
Jun 10, 2024
# Objective The method `AssetServer::add_async` (added in #13700) requires a future that returns an `AssetLoadError` error, which was a bit of an oversight on my part, as that type of error only really makes sense in the context of bevy's own asset loader -- returning it from user-defined futures isn't very useful. ## Solution Allow passing custom error types to `add_async`, which get cast into a trait object matching the form of `AssetLoader::load`. If merged before the next release this will not be a breaking change
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Objective
The method
AssetServer::add_async(added in #13700) requires a future that returns anAssetLoadErrorerror, which was a bit of an oversight on my part, as that type of error only really makes sense in the context of bevy's own asset loader -- returning it from user-defined futures isn't very useful.Solution
Allow passing custom error types to
add_async, which get cast into a trait object matching the form ofAssetLoader::load. If merged before the next release this will not be a breaking change