use std::fmt::Write;
use cairo_lang_debug::DebugWithDb;
use cairo_lang_defs::ids::NamedLanguageElementId;
use cairo_lang_syntax::node::{TypedStablePtr, TypedSyntaxNode};
use cairo_lang_test_utils::parse_test_file::TestRunnerResult;
use cairo_lang_utils::ordered_hash_map::OrderedHashMap;
use super::Usages;
use crate::Expr;
use crate::expr::fmt::ExprFormatter;
use crate::items::function_with_body::FunctionWithBodySemantic;
use crate::test_utils::{SemanticDatabaseForTesting, setup_test_function};
cairo_lang_test_utils::test_file_test!(
usage,
"src/usage/test_data",
{
usage: "usage",
},
test_function_usage
);
fn test_function_usage(
inputs: &OrderedHashMap<String, String>,
_args: &OrderedHashMap<String, String>,
) -> TestRunnerResult {
let db = &mut SemanticDatabaseForTesting::default();
let (test_function, semantic_diagnostics) = setup_test_function(db, inputs).split();
let file_id =
test_function.function_id.name_identifier(db).stable_ptr(db).untyped().file_id(db);
let expr_formatter = ExprFormatter { db, function_id: test_function.function_id };
let function_def =
db.function_body(test_function.concrete_function_id.function_with_body_id(db)).unwrap();
let usages = Usages::from_function_body(function_def);
let mut usages_str = String::new();
for (expr_id, usage) in usages.usages.iter() {
let expr = &function_def.arenas.exprs[*expr_id];
let stable_ptr = expr.stable_ptr();
let node = stable_ptr.untyped().lookup(db);
let position = node.span_start_without_trivia(db).position_in_file(db, file_id).unwrap();
match expr {
Expr::Loop(_) => write!(usages_str, "Loop").unwrap(),
Expr::While(_) => write!(usages_str, "While").unwrap(),
Expr::For(_) => write!(usages_str, "For").unwrap(),
Expr::ExprClosure(_) => write!(usages_str, "Closure").unwrap(),
_ => unreachable!(),
}
writeln!(usages_str, " {}:{}:", position.line, position.col).unwrap();
write!(usages_str, " Usage:").unwrap();
for (_, expr) in usage.usage.iter() {
write!(usages_str, " {:?},", expr.debug(expr_formatter.db)).unwrap();
}
writeln!(usages_str).unwrap();
write!(usages_str, " Changes:").unwrap();
for (_, expr) in usage.changes.iter() {
write!(usages_str, " {:?},", expr.debug(expr_formatter.db)).unwrap();
}
writeln!(usages_str).unwrap();
write!(usages_str, " Snapshot_Usage:").unwrap();
for (_, expr) in usage.snap_usage.iter() {
write!(usages_str, " {:?},", expr.debug(expr_formatter.db)).unwrap();
}
writeln!(usages_str).unwrap();
}
TestRunnerResult::success(OrderedHashMap::from([
("semantic_diagnostics".into(), semantic_diagnostics),
("usage".into(), usages_str),
]))
}