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

Generalize traversing a Clevis config #3708

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

mulkieran
Copy link
Member

No description provided.

Copy link

Congratulations! One of the builds has completed. 🍾

You can install the built RPMs by following these steps:

  • sudo yum install -y dnf-plugins-core on RHEL 8
  • sudo dnf install -y dnf-plugins-core on Fedora
  • dnf copr enable packit/stratis-storage-stratisd-3708
  • And now you can install the packages.

Please note that the RPMs should be used only in a testing environment.

2 similar comments
Copy link

Congratulations! One of the builds has completed. 🍾

You can install the built RPMs by following these steps:

  • sudo yum install -y dnf-plugins-core on RHEL 8
  • sudo dnf install -y dnf-plugins-core on Fedora
  • dnf copr enable packit/stratis-storage-stratisd-3708
  • And now you can install the packages.

Please note that the RPMs should be used only in a testing environment.

Copy link

Congratulations! One of the builds has completed. 🍾

You can install the built RPMs by following these steps:

  • sudo yum install -y dnf-plugins-core on RHEL 8
  • sudo dnf install -y dnf-plugins-core on Fedora
  • dnf copr enable packit/stratis-storage-stratisd-3708
  • And now you can install the packages.

Please note that the RPMs should be used only in a testing environment.

@mulkieran mulkieran self-assigned this Oct 17, 2024
@mulkieran
Copy link
Member Author

There is some way to do the recursive call non-greedily...

@mulkieran mulkieran force-pushed the generalize_clevis_config_traverse branch 3 times, most recently from c4182ea to ffcd83b Compare October 30, 2024 23:40
@mulkieran
Copy link
Member Author

The challenge problem is to turn the sss ident into a FnMut and get it to compile again.

@mulkieran mulkieran force-pushed the generalize_clevis_config_traverse branch 2 times, most recently from 67f797f to d82b208 Compare October 31, 2024 00:14
Copy link

Cockpit tests failed for commit ffcd83b. @martinpitt, @jelly, @mvollmer please check.

Copy link

Congratulations! One of the builds has completed. 🍾

You can install the built RPMs by following these steps:

  • sudo yum install -y dnf-plugins-core on RHEL 8
  • sudo dnf install -y dnf-plugins-core on Fedora
  • dnf copr enable packit/stratis-storage-stratisd-3708
  • And now you can install the packages.

Please note that the RPMs should be used only in a testing environment.

@mulkieran mulkieran marked this pull request as ready for review October 31, 2024 01:31
@mulkieran mulkieran requested a review from jbaublitz October 31, 2024 01:32
@mulkieran mulkieran force-pushed the generalize_clevis_config_traverse branch from d82b208 to 0c0c5df Compare November 8, 2024 18:24
Copy link
Member

@jbaublitz jbaublitz left a 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.

Comment on lines 234 to 236
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>),
Copy link
Member

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)| {
Copy link
Member

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.

Copy link
Member Author

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.

Copy link
Member

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.

Copy link
Member Author

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]>
@mulkieran mulkieran force-pushed the generalize_clevis_config_traverse branch from 0c0c5df to 818b9e9 Compare November 19, 2024 21:49
@mulkieran mulkieran requested a review from jbaublitz November 19, 2024 22:00
Copy link
Member

@jbaublitz jbaublitz left a 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.

@mulkieran
Copy link
Member Author

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.

I would have to say that this is a judgement that is essentially subjective.

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 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.

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

Successfully merging this pull request may close these issues.

2 participants