Fix compiler bomb
This commit is contained in:
@@ -448,8 +448,18 @@ pub fn return_from_block(ctx: &mut Context, arity: u32, is_function_end: bool) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn start_block(ctx: &mut Context) -> BlockState {
|
pub fn start_block(ctx: &mut Context) -> BlockState {
|
||||||
// free_return_register(ctx, arity);
|
use std::mem;
|
||||||
let current_state = ctx.block_state.clone();
|
|
||||||
|
// OPTIMISATION: We cannot use the parent's stack values (it is disallowed by the spec)
|
||||||
|
// so we start a new stack, using `mem::replace` to ensure that we never
|
||||||
|
// clone or deallocate anything.
|
||||||
|
//
|
||||||
|
// I believe that it would be possible to cause a compiler bomb if we did
|
||||||
|
// not do this, since cloning iterates over the whole `Vec`.
|
||||||
|
let out_stack = mem::replace(&mut ctx.block_state.stack, vec![]);
|
||||||
|
let mut current_state = ctx.block_state.clone();
|
||||||
|
current_state.stack = out_stack;
|
||||||
|
|
||||||
ctx.block_state.parent_locals = ctx.block_state.locals.clone();
|
ctx.block_state.parent_locals = ctx.block_state.locals.clone();
|
||||||
ctx.block_state.return_register = None;
|
ctx.block_state.return_register = None;
|
||||||
current_state
|
current_state
|
||||||
|
|||||||
Reference in New Issue
Block a user