-
Notifications
You must be signed in to change notification settings - Fork 55
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
Generalize traversing a Clevis config #3708
base: master
Are you sure you want to change the base?
Generalize traversing a Clevis config #3708
Conversation
Congratulations! One of the builds has completed. 🍾 You can install the built RPMs by following these steps:
Please note that the RPMs should be used only in a testing environment. |
2 similar comments
Congratulations! One of the builds has completed. 🍾 You can install the built RPMs by following these steps:
Please note that the RPMs should be used only in a testing environment. |
Congratulations! One of the builds has completed. 🍾 You can install the built RPMs by following these steps:
Please note that the RPMs should be used only in a testing environment. |
There is some way to do the recursive call non-greedily... |
c4182ea
to
ffcd83b
Compare
The challenge problem is to turn the |
67f797f
to
d82b208
Compare
Cockpit tests failed for commit ffcd83b. @martinpitt, @jelly, @mvollmer please check. |
Congratulations! One of the builds has completed. 🍾 You can install the built RPMs by following these steps:
Please note that the RPMs should be used only in a testing environment. |
d82b208
to
0c0c5df
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not entirely clear on some of the design choices here.
tang_func: &dyn Fn(&Map<String, Value>) -> StratisResult<T>, | ||
tpm2_func: &dyn Fn(&Map<String, Value>) -> StratisResult<T>, | ||
sss: &mut (&T, &mut dyn FnMut(T, T) -> StratisResult<T>), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you explain why you made these references? I don't see that pattern used in most closure usage in the Rust code I've seen. My understanding is that Fn()
itself already represents a reference.
recursion_limit - 1, | ||
)?, | ||
) | ||
obj.iter().try_fold(sss.0.clone(), |acc, (pin, config)| { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you explain why you opted for a reference here? My brief analysis of the ownership here leads me to believe that a move and an owned data type would be okay here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can change sss.0 so that it is not a reference. I've added a commit for that. But you can't move sss into the closure, because it is used after the closure returns. So, AFAICT, if you add a move, you have to be able to clone sss.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this gets back to my other comment: why do all of these need to be references? I feel like ownership may remove the need for cloning.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sss
is recursively passed and then used on the return value. I don't believe that it can be moved into the closure for that reason.
Retain laziness in traversing the structure and early exit on error. Signed-off-by: mulhern <[email protected]>
Note that it is still necessary to clone it, to pass as the argument to the recursive call _and_ to use as the base for a fold. Signed-off-by: mulhern <[email protected]>
0c0c5df
to
818b9e9
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just to give a little bit of context, my main concern here is that we don't yet have a reason to generalize this function. Because of the complexity this adds to the traversal, I generally would want to see a case where this generalization would be needed to avoid code duplication. If this is the only code using the abstraction, I hesitate to introduce the complexity just yet as I believe this version is harder to read upfront.
After playing with the code a little bit I see why you have written it the way you have. I don't see a much better way after trying quite a few different variations.
Do you have any concrete plans to use this abstraction or are you doing it out of principle? If there's no current foreseen usage of this, I would vote that we hold off on this until we bump into a situation where it's necessary.
I would have to say that this is a judgement that is essentially subjective.
I am happy to let this PR sit until the next time that there is some need to traverse the Clevis config. But I would also consider implementing something similar if we have the general need to recursively traverse anything else. |
No description provided.