#[cfg(test)]
mod test;
pub mod consts;
use std::sync::Arc;
use cairo_lang_defs::plugin::{MacroPlugin, PluginResult};
use cairo_lang_semantic::plugin::{AsDynMacroPlugin, SemanticPlugin};
use cairo_lang_syntax::node::ast;
use cairo_lang_syntax::node::db::SyntaxGroup;
use cairo_lang_syntax::node::helpers::QueryAttrs;
use consts::*;
pub mod aux_data;
mod contract;
mod dispatcher;
mod entry_point;
pub mod events;
mod storage;
mod storage_access;
mod utils;
use dispatcher::handle_trait;
use events::derive_event_needed;
use storage_access::derive_storage_access_needed;
use self::contract::{handle_contract_by_storage, handle_module};
use self::events::handle_enum;
#[derive(Debug, Default)]
#[non_exhaustive]
pub struct StarkNetPlugin;
impl MacroPlugin for StarkNetPlugin {
fn generate_code(&self, db: &dyn SyntaxGroup, item_ast: ast::Item) -> PluginResult {
match item_ast {
ast::Item::Module(module_ast) => handle_module(db, module_ast),
ast::Item::Trait(trait_ast) => handle_trait(db, trait_ast),
ast::Item::Struct(struct_ast) if derive_event_needed(&struct_ast, db) => {
events::handle_struct(db, struct_ast)
}
ast::Item::Struct(struct_ast) if derive_storage_access_needed(&struct_ast, db) => {
storage_access::handle_struct(db, struct_ast)
}
ast::Item::Struct(struct_ast) if struct_ast.has_attr(db, STORAGE_ATTR) => {
handle_contract_by_storage(db, struct_ast).unwrap_or_default()
}
ast::Item::Enum(enum_ast) => handle_enum(db, enum_ast),
_ => PluginResult::default(),
}
}
}
impl AsDynMacroPlugin for StarkNetPlugin {
fn as_dyn_macro_plugin<'a>(self: Arc<Self>) -> Arc<dyn MacroPlugin + 'a>
where
Self: 'a,
{
self
}
}
impl SemanticPlugin for StarkNetPlugin {}