C++ Events API
Note
This is correct for only versions of sc-machine that >= 0.10.0.
The C++ Events API is designed to handle event-driven programming within the sc-machine. This section details types of possible events and how to respond to triggered events.
Note
To include this API provide #include <sc-memory/sc_event.hpp>
in your hpp source.
What is event-driven model?
The sc-machine uses event-driven model to manage processing sc-constructions. The sc-memory stores SC-code constructions, which are graph structures, then any kind of events, occurring in sc-memory, is related to changes in these graph constructions.
These are methods that generate events:
GenerateConnector
,EraseElement
,SetLinkContent
.
They publish events to an event queue without needing to know which consumers will receive them. These components filter and distribute events to appropriate consumers. They manage the flow of events and ensure that they reach the correct destinations. Event consumers are the components that listen for and process events. Event consumers can be modules, agents or something else. See FAQ to find out why it works that way.
Within the OSTIS Technology, events are considered only situations in which relationships have changed or new relationships have been generated, or link content have been changed, or some sc-element have been erased.
ScEvent
The sc-machine provides functionality for subscribing to the following elementary types of sc-events:
ScElementaryEvent
is base class for all sc-events, it can be used to handle all sc-events for specified sc-element;ScEventAfterGenerateConnector
, emits each time, when sc-connector from or to specified sc-element is generated;ScEventAfterGenerateOutgoingArc
, emits each time, when outgoing sc-arc from specified sc-element is generated;ScEventAfterGenerateIncomingArc
, emits each time, when incoming sc-arc to specified sc-element is generated;ScEventAfterGenerateEdge
, emits each time, when sc-edge from or to specified sc-element is generated;ScEventBeforeEraseConnector
, emits each time, when sc-connector from or to specified sc-element is erasing;ScEventBeforeEraseOutgoingArc
, emits each time, when outgoing sc-arc from specified sc-element is erasing;ScEventBeforeEraseIncomingArc
, emits each time, when incoming sc-arc to specified sc-element is erasing;ScEventBeforeEraseEdge
, emits each time, when sc-edge from or to specified sc-element is erasing;ScEventBeforeEraseElement
, emits, when specified sc-element is erasing;ScEventBeforeChangeLinkContent
, emits each time, when content of specified sc-link is changing.
The following classes correspond to them:
class ScElementaryEvent
;template <ScType const & connectorType> class ScEventAfterGenerateConnector
;template <ScType const & arcType> class ScEventAfterGenerateOutgoingArc
;template <ScType const & arcType> class ScEventAfterGenerateIncomingArc
;template <ScType const & edgeType> class ScEventAfterGenerateEdge
;template <ScType const & connectorType> class ScEventBeforeEraseConnector
;template <ScType const & arcType> class ScEventBeforeEraseOutgoingArc
;template <ScType const & arcType> class ScEventBeforeEraseIncomingArc
;template <ScType const & edgeType> class ScEventBeforeEraseEdge
;class ScEventBeforeEraseElement
;class ScEventBeforeChangeLinkContent
.
Note
All these sc-events classes are inherited from ScElementaryEvent
class. ScElementaryEvent
class is inherited from ScEvent
class that is an abstract class.
Note
Types of sc-connectors are specified for sc-events of adding (erasing) sc-arc (sc-edge).
Warning
You can't generate objects of these classes. All constructors of these classes are private.
Warning
All objects of sc-event classes are not copyable and not movable.
ScElementaryEvent
This class provides three common methods for all sc-events: GetUser
, GetSubscriptionElement
and GetTriple
.
GetUser
Use this method to get sc-address of who initiated the current sc-event.
GetSubscriptionElement
Each event occurs within a semantic neighbourhood of some sc-element. This sc-element is called sc-event subscription sc-element. In other words, it is an element that is permanently listening for the occurrence of certain sc-events within its neighbourhood. To get it, use this method.
GetTriple
To get information about sc-elements in initiated sc-event, you can use this method. It returns tuple of three ScAddr. For more information see the table below.
Class | Description |
---|---|
ScEventAfterGenerateConnector |
|
ScEventAfterGenerateOutgoingArc |
|
ScEventAfterGenerateIncomingArc |
|
ScEventAfterGenerateEdge |
|
ScEventBeforeEraseConnector |
|
ScEventBeforeEraseOutgoingArc |
|
ScEventBeforeEraseIncomingArc |
|
ScEventBeforeEraseEdge |
|
ScEventBeforeEraseElement |
Example C++ code:
|
ScEventBeforeChangeLinkContent |
|
Note
All described methods of ScElementaryEvent
class are public and accessible from child classes.
ScEventAfterGenerateConnector
ScEventAfterGenerateConnector
is class that represents sc-event of generating sc-connector to or from specified sc-element.
GetConnector
Method GetConnector
returns generated sc-connector to or from listen sc-element (subscription sc-element).
GetConnectorType
It returns sc-type of generated sc-connector.
GetConnectorIncidentElements
A sc-connector can be a sc-arc or a sc-edge, so method GetConnectorIncidentElements
returns two incident elements for the generated sc-connector at once.
ScEventAfterGenerateOutgoingArc and ScEventAfterGenerateIncomingArc
ScEventAfterGenerateOutgoingArc
is class that represents sc-event of generating outgoing sc-arc from specified sc-element. ScEventAfterGenerateIncomingArc
represents sc-event of generating incoming sc-arc to specified sc-element.
GetArc
Method GetArc
returns generated sc-arc from (for ScEventAfterGenerateOutgoingArc
) or to (for ScEventAfterGenerateIncomingArc
) listen sc-element (subscription sc-element).
GetArcType
It returns sc-type of generated sc-arc.
GetArcSourceElement
To get source and target sc-elements of generated sc-arc you can use GetArcSourceElement
and GetArcTargetElement
methods. For ScEventAfterGenerateOutgoingArc
method GetArcSourceElement
returns sc-address of listen sc-element, for ScEventAfterGenerateIncomingArc
method GetArcTargetElement
returns sc-address of listen sc-element.
GetArcTargetElement
ScEventAfterGenerateEdge
This class represents sc-event of adding sc-edge from or to specified sc-element.
GetEdge
Method GetEdge
returns generated sc-edge from or to listen sc-element (subscription sc-element).
GetEdgeType
It returns sc-type of generated sc-edge.
GetEdgeIncidentElements
To get incident sc-elements of generated sc-edge you can use GetEdgeIncidentElements
method.
ScEventBeforeEraseConnector
ScEventBeforeEraseConnector
is class that represents sc-event of erasing sc-connector to or from specified sc-element.
GetConnector
Method GetConnector
returns erasable sc-connector to or from listen sc-element (subscription sc-element).
GetConnectorType
It returns sc-type of erasable sc-connector.
GetConnectorIncidentElements
Method GetConnectorIncidentElements
returns two incident elements for the erasable sc-connector at once.
ScEventBeforeEraseOutgoingArc and ScEventBeforeEraseIncomingArc
ScEventBeforeEraseOutgoingArc
is class that represents sc-event of erasing outgoing sc-arc from specified sc-element. ScEventBeforeEraseIncomingArc
represents sc-event of erasing incoming sc-arc to specified sc-element.
GetArc
Method GetArc
returns erasable sc-arc from (for ScEventBeforeEraseOutgoingArc
) or to (for ScEventBeforeEraseIncomingArc
) listen sc-element (subscription sc-element).
GetArcType
It returns sc-type of erasable sc-arc.
GetArcSourceElement
To get source and target sc-elements of erasable sc-arc you can use GetArcSourceElement
and GetArcTargetElement
methods. For ScEventBeforeEraseOutgoingArc
method GetArcSourceElement
returns sc-address of listen sc-element, for ScEventBeforeEraseIncomingArc
method GetArcTargetElement
returns sc-address of listen sc-element.
GetArcTargetElement
ScEventBeforeEraseEdge
This class represents sc-event of erasing sc-edge from or to specified sc-element.
GetEdge
Method GetEdge
returns erasable sc-edge from or to listen sc-element (subscription sc-element).
GetEdgeType
It returns sc-type of erasable sc-edge.
GetEdgeIncidentElements
To get incident sc-elements of erasable sc-edge you can use GetEdgeIncidentElements
method.
ScEventBeforeEraseElement
This class represents sc-event of erasing specified listen sc-element. You can use all methods from objects of this class that are accessible from ScElementaryEvent
class.
ScEventBeforeChangeLinkContent
This class represents sc-event of changing content for listen sc-link. You can use all methods from objects of this class that are accessible from ScElementaryEvent
class.
Note
For ScEventBeforeEraseElement
and ScEventBeforeChangeLinkContent
method GetTriple
returns tuple of three sc-address. The first one is a sc-event subscription sc-element. The other ones should be empty sc-addresses.
Frequently Asked Questions
- Is there sc-event of creating sc-node?
- Is fact of what happened recorded in the knowledge base? Are sc-events recorded in the knowledge base?
- Why do we need connector events?
Is there sc-event of creating sc-node?
A sc-event is defined as the addition, modification or erasing of connections between sc-elements, or changing link content, or erasing sc-element. This is so because knowledge is not a single sc-element, and knowledge is construction of three sc-elements at least. A sc-element does not carry any knowledge in itself. Therefore, a sc-event is considered to be emergence of some new knowledge. But there is an exception, erasing sc-elements with no connections with other sc-elements is considered an event.
Also, even if events were defined differently, it doesn't negate the fact that one cannot subscribe to sc-event of creating sc-node, since we don't know about that node in advance, because it doesn't exist.
Is fact of what happened recorded in the knowledge base? Are sc-events recorded in the knowledge base?
Right now, sc-events are not recorded in the knowledge base. It will be implemented in the future versions of the sc-machine.
Why do we need connector events?
Event of generating (erasing) sc-connector is needed to subscribe to both generating (erasing) sc-arc and sc-edge.
For example, man B is a brother for woman A, and man B is a brother for man C. Here, the relation to be a brother
between woman A and man B is oriented, i.e. they are connected by a sc-arc, not by a sc-edge, and the relation to be a brother
between man C and man B is undirected, i.e. these men are connected by a sc-edge. In order for an agent to react to appearance of both a sc-arc and a sc-edge from man B to woman A and man C correspondingly, it is necessary to subscribe that agent to appearance of a sc-connector, i.e sc-arc or sc-edge from man B.