About
An interface can declare an observable object. This observable will notify observers (callback functions) when a certain event occurs.
Usage
This interface declares the observable "ObservablePing" that will notify observers when the function "Ping" is called:
{
{
public:
};
}
Py_ssize_t count
Definition: abstract.h:640
MAXON_INTERFACE(ObserveMeInterface, MAXON_REFERENCE_NORMAL, "net.maxonexample.interfaces.observeme")
MAXON_OBSERVABLE(Result< void >, ObservablePing,(maxon::Int32 count), maxon::ObservableCombinerRunAllComponent)
int32_t Int32
32 bit signed integer datatype.
Definition: apibase.h:190
#define MAXON_REFERENCE_NORMAL(FREEIMPL)
Definition: interfacebase.h:1184
#define MAXON_METHOD
Definition: interfacebase.h:1012
#define MAXON_INTERFACE_BASES(...)
Definition: objectbase.h:1049
The maxon namespace contains all declarations of the MAXON API.
Definition: autoweight.h:14
Such a callback function must have the same return value and argument list as defined in the observable declaration:
{
}
Int64 Int
signed 32/64 bit int, size depends on the platform
Definition: apibase.h:202
return OK
Definition: apibase.h:2735
#define DiagnosticOutput(formatString,...)
Definition: debugdiagnostics.h:170
The observable is accessible by the function of its name. An observer is added with maxon::ObservableBaseInterface::AddObserver():
g_observeMe.ObservablePing(
true).AddObserver(WatchPing)
iferr_return;
#define iferr_return
Definition: resultbase.h:1524
It is also possible to add lambdas to the observable.
g_observeMe.ObservablePing(true).AddObserver(
{
The observer functions are called when the specific event is triggered.
Further Reading