nac3artiq: throw error message when constructor use rpc decorator #306

Merged
sb10q merged 10 commits from issue-221 into master 2022-07-11 15:55:55 +08:00
1 changed files with 13 additions and 13 deletions
Showing only changes of commit 90d7243bf5 - Show all commits

View File

@ -393,21 +393,21 @@ impl Nac3 {
let class_obj = module.getattr(py, name.to_string()).unwrap(); let class_obj = module.getattr(py, name.to_string()).unwrap();
for stmt in body.iter() { for stmt in body.iter() {
if let StmtKind::FunctionDef { name, decorator_list, .. } = &stmt.node { if let StmtKind::FunctionDef { name, decorator_list, .. } = &stmt.node {
// checking: constructor __init__ must not be decorated with rpc if let Some(location) = decorator_list
.iter()
.find_map(|ast::Located { location, node, .. } | {
match node {
ExprKind::Name { id, .. } if id == &"rpc".into() => Some(location),
_ => None,
}
})
{
if name == &"__init__".into() { if name == &"__init__".into() {
for decorator in decorator_list.iter() {
if let ast::Located { location, node: ExprKind::Name { id, .. }, .. } = decorator {
if id == &"rpc".into() {
return Err(CompileError::new_err(format!( return Err(CompileError::new_err(format!(
"compilation failed\n----------\nConstructor __init__ function should not decorated with rpc decorator (at {})", "compilation failed\n----------\nConstructor __init__ function should not decorated with rpc decorator (at {})",
location location
))); )));
} }
}
}
}
if decorator_list.iter().any(|decorator| matches!(decorator.node, ExprKind::Name { id, .. } if id == "rpc".into())) {
rpc_ids.push((Some((class_obj.clone(), *name)), def_id)); rpc_ids.push((Some((class_obj.clone(), *name)), def_id));
} }
} }