mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-28 04:55:33 +00:00
537cac1bf5
This fixes a bug spotted by @mjfh that was introduced by commit 2a7ccceb: try: if not c.continuation.isNil: (c.continuation)() c.continuation = nil c.selectVM(fork) except CatchableError as e: ... The call to `(c.continuation)()` was moved by 2a7ccceb inside the `try` so that, like all the Op functions do already, if the continuation raises, the interpreter's general catch turns the exception into a an error status result. But if the continuation raises an exception, `continuation` is not cleared in the next line, and at the next resumption the continuation is called again. It may loop doing this. This doesn't currently happen because the continuations don't really raise, but it's still a correctness issue. This fix also allows a continuation to spawn a second continuation, if it encounters a second suspension point. This also doesn't happen currently, but the pattern will become useful with async EVM. Signed-off-by: Jamie Lokier <jamie@shareable.org>