fix problem with missing function generations when functions have same name in different files

This commit is contained in:
Moritz Hölting 2024-06-10 20:32:10 +02:00
parent ae1492aa42
commit deddf1d77e
1 changed files with 18 additions and 21 deletions

View File

@ -26,7 +26,7 @@ pub struct Transpiler {
datapack: shulkerbox::datapack::Datapack, datapack: shulkerbox::datapack::Datapack,
/// Key: (program identifier, function name) /// Key: (program identifier, function name)
functions: RwLock<HashMap<(String, String), FunctionData>>, functions: RwLock<HashMap<(String, String), FunctionData>>,
function_locations: RwLock<HashMap<String, String>>, function_locations: RwLock<HashMap<(String, String), String>>,
} }
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
@ -152,32 +152,29 @@ impl Transpiler {
program_identifier: &str, program_identifier: &str,
handler: &impl Handler<TranspileError>, handler: &impl Handler<TranspileError>,
) -> TranspileResult<String> { ) -> TranspileResult<String> {
let program_query = (program_identifier.to_string(), name.to_string());
let already_transpiled = { let already_transpiled = {
let locations = self.function_locations.read().unwrap(); let locations = self.function_locations.read().unwrap();
locations.get(name).is_some() locations.get(&program_query).is_some()
}; };
if !already_transpiled { if !already_transpiled {
let statements = { let statements = {
let functions = self.functions.read().unwrap(); let functions = self.functions.read().unwrap();
let function_data = functions let function_data = functions.get(&program_query).ok_or_else(|| {
.get(&(program_identifier.to_string(), name.to_string())) let error = TranspileError::MissingFunctionDeclaration(name.to_string());
.ok_or_else(|| { handler.receive(error.clone());
let error = TranspileError::MissingFunctionDeclaration(name.to_string()); error
handler.receive(error.clone()); })?;
error
})?;
function_data.statements.clone() function_data.statements.clone()
}; };
let commands = self.transpile_function(&statements, program_identifier, handler)?; let commands = self.transpile_function(&statements, program_identifier, handler)?;
let functions = self.functions.read().unwrap(); let functions = self.functions.read().unwrap();
let function_data = functions let function_data = functions.get(&program_query).ok_or_else(|| {
.get(&(program_identifier.to_string(), name.to_string())) let error = TranspileError::MissingFunctionDeclaration(name.to_string());
.ok_or_else(|| { handler.receive(error.clone());
let error = TranspileError::MissingFunctionDeclaration(name.to_string()); error
handler.receive(error.clone()); })?;
error
})?;
let modified_name = function_data let modified_name = function_data
.annotations .annotations
@ -209,15 +206,15 @@ impl Transpiler {
self.datapack.add_load(&function_location); self.datapack.add_load(&function_location);
} }
self.function_locations self.function_locations.write().unwrap().insert(
.write() (program_identifier.to_string(), name.to_string()),
.unwrap() function_location,
.insert(name.to_string(), function_location); );
} }
let locations = self.function_locations.read().unwrap(); let locations = self.function_locations.read().unwrap();
locations locations
.get(name) .get(&program_query)
.ok_or_else(|| { .ok_or_else(|| {
let error = TranspileError::MissingFunctionDeclaration(name.to_string()); let error = TranspileError::MissingFunctionDeclaration(name.to_string());
handler.receive(error.clone()); handler.receive(error.clone());