From 8e4401c5e6a68cb7c5eed0985255fd38c9c5c0d1 Mon Sep 17 00:00:00 2001 From: Tobias Wienand Date: Fri, 20 Sep 2024 11:29:07 +0200 Subject: [PATCH] Implements compilation of arrays with spreading --- Sources/Fuzzilli/Compiler/Compiler.swift | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/Sources/Fuzzilli/Compiler/Compiler.swift b/Sources/Fuzzilli/Compiler/Compiler.swift index cfd88a31b..bca0790f2 100644 --- a/Sources/Fuzzilli/Compiler/Compiler.swift +++ b/Sources/Fuzzilli/Compiler/Compiler.swift @@ -833,17 +833,31 @@ public class JavaScriptCompiler { case .arrayExpression(let arrayExpression): var elements = [Variable]() var undefined: Variable? = nil + var spreads = [Bool]() for elem in arrayExpression.elements { if elem.expression == nil { if undefined == nil { undefined = emit(LoadUndefined()).output } elements.append(undefined!) + spreads.append(false) } else { - elements.append(try compileExpression(elem)) + if case .spreadElement(let spreadElement) = elem.expression { + elements.append(try compileExpression(spreadElement.argument)) + spreads.append(true) + } + else { + elements.append(try compileExpression(elem)) + spreads.append(false) + } } } - return emit(CreateArray(numInitialValues: elements.count), withInputs: elements).output + if spreads.contains(true) { + return emit(CreateArrayWithSpread(spreads: spreads), withInputs: elements).output + } + else { + return emit(CreateArray(numInitialValues: elements.count), withInputs: elements).output + } case .functionExpression(let functionExpression): let parameters = convertParameters(functionExpression.parameters)