pub mod assert;
pub use assert::*;
pub mod assign;
pub use assign::*;
pub mod block;
pub use block::*;
pub mod conditional;
pub use conditional::*;
pub mod console;
pub use console::*;
pub mod const_;
pub use const_::*;
pub mod definition;
pub use definition::*;
pub mod expression;
pub use expression::*;
pub mod iteration;
pub use iteration::*;
pub mod return_;
pub use return_::*;
use crate::{Node, NodeID};
use leo_span::Span;
use serde::{Deserialize, Serialize};
use std::fmt;
#[derive(Clone, PartialEq, Eq, Serialize, Deserialize, Debug)]
pub enum Statement {
Assert(AssertStatement),
Assign(Box<AssignStatement>),
Block(Block),
Conditional(ConditionalStatement),
Console(ConsoleStatement),
Const(ConstDeclaration),
Definition(DefinitionStatement),
Expression(ExpressionStatement),
Iteration(Box<IterationStatement>),
Return(ReturnStatement),
}
impl Statement {
pub fn dummy(span: Span, id: NodeID) -> Self {
Self::Block(Block { statements: Vec::new(), span, id })
}
pub(crate) fn semicolon(&self) -> &'static str {
use Statement::*;
if matches!(self, Block(..) | Conditional(..) | Iteration(..)) { "" } else { ";" }
}
}
impl fmt::Display for Statement {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
Statement::Assert(x) => x.fmt(f),
Statement::Assign(x) => x.fmt(f),
Statement::Block(x) => x.fmt(f),
Statement::Conditional(x) => x.fmt(f),
Statement::Console(x) => x.fmt(f),
Statement::Const(x) => x.fmt(f),
Statement::Definition(x) => x.fmt(f),
Statement::Expression(x) => x.fmt(f),
Statement::Iteration(x) => x.fmt(f),
Statement::Return(x) => x.fmt(f),
}
}
}
impl Node for Statement {
fn span(&self) -> Span {
use Statement::*;
match self {
Assert(n) => n.span(),
Assign(n) => n.span(),
Block(n) => n.span(),
Conditional(n) => n.span(),
Console(n) => n.span(),
Const(n) => n.span(),
Definition(n) => n.span(),
Expression(n) => n.span(),
Iteration(n) => n.span(),
Return(n) => n.span(),
}
}
fn set_span(&mut self, span: Span) {
use Statement::*;
match self {
Assert(n) => n.set_span(span),
Assign(n) => n.set_span(span),
Block(n) => n.set_span(span),
Conditional(n) => n.set_span(span),
Console(n) => n.set_span(span),
Const(n) => n.set_span(span),
Definition(n) => n.set_span(span),
Expression(n) => n.set_span(span),
Iteration(n) => n.set_span(span),
Return(n) => n.set_span(span),
}
}
fn id(&self) -> NodeID {
use Statement::*;
match self {
Assert(n) => n.id(),
Assign(n) => n.id(),
Block(n) => n.id(),
Conditional(n) => n.id(),
Console(n) => n.id(),
Const(n) => n.id(),
Definition(n) => n.id(),
Expression(n) => n.id(),
Iteration(n) => n.id(),
Return(n) => n.id(),
}
}
fn set_id(&mut self, id: NodeID) {
use Statement::*;
match self {
Assert(n) => n.set_id(id),
Assign(n) => n.set_id(id),
Block(n) => n.set_id(id),
Conditional(n) => n.set_id(id),
Console(n) => n.set_id(id),
Const(n) => n.set_id(id),
Definition(n) => n.set_id(id),
Expression(n) => n.set_id(id),
Iteration(n) => n.set_id(id),
Return(n) => n.set_id(id),
}
}
}