From dd5cb36ff640f1a88a29ae774343217562e17c36 Mon Sep 17 00:00:00 2001 From: Joshy Orndorff Date: Tue, 10 Oct 2023 01:11:09 -0400 Subject: [PATCH] Important TODO about making sure every expected inherent is present (and no extras). --- tuxedo-core/src/executive.rs | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/tuxedo-core/src/executive.rs b/tuxedo-core/src/executive.rs index 886b4a70d..2730f4f87 100644 --- a/tuxedo-core/src/executive.rs +++ b/tuxedo-core/src/executive.rs @@ -438,6 +438,15 @@ impl< } pub fn check_inherents(block: B, data: InherentData) -> sp_inherents::CheckInherentsResult { + //TODO We haven't actually made sure that all the inehrents that are expected to be in the block are indeed present. + // We could require each inherent to check this on its own. That's what FRAME does, but FRAME also allows multiple inherents per block + // Or we could do something like an accumulator. Actually, using an accumulator still requires the piece author to use the right accumulator and enforce it. + // For timestamp (and probably others) we can do this by storing not only the time, but also the block in which it is set. + // Then when we try to update it, we just make sure that the block in which it was last set is not the current block. + // Okay, but actually, maybe we can solve this a better way. The problem was taking the shortcut to a check_inherent (singular) method. + // We should stick with `check_inherents` and pass all the relevant inherents down the stack all the way to the bottom using the same wrapping and unwrapping trick. + + //TODO Sanity check. I thought this needs to be mutable. But maybe giving a mutable reference is good enough? let results = CheckInherentsResult::new();