slang::ast::InstanceSymbol class

Represents an instance of a module, interface, or program.

Base classes

class InstanceSymbolBase
Common functionality for module, interface, program, and primitive instances.

Public static functions

static auto createDefault(Compilation& compilation, const DefinitionSymbol& definition, const HierarchyOverrideNode* hierarchyOverrideNode = nullptr, const ConfigBlockSymbol* configBlock = nullptr, const ConfigRule* configRule = nullptr, SourceLocation locationOverride = {}) -> InstanceSymbol&
Creates a default-instantiated instance of the given definition.
static auto createVirtual(const ASTContext& context, SourceLocation loc, const DefinitionSymbol& definition, const syntax::ParameterValueAssignmentSyntax* paramAssignments) -> InstanceSymbol&
Creates a placeholder instance for a virtual interface type declaration.
static auto createDefaultNested(const Scope& scope, const syntax::ModuleDeclarationSyntax& syntax) -> Symbol&
Creates a default-instantiated instance of a nested definition in the provided scope.
static auto createInvalid(Compilation& compilation, const DefinitionSymbol& definition) -> InstanceSymbol&
Creates an intentionally invalid instance by forcing all parameters to null values.

Public functions

auto getCanonicalBody() const -> const InstanceBodySymbol*
If it has been determined that the body of this instance is an exact duplicate of another, this returns a pointer to the canonical copy to avoid duplicating effort visiting this instance's body again.

Public variables

const ResolvedConfig* resolvedConfig
A config rule that applies to this instance, or a pointer to the parent instance's config rule if there is one up the stack.

Function documentation

static InstanceSymbol& slang::ast::InstanceSymbol::createDefault(Compilation& compilation, const DefinitionSymbol& definition, const HierarchyOverrideNode* hierarchyOverrideNode = nullptr, const ConfigBlockSymbol* configBlock = nullptr, const ConfigRule* configRule = nullptr, SourceLocation locationOverride = {})

Creates a default-instantiated instance of the given definition.

All parameters must have defaults specified.

static InstanceSymbol& slang::ast::InstanceSymbol::createInvalid(Compilation& compilation, const DefinitionSymbol& definition)

Creates an intentionally invalid instance by forcing all parameters to null values.

This allows type checking instance members as long as they don't depend on any parameters.

const InstanceBodySymbol* slang::ast::InstanceSymbol::getCanonicalBody() const

If it has been determined that the body of this instance is an exact duplicate of another, this returns a pointer to the canonical copy to avoid duplicating effort visiting this instance's body again.

Otherwise returns nullptr.