sway_core/language/ty/
code_block.rsuse std::hash::Hasher;
use sway_error::handler::{ErrorEmitted, Handler};
use sway_types::Span;
use crate::{
decl_engine::*, engine_threading::*, language::ty::*, semantic_analysis::TypeCheckContext,
type_system::*,
};
#[derive(Clone, Debug)]
pub struct TyCodeBlock {
pub contents: Vec<TyAstNode>,
pub(crate) whole_block_span: Span,
}
impl Default for TyCodeBlock {
fn default() -> Self {
Self {
contents: Default::default(),
whole_block_span: Span::dummy(),
}
}
}
impl EqWithEngines for TyCodeBlock {}
impl PartialEqWithEngines for TyCodeBlock {
fn eq(&self, other: &Self, ctx: &PartialEqWithEnginesContext) -> bool {
self.contents.eq(&other.contents, ctx)
}
}
impl HashWithEngines for TyCodeBlock {
fn hash<H: Hasher>(&self, state: &mut H, engines: &Engines) {
let TyCodeBlock { contents, .. } = self;
contents.hash(state, engines);
}
}
impl SubstTypes for TyCodeBlock {
fn subst_inner(&mut self, ctx: &SubstTypesContext) -> HasChanges {
self.contents.subst(ctx)
}
}
impl ReplaceDecls for TyCodeBlock {
fn replace_decls_inner(
&mut self,
decl_mapping: &DeclMapping,
handler: &Handler,
ctx: &mut TypeCheckContext,
) -> Result<bool, ErrorEmitted> {
handler.scope(|handler| {
let mut has_changes = false;
for node in self.contents.iter_mut() {
if let Ok(r) = node.replace_decls(decl_mapping, handler, ctx) {
has_changes |= r;
}
}
Ok(has_changes)
})
}
}
impl UpdateConstantExpression for TyCodeBlock {
fn update_constant_expression(&mut self, engines: &Engines, implementing_type: &TyDecl) {
self.contents
.iter_mut()
.for_each(|x| x.update_constant_expression(engines, implementing_type));
}
}