From 8e1918343fadf2c76d1fb3713b76ecfe7ff20bfc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9my=20Baranx?= Date: Tue, 16 Jul 2024 10:00:20 +0700 Subject: [PATCH] fix cairo file metadata for contracts and models (#2175) --- crates/dojo-lang/src/compiler.rs | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/crates/dojo-lang/src/compiler.rs b/crates/dojo-lang/src/compiler.rs index 11e79380cb..dc52cd7020 100644 --- a/crates/dojo-lang/src/compiler.rs +++ b/crates/dojo-lang/src/compiler.rs @@ -553,7 +553,25 @@ fn save_expanded_source_file( contract_basename: &str, contract_tag: &str, ) -> anyhow::Result<()> { - if let Ok(file_id) = db.module_main_file(module_id) { + if let Ok(files) = db.module_files(module_id) { + let contract_name = naming::get_name_from_tag(contract_tag); + + // search among all the module files (real and virtual), the one named with + // the contract/model name. This is the file containing the Cairo code generated + // from Dojo plugins. + let res = files.iter().filter(|f| f.file_name(db).eq(&contract_name)).collect::>(); + + let file_id = if res.is_empty() { + // if there is no virtual file with the name of the contract/model, just use the main + // module file + match db.module_main_file(module_id) { + Ok(f) => f, + Err(_) => return Err(anyhow!("failed to get source file: {contract_tag}")), + } + } else { + *res[0] + }; + if let Some(file_content) = db.file_content(file_id) { let src_file_name = format!("{contract_basename}.cairo");