| libSBOL
    2.3.3
    | 
The FunctionalComponent class is used to specify the functional usage of a ComponentDefinition inside a ModuleDefinition. The ModuleDefinition describes how the that describes how the FunctionalComponent interacts with others and summarizes their aggregate function.
| Public Attributes | |
| URIProperty | direction | 
| Each FunctionalComponent MUST specify via the direction property whether it serves as an input, output, both, or neither for its parent ModuleDefinition object.  More... | |
| ReferencedObject | definition | 
| The definition property is a REQUIRED URI that refers to the ComponentDefinition of the ComponentInstance.  More... | |
| URIProperty | access | 
| The access property is a REQUIRED URI that indicates whether the ComponentInstance can be referred to remotely by a MapsTo.  More... | |
| OwnedObject< MapsTo > | mapsTos | 
| The mapsTos property is OPTIONAL and MAY contain a set of MapsTo objects that refer to and link together ComponentInstance objects (both Component objects and FunctionalComponent objects) within a larger design. | |
| OwnedObject< Measurement > | measurements | 
| The measurements property links a ComponentInstance to parameters or measurements and their associated units. For example a Measurement attached to a FunctionalComponent might indicate the quantity of a component ingredient in a growth medium recipe. | |
| URIProperty | persistentIdentity | 
| The persistentIdentity property is OPTIONAL and has a data type of URI. This URI serves to uniquely refer to a set of SBOL objects that are different versions of each other. An Identified object MUST be referred to using either its identity URI or its persistentIdentity URI. | |
| TextProperty | displayId | 
| The displayId property is an OPTIONAL identifier with a data type of String. This property is intended to be an intermediate between name and identity that is machine-readable, but more human-readable than the full URI of an identity. If the displayId property is used, then its String value SHOULD be locally unique (global uniqueness is not necessary) and MUST be composed of only alphanumeric or underscore characters and MUST NOT begin with a digit. | |
| VersionProperty | version | 
| If the version property is used, then it is RECOMMENDED that version numbering follow the conventions of semantic versioning, particularly as implemented by Maven. This convention represents versions as sequences of numbers and qualifiers that are separated by the characters “.” and “-” and are compared in lexicographical order (for example, 1 < 1.3.1 < 2.0-beta). For a full explanation, see the linked resources. | |
| URIProperty | wasDerivedFrom | 
| The wasDerivedFrom property is OPTIONAL and has a data type of URI. An SBOL object with this property refers to another SBOL object or non-SBOL resource from which this object was derived. If the wasDerivedFrom property of an SBOL object A that refers to an SBOL object B has an identical persistentIdentity, and both A and B have a version, then the version of B MUST precede that of A. In addition, an SBOL object MUST NOT refer to itself via its own wasDerivedFrom property or form a cyclical chain of references via its wasDerivedFrom property and those of other SBOL objects. For example, the reference chain “ A was derived from B and B was derived from A” is cyclical. | |
| ReferencedObject | wasGeneratedBy | 
| An Activity which generated this ComponentDefinition, eg., a design process like codon-optimization or a construction process like Gibson Assembly. | |
| TextProperty | name | 
| The name property is OPTIONAL and has a data type of String. This property is intended to be displayed to a human when visualizing an Identified object. If an Identified object lacks a name, then software tools SHOULD instead display the object’s displayId or identity. It is RECOMMENDED that software tools give users the ability to switch perspectives between name properties that are human-readable and displayId properties that are less human-readable, but are more likely to be unique. | |
| TextProperty | description | 
| The description property is OPTIONAL and has a data type of String. This property is intended to contain a more thorough text description of an Identified object. | |
| URIProperty | identity | 
| The identity property is REQUIRED by all Identified objects and has a data type of URI. A given Identified object’s identity URI MUST be globally unique among all other identity URIs. The identity of a compliant SBOL object MUST begin with a URI prefix that maps to a domain over which the user has control. Namely, the user can guarantee uniqueness of identities within this domain. For other best practices regarding URIs see Section 11.2 of the SBOL specification doucment. | |
| Public Member Functions | |
| FunctionalComponent (std::string uri="example", std::string definition="", std::string access=SBOL_ACCESS_PUBLIC, std::string direction=SBOL_DIRECTION_NONE, std::string version=VERSION_STRING) | |
| Construct a FunctionalComponent.  More... | |
| void | connect (FunctionalComponent &interface_component) | 
| This method connects module inputs and outputs.  More... | |
| void | mask (FunctionalComponent &masked_component) | 
| This method is used to state that FunctionalComponents in separate ModuleDefinitions are functionally equivalent.  More... | |
| void | override (FunctionalComponent &masked_component) | 
| This method is used to state that FunctionalComponents in separate ModuleDefinitions are functionally equivalent.  More... | |
| int | isMasked () | 
| Used to tell if a FunctionalComponent is linked to an equivalent FunctionalComponent in another ModuleDefinition.  More... | |
| virtual rdf_type | getTypeURI () | 
| std::string | getClassName (std::string type) | 
| SBOLObject * | find (std::string uri) | 
| Search this object recursively to see if an object or any child object with URI already exists.  More... | |
| SBOLObject * | find_property (std::string uri) | 
| Search this object recursively to see if it contains a member property with the given RDF type.  More... | |
| std::vector< SBOLObject * > | find_property_value (std::string uri, std::string value, std::vector< SBOLObject *> matches={}) | 
| Search this object recursively to see if it contains a member property with the given RDF type and indicated property value.  More... | |
| std::vector< SBOLObject * > | find_reference (std::string uri) | 
| Search this object recursively to see if it contains a member property with the given RDF type and indicated property value.  More... | |
| int | compare (SBOLObject *comparand) | 
| Compare two SBOL objects or Documents.  More... | |
| std::string | getPropertyValue (std::string property_uri) | 
| Get the value of a custom annotation property by its URI.  More... | |
| std::vector< std::string > | getPropertyValues (std::string property_uri) | 
| Get all values of a custom annotation property by its URI.  More... | |
| std::vector< std::string > | getProperties () | 
| Gets URIs for all properties contained by this object.  More... | |
| void | setPropertyValue (std::string property_uri, std::string val) | 
| Set and overwrite the value for a user-defined annotation property.  More... | |
| void | addPropertyValue (std::string property_uri, std::string val) | 
| Append a value to a user-defined annotation property.  More... | |
| void | setAnnotation (std::string property_uri, std::string val) | 
| Set the value for a user-defined annotation property.  More... | |
| std::string | getAnnotation (std::string property_uri) | 
| Get the value of a custom annotation property by its URI.  More... | |
| virtual void | close () | 
| Use this method to destroy an SBOL object that is not contained by a parent Document.  More... | |
| Protected Member Functions | |
| Identified & | copy (Document *target_doc=NULL, std::string ns="", std::string version="") | 
| Copy an object and automatically increment its version.  More... | |
| template<class ExtensionClass > | |
| void | register_extension_class (std::string ns, std::string ns_prefix, std::string class_name) | 
| Register an extension class and its namespace, so custom data can be embedded into and read from SBOL files.  More... | |
| 
 | inline | 
Construct a FunctionalComponent.
If operating in SBOL-compliant mode, use ModuleDefinition::functionalComponents::create instead.
| A | full URI including a scheme, namespace, and identifier. If SBOLCompliance configuration is enabled, then this argument is simply the displayId for the new object and a full URI will automatically be constructed. | 
| definition | A URI referring to the ComponentDefinition that defines this instance | 
| access | Flag indicating whether the FunctionalComponent can be referred to remotely by a MapsTo | 
| direction | The direction property specifies whether a FunctionalComponent serves as an input, output, both, or neither for its parent ModuleDefinition object | 
| version | An arbitrary version string. If SBOLCompliance is enabled, this should be a Maven version string of the form "major.minor.patch". | 
| 
 | inherited | 
Append a value to a user-defined annotation property.
Either a literal or URI value
| 
 | virtualinherited | 
| 
 | inherited | 
Compare two SBOL objects or Documents.
The behavior is currently undefined for objects with custom annotations or extension classes.
| comparand | A pointer to the object being compared to this one. | 
| void connect | ( | FunctionalComponent & | interface_component | ) | 
This method connects module inputs and outputs.
This convenience method auto-constructs a MapsTo object. See Biosystem Design for an example
| interface_component | An input or output component from another ModuleDefinition that corresponds with this component. | 
| 
 | protectedinherited | 
Copy an object and automatically increment its version.
If the optional version argument is specified, it will be used instead of incrementing the copied object's version. An object may also be copied into a new document and a new namespace, assuming compliant URIs.
| SBOLClass | The type of SBOL object being copied | 
| new_doc | The new copies will be attached to this Document. NULL by default. | 
| ns | This namespace will be substituted for the current namespace (as configured by setHomespace) in all SBOL-compliat URIs. | 
| version | A new version | 
| 
 | inherited | 
Search this object recursively to see if an object or any child object with URI already exists.
| uri | The URI to search for. | 
| 
 | inherited | 
Search this object recursively to see if it contains a member property with the given RDF type.
| uri | The RDF type of the property to search for. | 
| 
 | inherited | 
Search this object recursively to see if it contains a member property with the given RDF type and indicated property value.
| uri | The RDF type of the property to search for. | 
| value | The property value to match | 
| 
 | inherited | 
Search this object recursively to see if it contains a member property with the given RDF type and indicated property value.
| uri | A URI, either an ontology term or an object reference, to search for | 
| 
 | inherited | 
Get the value of a custom annotation property by its URI.
Synonymous with getPropertyValue
| property_uri | The URI for the property | 
| 
 | inherited | 
| 
 | inherited | 
Gets URIs for all properties contained by this object.
This includes SBOL core properties as well as custom annotations. Use this to find custom extension data in an SBOL file.
| 
 | inherited | 
Get the value of a custom annotation property by its URI.
| property_uri | The URI for the property | 
| 
 | inherited | 
Get all values of a custom annotation property by its URI.
| property_uri | The URI for the property | 
| 
 | virtualinherited | 
| int isMasked | ( | ) | 
Used to tell if a FunctionalComponent is linked to an equivalent FunctionalComponent in another ModuleDefinition.
| void mask | ( | FunctionalComponent & | masked_component | ) | 
This method is used to state that FunctionalComponents in separate ModuleDefinitions are functionally equivalent.
Using this method will override the FunctionalComponent in the argument with the FunctionalComponent calling the method. This is useful for overriding a generic, template component with an explicitly defined component. This convenience method auto-constructs a MapsTo object. See Biosystem Design for an example
| masked_component | The FunctionalComponent that is being masked (over-ridden) | 
| void override | ( | FunctionalComponent & | masked_component | ) | 
This method is used to state that FunctionalComponents in separate ModuleDefinitions are functionally equivalent.
Using this method will override the FunctionalComponent in the argument with the FunctionalComponent calling the method. This is useful for overriding a generic, template component with an explicitly defined component. This convenience method auto-constructs a MapsTo object. See Biosystem Design for an example
| masked_component | The FunctionalComponent that is being masked (over-ridden) | 
| 
 | protectedinherited | 
Register an extension class and its namespace, so custom data can be embedded into and read from SBOL files.
| ExtensionClass | The new class | 
| ns | The extension namespace, eg, http://myhome.org/my_extension#. It's important that the namespace ends in a forward-slash or hash | 
| ns_prefix | A shorthand symbol for the full namespace as it will appear in the output file, eg, my_extension | 
| 
 | inherited | 
Set the value for a user-defined annotation property.
Synonymous with setPropertyValue If the value is a URI, it should be surrounded by angle brackets, else it will be interpreted as a literal value
| 
 | inherited | 
Set and overwrite the value for a user-defined annotation property.
Either a literal or URI value
| 
 | inherited | 
The access property is a REQUIRED URI that indicates whether the ComponentInstance can be referred to remotely by a MapsTo.
The value of the access property MUST be one of the following URIs.
| Access URI | Description | 
|---|---|
| http://sbols.org/v2#public | The ComponentInstance MAY be referred to by remote MapsTo objects | 
| http://sbols.org/v2#private | The ComponentInstance MAY be referred to by remote MapsTo objects | 
| 
 | inherited | 
The definition property is a REQUIRED URI that refers to the ComponentDefinition of the ComponentInstance.
As described in the previous section, this ComponentDefinition effectively provides information about the types and roles of the ComponentInstance. The definition property MUST NOT refer to the same ComponentDefinition as the one that contains the ComponentInstance. Furthermore, ComponentInstance objects MUST NOT form a cyclical chain of references via their definition properties and the ComponentDefinition objects that contain them. For example, consider the ComponentInstance objects A and B and the ComponentDefinition objects X and Y . The reference chain “X contains A, A isdefinedby Y, Y contains B, and B isdefinedby X” iscyclical.
| URIProperty direction | 
Each FunctionalComponent MUST specify via the direction property whether it serves as an input, output, both, or neither for its parent ModuleDefinition object.
The value for this property MUST be one of the URIs given in the table below.
| Direction URI | Description | LibSBOL Symbol | 
|---|---|---|
| http://sbols.org/v2#in | Indicates that the FunctionalComponent is an input. | SBOL_DIRECTION_IN | 
| http://sbols.org/v2#out | Indicates that the FunctionalComponent is an output. | SBOL_DIRECTION_OUT | 
| http://sbols.org/v2#inout | Indicates that the FunctionalComponent is both an input and output | SBOL_DIRECTION_IN_OUT | 
| http://sbols.org/v2#none | Indicates that the FunctionalComponent is neither an input or output. | SBOL_DIRECTION_NONE | 
Inherits ComponentInstance.
 1.8.14
 1.8.14