mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-11-03 23:00:58 +00:00 
			
		
		
		
	It simplifies ladders of BinaryOperators nodes in the function call arguments into nice and neat FunctionCall node. Ladders initially appear since I do not want to complicate expression parser, so it interprets `f(a, b, c, d)` as `f "function_call_operator" (a, (b, (c, d))))`.
		
			
				
	
	
		
			26 lines
		
	
	
	
		
			701 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
	
		
			701 B
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (c) 2023, Dan Klishch <danilklishch@gmail.com>
 | 
						|
 *
 | 
						|
 * SPDX-License-Identifier: BSD-2-Clause
 | 
						|
 */
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include "Compiler/GenericASTPass.h"
 | 
						|
 | 
						|
namespace JSSpecCompiler {
 | 
						|
 | 
						|
// FunctionCallCanonicalizationPass simplifies ladders of BinaryOperators nodes in the function call
 | 
						|
// arguments into nice and neat FunctionCall nodes.
 | 
						|
//
 | 
						|
// Ladders initially appear since I do not want to complicate expression parser, so it interprets
 | 
						|
// `f(a, b, c, d)` as `f "function_call_operator" (a, (b, (c, d))))`.
 | 
						|
class FunctionCallCanonicalizationPass : public GenericASTPass {
 | 
						|
public:
 | 
						|
    using GenericASTPass::GenericASTPass;
 | 
						|
 | 
						|
protected:
 | 
						|
    RecursionDecision on_entry(Tree tree) override;
 | 
						|
};
 | 
						|
 | 
						|
}
 |