sway_core/language/parsed/use_statement.rs
use crate::{language::Visibility, parsed::Span};
use serde::{Deserialize, Serialize};
use sway_types::ident::Ident;
#[derive(Debug, Clone, PartialEq, Eq, Hash, Serialize, Deserialize)]
pub enum ImportType {
Star,
SelfImport(Span),
Item(Ident),
}
/// A [UseStatement] is a statement that imports something from a module into the local namespace.
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
pub struct UseStatement {
pub call_path: Vec<Ident>,
pub span: Span,
pub import_type: ImportType,
// If `is_relative_to_package_root` is true, then this use statement is a path relative to the
// project root. For example, if the path is `::X::Y` and occurs in package `P`, then the path
// refers to the full path `P::X::Y`.
// If `is_relative_to_package_root` is false, then there are two options:
// - The path refers to a path relative to the current namespace. For example, if the path is
// `X::Y` and it occurs in a module whose path is `P::M`, then the path refers to the full
// path `P::M::X::Y`.
// - The path refers to a path in an external package. For example, the path `X::Y` refers to an
// entity `Y` in the external package `X`.
pub is_relative_to_package_root: bool,
// If `reexport` is Visibility::Public, then this use statement reexports its imported binding.
// If not, then the import binding is private to the importing module.
pub reexport: Visibility,
pub alias: Option<Ident>,
}