Specialization SysML

class Specialization

Implementation of Specialization defined in the KerML specification.

Specification:

Specialization is a Relationship between two Types that requires all instances of the specific type to also be instances of the general Type (i.e., the set of instances of the specific Type is a subset of those of the general Type, which might be the same set).

For language description, see section 7.3.2.3 of the KerML specification. For more details on the model, see section 8.3.3.1.8 of the KerML specification.

%3 Specialization Specialization syside.Specialization Relationship Relationship syside.Relationship Relationship->Specialization Element Element syside.Element Element->Relationship AstNode AstNode syside.AstNode AstNode->Element
Children
Members defined in Specialization (8 members)

CHAINABLE

R

Whether this relationship can be used with chained features.

STD

R

All subtypes of Specialization according to the specification.

children

R

The elements enclosed by curly brackets in textual syntax.

general

R SysML

Implementation of general defined in the KerML specification.

general_target

R

Syside specific accessor for manipulating the target of general.

owning_type

R SysML

Implementation of owning_type defined in the KerML specification.

specific

R SysML

Implementation of specific defined in the KerML specification.

specific_target

R

Syside specific accessor for manipulating the target of specific.

Members inherited from Relationship (12 members)

first_source

R

Convenience method for sources[0].

first_target

R

Convenience method for targets[0].

is_implied

RW SysML

Implementation of is_implied defined in the KerML specification.

is_visibility_implied

R

Returns True if this Relationship is using implicit visibility.

owned_related_elements

R SysML

Implementation of owned_related_element defined in the KerML specification.

owning_related_element

R SysML

Implementation of owning_related_element defined in the KerML specification.

related_elements

R SysML

Implementation of related_element defined in the KerML specification.

sources

R SysML

Implementation of source defined in the KerML specification.

targets

R SysML

Implementation of target defined in the KerML specification.

visibility

RW

The visibility level of the related elements from this Relationship relative to the owning_related_element.

reset_visibility

Reset visibility to its implicit value.

try_set_visibility

Non-throwing alternative to visibility setter.

Members inherited from Element (25 members)

alias_ids

R SysML

Implementation of alias_ids defined in the KerML specification.

comments

R

The owned Comments related by owned_relationships.

declared_name

RW SysML

Implementation of declared_name defined in the KerML specification.

declared_short_name

RW SysML

Implementation of declared_short_name defined in the KerML specification.

documentation

R SysML

Implementation of documentation defined in the KerML specification.

element_id

RW SysML

Implementation of element_id defined in the KerML specification.

is_implied_included

R SysML

Implementation of is_implied_included defined in the KerML specification.

is_library_element

R SysML

Implementation of is_library_element defined in the KerML specification.

metadata

R

The owned metadata related by owned_relationships.

name

R SysML

Implementation of name defined in the KerML specification.

owned_annotations

R SysML

Implementation of owned_annotation defined in the KerML specification.

owned_elements

R SysML

Implementation of owned_element defined in the KerML specification.

owned_relationships

R SysML

Implementation of owned_relationship defined in the KerML specification.

owner

R SysML

Implementation of owner defined in the KerML specification.

owning_membership

R SysML

Implementation of owning_membership defined in the KerML specification.

owning_namespace

R SysML

Implementation of owning_namespace defined in the KerML specification.

owning_relationship

R SysML

Implementation of owning_relationship defined in the KerML specification.

path

R

Return a unique description of the location of this Element in the containment structure rooted in a root Namespace. In most cases the segments will be identical to QualifiedName.

qualified_name

R SysML

Implementation of qualified_name defined in the KerML specification.

scoped_owner

R

The owner of this Element as the parent of owning_membership or owning_relationship otherwise.

sema_state

RW

The state of semantic resolution for this Element. Based on this, sema may skip elements to avoid duplicate work, e.g. when resolving elements in a group of related documents.

short_name

R SysML

Implementation of short_name defined in the KerML specification.

textual_representations

R SysML

Implementation of textual_representation defined in the KerML specification.

__str__

matches_qualified_name

Check if the qualified name of this Element matches the provided segments of a qualified name.

Members inherited from AstNode (7 members)

cst_node

R

The source CST node of self if one exists.

document

R

The document that owns this node.

parent

R

The parent node of self.

__hash__

Identity based hash of this node.

cast

  1. cast(self, *type: type[TNode]) -> TNode

isinstance

Chainable equivalent to isintance(self, type)

try_cast

Checked cast to type.

Attributes

CHAINABLE: bool = True

Whether this relationship can be used with chained features.

Using this in, e.g. append_chain, will not raise TypeError.

STD: tuple[type[syside.Specialization], ...] = ()

All subtypes of Specialization according to the specification.

This is needed because the implementation does not use multiple inheritance like the standard metamodel. However, all would-be inherited attributes are implemented explicitly on classes in Specialization.Std.

When working with standard metamodel types, use:

if isinstance(element, Specialization.STD):
    ...

For type hints, instead use Specialization.Std:

def function(element: Element) -> Specialization.Std:
    ...

Note that Specialization.Std is only defined during TYPE_CHECKING, depending on the Python version used either from __future__ import annotations or def function(...) -> "Specialization.Std" may be required to ensure that annotations are resolved lazily without an actual object present.

property children: syside.RelationshipBody

The elements enclosed by curly brackets in textual syntax.

property general: syside.Type | None

Implementation of general defined in the KerML specification.

Specification:

A Type with a superset of all instances of the specific Type, which might be the same set.

See section 8.3.3.1.8 of the KerML specification for more details.

property general_target: syside.ChainedTypeReference

Syside specific accessor for manipulating the target of general.

property owning_type: syside.Type | None

Implementation of owning_type defined in the KerML specification.

Specification:

The Type that is the specific Type of this Specialization and owns it as its owning_related_element.

See section 8.3.3.1.8 of the KerML specification for more details.

property specific: syside.Type | None

Implementation of specific defined in the KerML specification.

Specification:

A Type with a subset of all instances of the general Type, which might be the same set.

See section 8.3.3.1.8 of the KerML specification for more details.

property specific_target: syside.ChainedTypeReference

Syside specific accessor for manipulating the target of specific.

Used in