-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
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
Insert custom local system resources #745
Conversation
I think the "only set Local if it hasn't been initialized" part of this is good to go, but I think the convenience functions are a bit too "hard coded" as a system could have more than one local resource. I think I'd rather have an api like this: app.add_system(something.system())
.add_system_local(something.name(), SomeResource) Retrieving a system id/name without a system instance is something thats still being discussed. We'll want whatever api we use for "adding system locals" to line up with other apis like "adding explicit manual system dependencies". Can we scope this pr to just the "only set Local if it hasn't been initialized" for now? Then we can spec out the "address system by name and/or id without re-initializing the system" design elsewhere. |
I specifically made sure to do those two in separate commits so the convenience functions could be shelved if they aren't as agreed upon. That said, I'm not entirely sure what you mean by the "Retrieving a system id/name without a system instance" part. As far as I understand what you mean, this doesn't require that? Personally, I know that if these conveniences aren't implemented, I'll be making my own convenience trait that effectively does this: app.init_system(|resources| {
let system = system.system();
resources.insert_local(system.id(), local_resource_to_init_with);
system
}) Did you mean that it's presently not possible (or in debate for how it should be possible) to call |
I mean that right now if you dont have a direct reference to If in the short term you can build your own helpers, I think thats preferable while we work out what the final api looks like. |
I understand, makes sense. I'm going to get to removing that commit soon and then this can hopefully get merged |
Local<T> will no longer insert the inner resource if it already exists.
73cea50
to
bc5cd93
Compare
Rebased and removed the appbuilder changes. Should be all ready to merge now! |
This modifies some of the traits on
Local<T>
causing it to only initializeT
usingFromResources
if the resourceT
doesn't yet exist on the system. This allows having aLocal<T>
on a system which you then initialize later using whatever value ofT
you'd like.In addition, this adds some convenience functions to
AppBuilder
that allow easily adding a customT
value to a given system.