Remove unneeded Luau branch gadgets
Fixiee
This commit is contained in:
		
							parent
							
								
									49bc994353
								
							
						
					
					
						commit
						cdefb2f06a
					
				| @ -1,29 +0,0 @@ | ||||
| use std::collections::HashMap; | ||||
| 
 | ||||
| use wasm_ast::{ | ||||
| 	node::{BrTable, FuncData}, | ||||
| 	visit::{Driver, Visitor}, | ||||
| }; | ||||
| 
 | ||||
| struct Visit { | ||||
| 	id_map: HashMap<usize, usize>, | ||||
| } | ||||
| 
 | ||||
| impl Visitor for Visit { | ||||
| 	fn visit_br_table(&mut self, table: &BrTable) { | ||||
| 		let id = table as *const _ as usize; | ||||
| 		let len = self.id_map.len() + 1; | ||||
| 
 | ||||
| 		self.id_map.insert(id, len); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| pub fn visit(ast: &FuncData) -> HashMap<usize, usize> { | ||||
| 	let mut visit = Visit { | ||||
| 		id_map: HashMap::new(), | ||||
| 	}; | ||||
| 
 | ||||
| 	ast.accept(&mut visit); | ||||
| 
 | ||||
| 	visit.id_map | ||||
| } | ||||
							
								
								
									
										40
									
								
								codegen/luau/src/analyzer/br_target.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								codegen/luau/src/analyzer/br_target.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,40 @@ | ||||
| use std::collections::HashMap; | ||||
| 
 | ||||
| use wasm_ast::{ | ||||
| 	node::{Br, BrIf, BrTable, FuncData}, | ||||
| 	visit::{Driver, Visitor}, | ||||
| }; | ||||
| 
 | ||||
| struct Visit { | ||||
| 	br_map: HashMap<usize, usize>, | ||||
| 	has_branch: bool, | ||||
| } | ||||
| 
 | ||||
| impl Visitor for Visit { | ||||
| 	fn visit_br(&mut self, _: &Br) { | ||||
| 		self.has_branch = true; | ||||
| 	} | ||||
| 
 | ||||
| 	fn visit_br_if(&mut self, _: &BrIf) { | ||||
| 		self.has_branch = true; | ||||
| 	} | ||||
| 
 | ||||
| 	fn visit_br_table(&mut self, table: &BrTable) { | ||||
| 		let id = table as *const _ as usize; | ||||
| 		let len = self.br_map.len() + 1; | ||||
| 
 | ||||
| 		self.has_branch = true; | ||||
| 		self.br_map.insert(id, len); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| pub fn visit(ast: &FuncData) -> (HashMap<usize, usize>, bool) { | ||||
| 	let mut visit = Visit { | ||||
| 		br_map: HashMap::new(), | ||||
| 		has_branch: false, | ||||
| 	}; | ||||
| 
 | ||||
| 	ast.accept(&mut visit); | ||||
| 
 | ||||
| 	(visit.br_map, visit.has_branch) | ||||
| } | ||||
| @ -1,3 +1,3 @@ | ||||
| pub mod as_symbol; | ||||
| pub mod br_table; | ||||
| pub mod br_target; | ||||
| pub mod localize; | ||||
|  | ||||
| @ -9,7 +9,7 @@ use wasm_ast::node::{ | ||||
| }; | ||||
| use wasmparser::ValType; | ||||
| 
 | ||||
| use crate::analyzer::br_table; | ||||
| use crate::analyzer::br_target; | ||||
| 
 | ||||
| use super::manager::{ | ||||
| 	write_ascending, write_condition, write_separated, write_variable, Driver, Manager, | ||||
| @ -130,7 +130,7 @@ fn write_br_gadget( | ||||
| 	label: usize, | ||||
| 	w: &mut dyn Write, | ||||
| ) -> Result<()> { | ||||
| 	if label_list.len() == 1 { | ||||
| 	if label_list.len() == 1 || label_list.iter().all(Option::is_none) { | ||||
| 		return Ok(()); | ||||
| 	} | ||||
| 
 | ||||
| @ -340,17 +340,20 @@ fn write_variable_list(ast: &FuncData, w: &mut dyn Write) -> Result<()> { | ||||
| 
 | ||||
| impl Driver for FuncData { | ||||
| 	fn write(&self, mng: &mut Manager, w: &mut dyn Write) -> Result<()> { | ||||
| 		let br_map = br_table::visit(self); | ||||
| 		let br_data = br_target::visit(self); | ||||
| 
 | ||||
| 		write_parameter_list(self, w)?; | ||||
| 		write_variable_list(self, w)?; | ||||
| 		write!(w, "local desired ")?; | ||||
| 
 | ||||
| 		if !br_map.is_empty() { | ||||
| 		if br_data.1 { | ||||
| 			write!(w, "local desired ")?; | ||||
| 		} | ||||
| 
 | ||||
| 		if !br_data.0.is_empty() { | ||||
| 			write!(w, "local br_map = {{}} ")?; | ||||
| 		} | ||||
| 
 | ||||
| 		mng.set_table_map(br_map); | ||||
| 		mng.set_table_map(br_data.0); | ||||
| 		mng.set_num_param(self.num_param()); | ||||
| 		self.code().write(mng, w)?; | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user