mod abi;
mod configurable;
mod constant;
mod r#enum;
pub mod function;
mod impl_trait;
mod storage;
mod r#struct;
mod r#trait;
mod type_alias;
mod variable;
use std::fmt;
pub use abi::*;
pub use configurable::*;
pub use constant::*;
pub use function::*;
pub use impl_trait::*;
pub use r#enum::*;
pub use r#struct::*;
pub use r#trait::*;
pub use storage::*;
use sway_types::{Ident, Span, Spanned};
pub use type_alias::*;
pub use variable::*;
use crate::{
decl_engine::{
parsed_engine::{ParsedDeclEngine, ParsedDeclEngineGet},
parsed_id::ParsedDeclId,
},
engine_threading::{
DebugWithEngines, DisplayWithEngines, EqWithEngines, PartialEqWithEngines,
PartialEqWithEnginesContext,
},
language::Visibility,
Engines,
};
#[derive(Debug, Clone)]
pub enum Declaration {
VariableDeclaration(ParsedDeclId<VariableDeclaration>),
FunctionDeclaration(ParsedDeclId<FunctionDeclaration>),
TraitDeclaration(ParsedDeclId<TraitDeclaration>),
StructDeclaration(ParsedDeclId<StructDeclaration>),
EnumDeclaration(ParsedDeclId<EnumDeclaration>),
EnumVariantDeclaration(EnumVariantDeclaration),
ImplTrait(ParsedDeclId<ImplTrait>),
ImplSelf(ParsedDeclId<ImplSelf>),
AbiDeclaration(ParsedDeclId<AbiDeclaration>),
ConstantDeclaration(ParsedDeclId<ConstantDeclaration>),
ConfigurableDeclaration(ParsedDeclId<ConfigurableDeclaration>),
StorageDeclaration(ParsedDeclId<StorageDeclaration>),
TypeAliasDeclaration(ParsedDeclId<TypeAliasDeclaration>),
TraitTypeDeclaration(ParsedDeclId<TraitTypeDeclaration>),
}
#[derive(Debug, Clone)]
pub struct EnumVariantDeclaration {
pub enum_ref: ParsedDeclId<EnumDeclaration>,
pub variant_name: Ident,
pub variant_decl_span: Span,
}
impl Declaration {
pub(crate) fn is_test(&self, engines: &Engines) -> bool {
if let Declaration::FunctionDeclaration(fn_decl) = self {
let fn_decl = engines.pe().get_function(fn_decl);
fn_decl.is_test()
} else {
false
}
}
pub fn friendly_type_name(&self) -> &'static str {
use Declaration::*;
match self {
VariableDeclaration(_) => "variable",
ConstantDeclaration(_) => "constant",
ConfigurableDeclaration(_) => "configurable",
TraitTypeDeclaration(_) => "type",
FunctionDeclaration(_) => "function",
TraitDeclaration(_) => "trait",
StructDeclaration(_) => "struct",
EnumDeclaration(_) => "enum",
EnumVariantDeclaration(_) => "enum variant",
ImplSelf(_) => "impl self",
ImplTrait(_) => "impl trait",
AbiDeclaration(_) => "abi",
StorageDeclaration(_) => "contract storage",
TypeAliasDeclaration(_) => "type alias",
}
}
pub fn span(&self, engines: &Engines) -> sway_types::Span {
use Declaration::*;
let pe = engines.pe();
match self {
VariableDeclaration(decl_id) => pe.get_variable(decl_id).span(),
FunctionDeclaration(decl_id) => pe.get_function(decl_id).span(),
TraitDeclaration(decl_id) => pe.get_trait(decl_id).span(),
StructDeclaration(decl_id) => pe.get_struct(decl_id).span(),
EnumDeclaration(decl_id) => pe.get_enum(decl_id).span(),
EnumVariantDeclaration(decl) => decl.variant_decl_span.clone(),
ImplTrait(decl_id) => pe.get_impl_trait(decl_id).span(),
ImplSelf(decl_id) => pe.get_impl_self(decl_id).span(),
AbiDeclaration(decl_id) => pe.get_abi(decl_id).span(),
ConstantDeclaration(decl_id) => pe.get_constant(decl_id).span(),
ConfigurableDeclaration(decl_id) => pe.get_configurable(decl_id).span(),
StorageDeclaration(decl_id) => pe.get_storage(decl_id).span(),
TypeAliasDeclaration(decl_id) => pe.get_type_alias(decl_id).span(),
TraitTypeDeclaration(decl_id) => pe.get_trait_type(decl_id).span(),
}
}
pub(crate) fn visibility(&self, decl_engine: &ParsedDeclEngine) -> Visibility {
match self {
Declaration::TraitDeclaration(decl_id) => decl_engine.get_trait(decl_id).visibility,
Declaration::ConstantDeclaration(decl_id) => {
decl_engine.get_constant(decl_id).visibility
}
Declaration::ConfigurableDeclaration(decl_id) => {
decl_engine.get_configurable(decl_id).visibility
}
Declaration::StructDeclaration(decl_id) => decl_engine.get_struct(decl_id).visibility,
Declaration::EnumDeclaration(decl_id) => decl_engine.get_enum(decl_id).visibility,
Declaration::EnumVariantDeclaration(decl) => {
decl_engine.get_enum(&decl.enum_ref).visibility
}
Declaration::FunctionDeclaration(decl_id) => {
decl_engine.get_function(decl_id).visibility
}
Declaration::TypeAliasDeclaration(decl_id) => {
decl_engine.get_type_alias(decl_id).visibility
}
Declaration::VariableDeclaration(_decl_id) => Visibility::Private,
Declaration::ImplTrait(_)
| Declaration::ImplSelf(_)
| Declaration::StorageDeclaration(_)
| Declaration::AbiDeclaration(_)
| Declaration::TraitTypeDeclaration(_) => Visibility::Public,
}
}
}
impl DisplayWithEngines for Declaration {
fn fmt(&self, f: &mut fmt::Formatter<'_>, engines: &Engines) -> std::fmt::Result {
write!(
f,
"{} parsed declaration ({})",
self.friendly_type_name(),
match self {
Declaration::VariableDeclaration(decl_id) => {
engines.pe().get(decl_id).name.as_str().into()
}
Declaration::FunctionDeclaration(decl_id) => {
engines.pe().get(decl_id).name.as_str().into()
}
Declaration::TraitDeclaration(decl_id) => {
engines.pe().get(decl_id).name.as_str().into()
}
Declaration::StructDeclaration(decl_id) => {
engines.pe().get(decl_id).name.as_str().into()
}
Declaration::EnumDeclaration(decl_id) => {
engines.pe().get(decl_id).name.as_str().into()
}
Declaration::ImplTrait(decl_id) => {
engines
.pe()
.get(decl_id)
.trait_name
.as_vec_string()
.join("::")
.as_str()
.into()
}
Declaration::TypeAliasDeclaration(decl_id) =>
engines.pe().get(decl_id).name.as_str().into(),
_ => String::new(),
}
)
}
}
impl DebugWithEngines for Declaration {
fn fmt(&self, f: &mut fmt::Formatter<'_>, engines: &Engines) -> std::fmt::Result {
DisplayWithEngines::fmt(&self, f, engines)
}
}
impl EqWithEngines for Declaration {}
impl PartialEqWithEngines for Declaration {
fn eq(&self, other: &Self, ctx: &PartialEqWithEnginesContext) -> bool {
let decl_engine = ctx.engines().pe();
match (self, other) {
(Declaration::VariableDeclaration(lid), Declaration::VariableDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::FunctionDeclaration(lid), Declaration::FunctionDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::TraitDeclaration(lid), Declaration::TraitDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::StructDeclaration(lid), Declaration::StructDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::EnumDeclaration(lid), Declaration::EnumDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::ImplTrait(lid), Declaration::ImplTrait(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::ImplSelf(lid), Declaration::ImplSelf(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::AbiDeclaration(lid), Declaration::AbiDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::ConstantDeclaration(lid), Declaration::ConstantDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::StorageDeclaration(lid), Declaration::StorageDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::TypeAliasDeclaration(lid), Declaration::TypeAliasDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
(Declaration::TraitTypeDeclaration(lid), Declaration::TraitTypeDeclaration(rid)) => {
decl_engine.get(lid).eq(&decl_engine.get(rid), ctx)
}
_ => false,
}
}
}