capellambse.extensions.reqif package

Tools for handling ReqIF Requirements.

data:image/svg+xml;base64,<svg baseProfile="full" class="ClassDiagramBlank" cursor="pointer" font-family="'Open Sans','Segoe UI',Arial,sans-serif" font-size="11px" height="650" shape-rendering="geometricPrecision" version="1.1" viewBox="445 5 511 650" width="511" xmlns="http://www.w3.org/2000/svg" xmlns:ev="http://www.w3.org/2001/xml-events" xmlns:xlink="http://www.w3.org/1999/xlink"><defs><symbol id="ClassSymbol" viewBox="0 0 25 25"><linearGradient id="ClassSymbol-gradient" x1="0" x2="0" y1="0" y2="1"><stop offset="0.0" stop-color="#cfa6a5" stop-opacity="1" /><stop offset="1.0" stop-color="#f1e2e3" stop-opacity="1" /></linearGradient><g stroke="#913734"><rect fill="#eedcdd" height="3" width="15" x="5" y="17" /><rect fill="#eedcdd" height="3" width="15" x="5" y="14" /><rect fill="url(#ClassSymbol-gradient)" height="10" width="15" x="5" y="4" /></g></symbol><linearGradient id="CustomGradient_FFFFFF_E8E0D2" x1="0" x2="0" y1="0" y2="1"><stop offset="0.0" stop-color="#FFFFFF" stop-opacity="1" /><stop offset="1.0" stop-color="#E8E0D2" stop-opacity="1" /></linearGradient><linearGradient id="CustomGradient_FFFFFF_FAFAFA" x1="0" x2="0" y1="0" y2="1"><stop offset="0.0" stop-color="#FFFFFF" stop-opacity="1" /><stop offset="1.0" stop-color="#FAFAFA" stop-opacity="1" /></linearGradient><linearGradient id="CustomGradient_FFEBA7_FFFFFF" x1="0" x2="0" y1="0" y2="1"><stop offset="0.0" stop-color="#FFEBA7" stop-opacity="1" /><stop offset="1.0" stop-color="#FFFFFF" stop-opacity="1" /></linearGradient><marker id="GeneralizationMark_000000" markerHeight="7.5" markerUnits="userSpaceOnUse" markerWidth="7.5" orient="auto" refX="7" refY="4"><path d="M 0.1275,7.5 7.5,3.75 0,0 Z" fill="#fff" stroke="#000000" stroke-width="1" /></marker></defs><rect fill="#fff" height="650" stroke="none" width="511" x="445" y="5" /><g class="Box Class context-_qETtYLirEeuQHsJc0QO2Dg" id="_TBnaEPHHEeq0lMtL-g80AA"><rect class="Class" fill="url(&quot;#CustomGradient_FFFFFF_E8E0D2&quot;)" height="101" rx="10px" ry="10px" stroke="#077F00" stroke-width="1" width="152" x="475.5" y="15.5" /><text class="Class" dominant-baseline="middle" fill="#009009" font-style="italic" text-anchor="middle" x="475" y="15"><tspan x="562.0" xml:space="preserve" y="23.142857142857142">GenericElement</tspan></text><use height="20" width="20" x="497.6190476190476" xlink:href="#ClassSymbol" y="13.142857142857142" /><line stroke="#077F00" x1="475.5" x2="627.5" y1="39.785714285714285" y2="39.785714285714285" /><text class="Features" dominant-baseline="middle" fill="#009009" font-style="italic" text-anchor="start" x="487.5" y="39.785714285714285"><tspan x="487.5" xml:space="preserve" y="54.07142857142857">uuid : String</tspan><tspan x="487.5" xml:space="preserve" y="72.64285714285714">name : String</tspan><tspan x="487.5" xml:space="preserve" y="91.21428571428571">description :</tspan><tspan x="487.5" xml:space="preserve" y="109.78571428571428">HTML-Text</tspan><tspan x="487.5" xml:space="preserve" y="128.35714285714286">xtype : XType...</tspan></text></g><g class="Box DataPkg" id="_ob4-ELirEeuQHsJc0QO2Dg"><rect class="DataPkg" fill="url(&quot;#CustomGradient_FFFFFF_FAFAFA&quot;)" height="490" stroke="#454545" stroke-width="1" width="491" x="455.5" y="155.5" /><text class="DataPkg" dominant-baseline="middle" fill="#000000" text-anchor="middle" x="455" y="155"><tspan x="700.5" xml:space="preserve" y="167.28571428571428">reqif</tspan></text></g><g class="Box Class context-_qETtYLirEeuQHsJc0QO2Dg context-_qEUUcLirEeuQHsJc0QO2Dg context-_qEUUdbirEeuQHsJc0QO2Dg context-_qEUUerirEeuQHsJc0QO2Dg context-_qEUUf7irEeuQHsJc0QO2Dg" id="_qECAk7irEeuQHsJc0QO2Dg"><rect class="Class" fill="url(&quot;#CustomGradient_FFEBA7_FFFFFF&quot;)" height="125" rx="10px" ry="10px" stroke="#EAA900" stroke-width="1" width="130" x="475.5" y="204.5" /><text class="Class" dominant-baseline="middle" fill="#C06E00" font-style="italic" text-anchor="middle" x="475" y="204"><tspan x="551.0" xml:space="preserve" y="214.28571428571428">ReqIFElement</tspan></text><use height="20" width="20" x="492.3333333333333" xlink:href="#ClassSymbol" y="204.28571428571428" /><line stroke="#EAA900" x1="475.5" x2="605.5" y1="233.07142857142858" y2="233.07142857142858" /><text class="Features" dominant-baseline="middle" fill="#C06E00" font-style="italic" text-anchor="start" x="487.5" y="233.07142857142858"><tspan x="487.5" xml:space="preserve" y="247.35714285714286">identifier :</tspan><tspan x="487.5" xml:space="preserve" y="265.92857142857144">String</tspan><tspan x="487.5" xml:space="preserve" y="284.5">long_name :</tspan><tspan x="487.5" xml:space="preserve" y="303.07142857142856">String</tspan><tspan x="487.5" xml:space="preserve" y="321.6428571428571">description :</tspan><tspan x="487.5" xml:space="preserve" y="340.21428571428567">String</tspan><tspan x="487.5" xml:space="preserve" y="358.7857142857142">name :...</tspan></text></g><g class="Box Class context-_qEUUcLirEeuQHsJc0QO2Dg" id="_qECno7irEeuQHsJc0QO2Dg"><rect class="Class" fill="url(&quot;#CustomGradient_FFEBA7_FFFFFF&quot;)" height="54" rx="10px" ry="10px" stroke="#EAA900" stroke-width="1" width="151" x="545.5" y="512.5" /><text class="Class" dominant-baseline="middle" fill="#C06E00" text-anchor="middle" x="545" y="512"><tspan x="631.5" xml:space="preserve" y="522.2857142857143">RequirementsFolder</tspan></text><use height="20" width="20" x="555.2142857142857" xlink:href="#ClassSymbol" y="512.2857142857143" /><line stroke="#EAA900" x1="545.5" x2="696.5" y1="541.0714285714286" y2="541.0714285714286" /></g><g class="Box Class context-_qEUUdbirEeuQHsJc0QO2Dg" id="_qEDOs7irEeuQHsJc0QO2Dg"><rect class="Class" fill="url(&quot;#CustomGradient_FFEBA7_FFFFFF&quot;)" height="77" rx="10px" ry="10px" stroke="#EAA900" stroke-width="1" width="144" x="705.5" y="364.5" /><text class="Class" dominant-baseline="middle" fill="#C06E00" text-anchor="middle" x="705" y="364"><tspan x="788.0" xml:space="preserve" y="373.57142857142856">Requirement</tspan></text><use height="20" width="20" x="731.2380952380952" xlink:href="#ClassSymbol" y="363.57142857142856" /><line stroke="#EAA900" x1="705.5" x2="849.5" y1="391.64285714285717" y2="391.64285714285717" /><text class="Features" dominant-baseline="middle" fill="#C06E00" text-anchor="start" x="717.5" y="391.64285714285717"><tspan x="717.5" xml:space="preserve" y="405.92857142857144">text : String</tspan><tspan x="717.5" xml:space="preserve" y="424.5">foreign_id :</tspan><tspan x="717.5" xml:space="preserve" y="443.07142857142856">Integer</tspan><tspan x="717.5" xml:space="preserve" y="461.6428571428571">chapter_name...</tspan></text></g><g class="Box Class context-_qEUUerirEeuQHsJc0QO2Dg" id="_qED1wrirEeuQHsJc0QO2Dg"><rect class="Class" fill="url(&quot;#CustomGradient_FFEBA7_FFFFFF&quot;)" height="66" rx="10px" ry="10px" stroke="#EAA900" stroke-width="1" width="100" x="785.5" y="518.5" /><text class="Class" dominant-baseline="middle" fill="#C06E00" text-anchor="middle" x="785" y="518"><tspan x="846.0" xml:space="preserve" y="526.1428571428571">Module</tspan></text><use height="20" width="20" x="803.5238095238095" xlink:href="#ClassSymbol" y="516.1428571428571" /><line stroke="#EAA900" x1="785.5" x2="885.5" y1="542.7857142857143" y2="542.7857142857143" /><text class="Features" dominant-baseline="middle" fill="#C06E00" text-anchor="start" x="797.5" y="542.7857142857143"><tspan x="797.5" xml:space="preserve" y="556.3571428571429">type : String</tspan></text></g><g class="Box Class context-_qEUUf7irEeuQHsJc0QO2Dg" id="_qEEc0rirEeuQHsJc0QO2Dg"><rect class="Class" fill="url(&quot;#CustomGradient_FFEBA7_FFFFFF&quot;)" height="51" rx="10px" ry="10px" stroke="#EAA900" stroke-width="1" width="80" x="755.5" y="233.5" /><text class="Class" dominant-baseline="middle" fill="#C06E00" text-anchor="middle" x="755" y="233"><tspan x="806.0" xml:space="preserve" y="241.14285714285714">Relation</tspan></text><use height="20" width="20" x="762.0952380952381" xlink:href="#ClassSymbol" y="231.14285714285714" /><line stroke="#EAA900" x1="755.5" x2="835.5" y1="257.7857142857143" y2="257.7857142857143" /></g><g class="Edge Generalization" id="_qETtYLirEeuQHsJc0QO2Dg"><path class="Edge" d="M 539.5 204.5 539.5 116.5" fill="none" marker-end="url(&quot;#GeneralizationMark_000000&quot;)" stroke="#000000" stroke-width="1" /></g><g class="Edge Generalization" id="_qEUUcLirEeuQHsJc0QO2Dg"><path class="Edge" d="M 545.5 538.5 525.5 538.5 525.5 329.5" fill="none" marker-end="url(&quot;#GeneralizationMark_000000&quot;)" stroke="#000000" stroke-width="1" /></g><g class="Edge Generalization" id="_qEUUdbirEeuQHsJc0QO2Dg"><path class="Edge" d="M 705.5 393.5 525.5 393.5 525.5 329.5" fill="none" marker-end="url(&quot;#GeneralizationMark_000000&quot;)" stroke="#000000" stroke-width="1" /></g><g class="Edge Generalization" id="_qEUUerirEeuQHsJc0QO2Dg"><path class="Edge" d="M 816.5 584.5 816.5 604.5 526.5 604.5 526.5 329.5" fill="none" marker-end="url(&quot;#GeneralizationMark_000000&quot;)" stroke="#000000" stroke-width="1" /></g><g class="Edge Generalization" id="_qEUUf7irEeuQHsJc0QO2Dg"><path class="Edge" d="M 755.5 273.5 605.5 273.5" fill="none" marker-end="url(&quot;#GeneralizationMark_000000&quot;)" stroke="#000000" stroke-width="1" /></g></svg>
class capellambse.extensions.reqif.AbstractRequirementsAttribute

Bases: GenericElement

definition

The definition of this AbstractRequirementsAttribute.

value: c.AttributeProperty | c.AttrProxyAccessor
class capellambse.extensions.reqif.AbstractRequirementsRelation

Bases: ReqIFElement

source

The source of this AbstractRequirementsRelation.

target

The target of this AbstractRequirementsRelation.

type: c.Accessor

The type of this AbstractRequirementsRelation.

class capellambse.extensions.reqif.AbstractType

Bases: ReqIFElement

attribute_definitions

The attribute definitions of this AbstractType.

owner

The owner of this AbstractType.

class capellambse.extensions.reqif.AttributeAccessor

Bases: DirectProxyAccessor[AbstractRequirementsAttribute]

__init__()

Create a DirectProxyAccessor.

Parameters:
  • class – The proxy class.

  • xtypes – The xsi:type(s) of the child element(s). If None, then the constructed proxy will be passed the original element instead of a child.

  • aslist – If None, only a single element must match, which will be returned directly. If not None, must be a subclass of ElementList, which will be used to return a list of all matched objects.

  • follow_abstract – Follow the link in the abstractType XML attribute of each list member and instantiate that object instead. The default is to instantiate the child elements directly.

  • list_extra_args – Extra arguments to pass to the ElementList constructor.

  • rootelem – A class or xsi:type (or list thereof) that defines the path from the current object’s XML element to the search root. If None, the current element will be used directly.

  • single_attr – If objects can be created with only a single attribute specified, this argument is the name of that attribute. This create_singleattr().

Return type:

None

follow_abstract: bool
rootelem: cabc.Sequence[str]
class capellambse.extensions.reqif.AttributeDefinition

Bases: ReqIFElement

An attribute definition for requirement types.

data_type

The data type of this AttributeDefinition.

class capellambse.extensions.reqif.AttributeDefinitionEnumeration

Bases: ReqIFElement

An enumeration attribute definition for requirement types.

data_type

The data type of this AttributeDefinitionEnumeration.

multi_valued

Boolean flag for setting multiple enumeration values on the attribute

class capellambse.extensions.reqif.BooleanValueAttribute

Bases: AbstractRequirementsAttribute

A string value attribute.

value: c.AttributeProperty | c.AttrProxyAccessor
class capellambse.extensions.reqif.CapellaIncomingRelation

Bases: AbstractRequirementsRelation

A Relation between a requirement and an object.

class capellambse.extensions.reqif.CapellaModule

Bases: ReqIFElement

A ReqIF Module that bundles multiple Requirement folders.

attributes

The attributes of this CapellaModule.

folders

The folders of this CapellaModule.

requirement_types_folders

The requirement types folders of this CapellaModule.

requirements

The requirements of this CapellaModule.

to_reqif(to, *, metadata=None, pretty=False, compress=None)

Export this module as ReqIF XML.

You can override some auto-generated metadata placed in the header section by passing a dictionary as metadata. The following keys are supported. Unsupported keys are silently ignored.

  • creation_time: A datetime.datetime object that specifies this document’s creation time. Default to the current time.

  • comment: Override the ReqIF file’s comment. Defaults to a text derived from the model and module names.

  • title: Specify the document title. Defaults to the module’s long_name.

Parameters:
  • to (str | PathLike | IO[bytes]) – Where to export to. Can be the name of a file, or a file-like object opened in binary mode.

  • metadata (Mapping[str, Any] | None) – A dictionary with additional metadata (see above).

  • pretty (bool) – Format the XML human-readable.

  • compress (bool | None) – Write compressed data (*.reqifz). Defaults to True if target is a string or path-like and its name ends in .reqifz, otherwise defaults to False.

Return type:

None

type: c.Accessor

The type of this CapellaModule.

class capellambse.extensions.reqif.CapellaOutgoingRelation

Bases: AbstractRequirementsRelation

A Relation between an object and a requirement.

source

The source of this CapellaOutgoingRelation.

target

The target of this CapellaOutgoingRelation.

class capellambse.extensions.reqif.CapellaTypesFolder

Bases: ReqIFElement

data_type_definitions

The data type definitions of this CapellaTypesFolder.

module_types

The module types of this CapellaTypesFolder.

relation_types

The relation types of this CapellaTypesFolder.

requirement_types

The requirement types of this CapellaTypesFolder.

class capellambse.extensions.reqif.DataTypeDefinition

Bases: ReqIFElement

A data type definition for requirement types.

class capellambse.extensions.reqif.DateValueAttribute

Bases: AbstractRequirementsAttribute

A value attribute that stores a date and time.

value: c.AttributeProperty | c.AttrProxyAccessor
class capellambse.extensions.reqif.ElementRelationAccessor

Bases: WritableAccessor[rq.AbstractRequirementsRelation]

Provides access to RequirementsRelations of a GenericElement.

__init__()
Return type:

None

aslist: type[ElementListCouplingMixin] | None
purge_references(obj, target)

Do nothing.

This is a no-op, as this accessor provides a virtual relation.

The relation objects it handles are cleaned up by removing the source or target attribute.

Parameters:
Return type:

Generator[None, None, None]

class capellambse.extensions.reqif.EnumValue

Bases: ReqIFElement

An enumeration value for EnumerationDataTypeDefinition.

class capellambse.extensions.reqif.EnumerationDataTypeDefinition

Bases: ReqIFElement

An enumeration data type definition for requirement types.

values

The values of this EnumerationDataTypeDefinition.

class capellambse.extensions.reqif.EnumerationValueAttribute

Bases: AbstractRequirementsAttribute

An enumeration attribute.

definition

The definition of this EnumerationValueAttribute.

property value
values

The values of this EnumerationValueAttribute.

class capellambse.extensions.reqif.Folder

Bases: Requirement

A folder that stores Requirements.

folders: c.Accessor

The folders of this Folder.

requirements

The requirements of this Folder.

class capellambse.extensions.reqif.IntegerValueAttribute

Bases: AbstractRequirementsAttribute

An integer value attribute.

value: c.AttributeProperty | c.AttrProxyAccessor
class capellambse.extensions.reqif.InternalRelation

Bases: AbstractRequirementsRelation

A Relation between two requirements.

class capellambse.extensions.reqif.ModuleType

Bases: AbstractType

A requirement-module type.

class capellambse.extensions.reqif.RealValueAttribute

Bases: AbstractRequirementsAttribute

A floating-point number value attribute.

value: c.AttributeProperty | c.AttrProxyAccessor
class capellambse.extensions.reqif.RelationType

Bases: AbstractType

A requirement-relation type.

class capellambse.extensions.reqif.RelationsList

Bases: ElementList[rq.AbstractRequirementsRelation]

__init__(model, elements, elemclass=None, *, source)
Parameters:
Return type:

None

by_relation_class(class_)
Parameters:

class_ (Literal['incoming', 'outgoing', 'internal'])

Return type:

RelationsList

by_relation_type(reltype)
Parameters:

reltype (str)

Return type:

RelationsList

class capellambse.extensions.reqif.ReqIFElement

Bases: GenericElement

Attributes shared by all ReqIF elements.

description: str
identifier
long_name
name
prefix
property type
class capellambse.extensions.reqif.Requirement

Bases: ReqIFElement

A ReqIF Requirement.

attributes

The attributes of this Requirement.

chapter_name
foreign_id
owner

The owner of this Requirement.

related: c.Accessor[c.GenericElement]

The related of this Requirement.

relations: c.Accessor[AbstractRequirementsRelation]

The relations of this Requirement.

text
type: c.Accessor

The type of this Requirement.

class capellambse.extensions.reqif.RequirementType

Bases: AbstractType

A requirement type.

class capellambse.extensions.reqif.RequirementsRelationAccessor

Bases: WritableAccessor[rq.AbstractRequirementsRelation]

Searches for requirement relations in the architecture layer.

__init__(*args, **kw)
Return type:

None

aslist: type[ElementListCouplingMixin] | None
create(elmlist, /, *type_hints, **kw)

Create and return a new element of type elmclass.

Parameters:
  • elmlist (ElementListCouplingMixin) – The (coupled) ElementList to insert the new object into.

  • type_hints (str | None) – Hints for finding the correct type of element to create. Can either be a full or shortened xsi:type string, or an abbreviation defined by the specific Accessor instance.

  • kw (Any) – Initialize the properties of the new object. Depending on the object’s type, some attributes may be required.

Return type:

InternalRelation | CapellaIncomingRelation

delete(elmlist, obj)

Delete the obj from the model.

Return type:

None

insert(elmlist, index, value)

Insert the value object into the model.

The object must be inserted at an appropriate place, so that, if elmlist were to be created afresh, value would show up at index index.

Parameters:
Return type:

None

purge_references(obj, target)

Do nothing.

This is a no-op, as this accessor provides a virtual relation.

The relation objects it handles are cleaned up by removing the source or target attribute.

Parameters:
Return type:

Generator[None, None, None]

class capellambse.extensions.reqif.StringValueAttribute

Bases: AbstractRequirementsAttribute

A string value attribute.

value: c.AttributeProperty | c.AttrProxyAccessor
capellambse.extensions.reqif.init()
Return type:

None

Submodules

capellambse.extensions.reqif.exporter module

Implementation of a ReqIF 1.1 and 1.2 exporter.

capellambse.extensions.reqif.exporter.export_module(module, target, *, metadata=None, pretty=False, compress=None)
Parameters:
Return type:

None