ConsoleDomain class.
More...
#include <C:/Users/Andres/source/repos/casm_viewer/external/tinc/external/allolib/include/al/app/al_ConsoleDomain.hpp>
|
std::function< bool(const std::string &)> | onLine |
|
|
void | callStartCallbacks () |
| callStartCallbacks should be called by children of this class after the domain has been set up to start, before going into the blocking loop
|
|
void | callStopCallbacks () |
| callStopCallbacks should be called by children of this class on the stop request, before the domain has been stopped
|
|
bool | initializeSubdomains (bool pre=false) |
| initializeSubdomains should be called within the domain's initialization function More...
|
|
bool | tickSubdomains (bool pre=false) |
| execute subdomains More...
|
|
bool | cleanupSubdomains (bool pre=false) |
| cleanup subdomains More...
|
|
void | callInitializeCallbacks () |
| callInitializeCallbacks should be called by children of this class after the domain has been initialized
|
|
void | callCleanupCallbacks () |
| callInitializeCallbacks should be called by children of this class before the domain has been cleaned up
|
|
|
std::mutex | mSubdomainLock |
|
double | mTimeDrift {0.0} |
|
std::vector< std::pair< std::shared_ptr< SynchronousDomain >, bool > > | mSubDomainList |
|
std::vector< ParameterMeta * > | mParameters |
|
ConsoleDomain class.
This domain is a blocking domain, i.e. blocks on start(). Set the onLine() function to get lines entered in the console. My default, the domain exits when the line is empty (when return is pressed). You can use this domain instead of app to build your own command line classes.
Definition at line 21 of file al_ConsoleDomain.hpp.
◆ cleanup()
◆ cleanupSubdomains()
bool al::ComputationDomain::cleanupSubdomains |
( |
bool |
pre = false | ) |
|
|
protectedinherited |
cleanup subdomains
- Parameters
-
pre | cleanup prepended domains if true, otherwise appended domains. |
- Returns
- true if all cleanup sucessful.
You must call this function twice: once for prepended and then for appended domains.
◆ init()
◆ initializeSubdomains()
bool al::ComputationDomain::initializeSubdomains |
( |
bool |
pre = false | ) |
|
|
protectedinherited |
initializeSubdomains should be called within the domain's initialization function
- Parameters
-
pre | initialize prepended domains if true, otherwise appended domains. |
- Returns
- true if all initializations sucessful.
You must call this function twice: once for prepended and then for appended domains.
◆ newSubDomain()
template<class DomainType >
std::shared_ptr< DomainType > al::ComputationDomain::newSubDomain |
( |
bool |
prepend = false | ) |
|
|
inherited |
Add a synchronous domain to this domain.
- Parameters
-
prepend | Determines whether the sub-domain should run before or after this domain |
- Returns
- the created domain.
The domain specified by DomainType must inherit from SynchronousDomian. It will trigger an assertion if not (will have undefined behavior for Release builds) This operation is thread safe if the domain can pause itself, but it is blocking, so there are no guarantees that it will not interefere with the timely running of the domain.
Definition at line 218 of file al_ComputationDomain.hpp.
◆ parameters()
std::vector<ParameterMeta *> al::ComputationDomain::parameters |
( |
| ) |
|
|
inlineinherited |
Return a list of parameters that control this domain.
- Returns
- list of parameters
The parameters provided here provide runtime "continuous" parameters, for example like audio gain or eye separation. There should be a clear distinction between values that need to be set on domain intialization that must remain immutable during domain operation and parameters provided here that provide continuous adjustment to the domain's operation.
Definition at line 104 of file al_ComputationDomain.hpp.
◆ registerCleanupCallback()
void al::ComputationDomain::registerCleanupCallback |
( |
std::function< void(ComputationDomain *)> |
callback | ) |
|
|
inherited |
register callbacks to be called in the cleanup() function
- Parameters
-
◆ registerInitializeCallback()
void al::ComputationDomain::registerInitializeCallback |
( |
std::function< void(ComputationDomain *)> |
callback | ) |
|
|
inherited |
register callbacks to be called in the init() function
- Parameters
-
◆ removeSubDomain()
void al::ComputationDomain::removeSubDomain |
( |
std::shared_ptr< SynchronousDomain > |
subDomain | ) |
|
|
inherited |
Remove a subdomain.
- Parameters
-
subDomain | This operation is thread safe, but it might block causing drops or missed deadlines for the parent domain. If this is a problem, the domain should be stopped prior to adding/removeing sub-domains. |
◆ start()
bool al::ConsoleDomain::start |
( |
| ) |
|
|
inlineoverridevirtual |
◆ stop()
bool al::ConsoleDomain::stop |
( |
| ) |
|
|
inlineoverridevirtual |
◆ tickSubdomains()
bool al::ComputationDomain::tickSubdomains |
( |
bool |
pre = false | ) |
|
|
protectedinherited |
execute subdomains
- Parameters
-
pre | execute prepended domains if true, otherwise appended domains. |
- Returns
- true if all execution sucessful.
You must call this function twice: once for prepended and then for appended domains.
◆ timeDelta()
double al::ComputationDomain::timeDelta |
( |
| ) |
|
|
inlineinherited |
Return time delta with respect to previous processing pass for this domain.
- Returns
- time delta
The time delta may be set internally by the domain so that it is available whenever the domain ticks. It might be 0 for domains that don't support this functionality or that are tied to strict hardware clocks where this information is not necessary
Definition at line 75 of file al_ComputationDomain.hpp.
◆ onLine
std::function<bool(const std::string &)> al::ConsoleDomain::onLine |
Initial value:=
[](const std::string &line) {
if (line.size() == 0) {
return false;
}
return true;
}
Definition at line 37 of file al_ConsoleDomain.hpp.
The documentation for this class was generated from the following file: