512 lines
28 KiB
HTML
512 lines
28 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
<meta name="generator" content="Doxygen 1.8.16"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>EnTT: entt::scheduler< Delta > Class Template Reference</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="jquery.js"></script>
|
|
<script type="text/javascript" src="dynsections.js"></script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
<script type="text/javascript" src="search/search.js"></script>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
</head>
|
|
<body>
|
|
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
<div id="titlearea">
|
|
<table cellspacing="0" cellpadding="0">
|
|
<tbody>
|
|
<tr style="height: 56px;">
|
|
<td id="projectalign" style="padding-left: 0.5em;">
|
|
<div id="projectname">EnTT
|
|
 <span id="projectnumber">3.3.0</span>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.16 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
/* @license-end */</script>
|
|
<div id="main-nav"></div>
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
</div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<iframe src="javascript:void(0)" frameborder="0"
|
|
name="MSearchResults" id="MSearchResults">
|
|
</iframe>
|
|
</div>
|
|
|
|
<div id="nav-path" class="navpath">
|
|
<ul>
|
|
<li class="navelem"><a class="el" href="namespaceentt.html">entt</a></li><li class="navelem"><a class="el" href="classentt_1_1scheduler.html">scheduler</a></li> </ul>
|
|
</div>
|
|
</div><!-- top -->
|
|
<div class="header">
|
|
<div class="summary">
|
|
<a href="#nested-classes">Classes</a> |
|
|
<a href="#pub-types">Public Types</a> |
|
|
<a href="#pub-methods">Public Member Functions</a> |
|
|
<a href="classentt_1_1scheduler-members.html">List of all members</a> </div>
|
|
<div class="headertitle">
|
|
<div class="title">entt::scheduler< Delta > Class Template Reference</div> </div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
|
|
<p>Cooperative scheduler for processes.
|
|
<a href="classentt_1_1scheduler.html#details">More...</a></p>
|
|
|
|
<p><code>#include <<a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>></code></p>
|
|
<table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
|
|
Public Types</h2></td></tr>
|
|
<tr class="memitem:afcec47d6ec28a994af2a7097348ce59f"><td class="memItemLeft" align="right" valign="top"><a id="afcec47d6ec28a994af2a7097348ce59f"></a>
|
|
using </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#afcec47d6ec28a994af2a7097348ce59f">size_type</a> = std::size_t</td></tr>
|
|
<tr class="memdesc:afcec47d6ec28a994af2a7097348ce59f"><td class="mdescLeft"> </td><td class="mdescRight">Unsigned integer type. <br /></td></tr>
|
|
<tr class="separator:afcec47d6ec28a994af2a7097348ce59f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table><table class="memberdecls">
|
|
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
|
|
Public Member Functions</h2></td></tr>
|
|
<tr class="memitem:a49a81e662dc26831f4a951a715705d6e"><td class="memItemLeft" align="right" valign="top"><a id="a49a81e662dc26831f4a951a715705d6e"></a>
|
|
 </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#a49a81e662dc26831f4a951a715705d6e">scheduler</a> ()=default</td></tr>
|
|
<tr class="memdesc:a49a81e662dc26831f4a951a715705d6e"><td class="mdescLeft"> </td><td class="mdescRight">Default constructor. <br /></td></tr>
|
|
<tr class="separator:a49a81e662dc26831f4a951a715705d6e"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af582ffea72368a83ea4dd7d9e563f715"><td class="memItemLeft" align="right" valign="top"><a id="af582ffea72368a83ea4dd7d9e563f715"></a>
|
|
 </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#af582ffea72368a83ea4dd7d9e563f715">scheduler</a> (<a class="el" href="classentt_1_1scheduler.html">scheduler</a> &&)=default</td></tr>
|
|
<tr class="memdesc:af582ffea72368a83ea4dd7d9e563f715"><td class="mdescLeft"> </td><td class="mdescRight">Default move constructor. <br /></td></tr>
|
|
<tr class="separator:af582ffea72368a83ea4dd7d9e563f715"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aea6ab78dbf00ba17c6e828ee0505afd9"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classentt_1_1scheduler.html">scheduler</a> & </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#aea6ab78dbf00ba17c6e828ee0505afd9">operator=</a> (<a class="el" href="classentt_1_1scheduler.html">scheduler</a> &&)=default</td></tr>
|
|
<tr class="memdesc:aea6ab78dbf00ba17c6e828ee0505afd9"><td class="mdescLeft"> </td><td class="mdescRight">Default move assignment operator. <a href="classentt_1_1scheduler.html#aea6ab78dbf00ba17c6e828ee0505afd9">More...</a><br /></td></tr>
|
|
<tr class="separator:aea6ab78dbf00ba17c6e828ee0505afd9"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ab0c473e6d4733bdb78f3dc26147de4ad"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classentt_1_1scheduler.html#afcec47d6ec28a994af2a7097348ce59f">size_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#ab0c473e6d4733bdb78f3dc26147de4ad">size</a> () const ENTT_NOEXCEPT</td></tr>
|
|
<tr class="memdesc:ab0c473e6d4733bdb78f3dc26147de4ad"><td class="mdescLeft"> </td><td class="mdescRight">Number of processes currently scheduled. <a href="classentt_1_1scheduler.html#ab0c473e6d4733bdb78f3dc26147de4ad">More...</a><br /></td></tr>
|
|
<tr class="separator:ab0c473e6d4733bdb78f3dc26147de4ad"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a817d93653aec6a479b920143bd21edbb"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#a817d93653aec6a479b920143bd21edbb">empty</a> () const ENTT_NOEXCEPT</td></tr>
|
|
<tr class="memdesc:a817d93653aec6a479b920143bd21edbb"><td class="mdescLeft"> </td><td class="mdescRight">Returns true if at least a process is currently scheduled. <a href="classentt_1_1scheduler.html#a817d93653aec6a479b920143bd21edbb">More...</a><br /></td></tr>
|
|
<tr class="separator:a817d93653aec6a479b920143bd21edbb"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a5a0f92dbe54b58751237a567e86805e0"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#a5a0f92dbe54b58751237a567e86805e0">clear</a> ()</td></tr>
|
|
<tr class="memdesc:a5a0f92dbe54b58751237a567e86805e0"><td class="mdescLeft"> </td><td class="mdescRight">Discards all scheduled processes. <a href="classentt_1_1scheduler.html#a5a0f92dbe54b58751237a567e86805e0">More...</a><br /></td></tr>
|
|
<tr class="separator:a5a0f92dbe54b58751237a567e86805e0"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a729c83e1983123c642a08cda67e486e3"><td class="memTemplParams" colspan="2">template<typename Proc , typename... Args> </td></tr>
|
|
<tr class="memitem:a729c83e1983123c642a08cda67e486e3"><td class="memTemplItemLeft" align="right" valign="top">auto </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#a729c83e1983123c642a08cda67e486e3">attach</a> (Args &&... args)</td></tr>
|
|
<tr class="memdesc:a729c83e1983123c642a08cda67e486e3"><td class="mdescLeft"> </td><td class="mdescRight">Schedules a process for the next tick. <a href="classentt_1_1scheduler.html#a729c83e1983123c642a08cda67e486e3">More...</a><br /></td></tr>
|
|
<tr class="separator:a729c83e1983123c642a08cda67e486e3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a871812d08af8483316d1ce5d1e9d686f"><td class="memTemplParams" colspan="2">template<typename Func > </td></tr>
|
|
<tr class="memitem:a871812d08af8483316d1ce5d1e9d686f"><td class="memTemplItemLeft" align="right" valign="top">auto </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#a871812d08af8483316d1ce5d1e9d686f">attach</a> (Func &&func)</td></tr>
|
|
<tr class="memdesc:a871812d08af8483316d1ce5d1e9d686f"><td class="mdescLeft"> </td><td class="mdescRight">Schedules a process for the next tick. <a href="classentt_1_1scheduler.html#a871812d08af8483316d1ce5d1e9d686f">More...</a><br /></td></tr>
|
|
<tr class="separator:a871812d08af8483316d1ce5d1e9d686f"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a827eae426378df9ed9190752156a4154"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#a827eae426378df9ed9190752156a4154">update</a> (const Delta delta, void *data=nullptr)</td></tr>
|
|
<tr class="memdesc:a827eae426378df9ed9190752156a4154"><td class="mdescLeft"> </td><td class="mdescRight">Updates all scheduled processes. <a href="classentt_1_1scheduler.html#a827eae426378df9ed9190752156a4154">More...</a><br /></td></tr>
|
|
<tr class="separator:a827eae426378df9ed9190752156a4154"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aabc25388bff1b3b0770f913f54b915f2"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1scheduler.html#aabc25388bff1b3b0770f913f54b915f2">abort</a> (const bool immediately=false)</td></tr>
|
|
<tr class="memdesc:aabc25388bff1b3b0770f913f54b915f2"><td class="mdescLeft"> </td><td class="mdescRight">Aborts all scheduled processes. <a href="classentt_1_1scheduler.html#aabc25388bff1b3b0770f913f54b915f2">More...</a><br /></td></tr>
|
|
<tr class="separator:aabc25388bff1b3b0770f913f54b915f2"><td class="memSeparator" colspan="2"> </td></tr>
|
|
</table>
|
|
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
|
|
<div class="textblock"><h3>template<typename Delta><br />
|
|
class entt::scheduler< Delta ></h3>
|
|
|
|
<p>Cooperative scheduler for processes. </p>
|
|
<p>A cooperative scheduler runs processes and helps managing their life cycles.</p>
|
|
<p>Each process is invoked once per tick. If a process terminates, it's removed automatically from the scheduler and it's never invoked again.<br />
|
|
A process can also have a child. In this case, the process is replaced with its child when it terminates if it returns with success. In case of errors, both the process and its child are discarded.</p>
|
|
<p>Example of use (pseudocode):</p>
|
|
<div class="fragment"><div class="line"><a class="code" href="classentt_1_1scheduler.html#a49a81e662dc26831f4a951a715705d6e">scheduler</a>.attach([](<span class="keyword">auto</span> delta, <span class="keywordtype">void</span> *, <span class="keyword">auto</span> succeed, <span class="keyword">auto</span> fail) {</div>
|
|
<div class="line"> <span class="comment">// code</span></div>
|
|
<div class="line">}).then<my_process>(arguments...);</div>
|
|
</div><!-- fragment --><p>In order to invoke all scheduled processes, call the <code>update</code> member function passing it the elapsed time to forward to the tasks.</p>
|
|
<dl class="section see"><dt>See also</dt><dd><a class="el" href="classentt_1_1process.html" title="Base class for processes.">process</a></dd></dl>
|
|
<dl class="tparams"><dt>Template Parameters</dt><dd>
|
|
<table class="tparams">
|
|
<tr><td class="paramname">Delta</td><td>Type to use to provide elapsed time. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00044">44</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
</div><h2 class="groupheader">Member Function Documentation</h2>
|
|
<a id="aabc25388bff1b3b0770f913f54b915f2"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aabc25388bff1b3b0770f913f54b915f2">◆ </a></span>abort()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::abort </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const bool </td>
|
|
<td class="paramname"><em>immediately</em> = <code>false</code></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Aborts all scheduled processes. </p>
|
|
<p>Unless an immediate operation is requested, the abort is scheduled for the next tick. Processes won't be executed anymore in any case.<br />
|
|
Once a process is fully aborted and thus finished, it's discarded along with its child, if any.</p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">immediately</td><td>Requests an immediate operation. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00280">280</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a729c83e1983123c642a08cda67e486e3"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a729c83e1983123c642a08cda67e486e3">◆ </a></span>attach() <span class="overload">[1/2]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<div class="memtemplate">
|
|
template<typename Proc , typename... Args> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">auto <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::attach </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Args &&... </td>
|
|
<td class="paramname"><em>args</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Schedules a process for the next tick. </p>
|
|
<p>Returned value is an opaque object that can be used to attach a child to the given process. The child is automatically scheduled when the process terminates and only if the process returns with success.</p>
|
|
<p>Example of use (pseudocode):</p>
|
|
<div class="fragment"><div class="line"><span class="comment">// schedules a task in the form of a process class</span></div>
|
|
<div class="line"><a class="code" href="classentt_1_1scheduler.html#a49a81e662dc26831f4a951a715705d6e">scheduler</a>.attach<my_process>(arguments...)</div>
|
|
<div class="line"><span class="comment">// appends a child in the form of a lambda function</span></div>
|
|
<div class="line">.then([](<span class="keyword">auto</span> delta, <span class="keywordtype">void</span> *, <span class="keyword">auto</span> succeed, <span class="keyword">auto</span> fail) {</div>
|
|
<div class="line"> <span class="comment">// code</span></div>
|
|
<div class="line">})</div>
|
|
<div class="line"><span class="comment">// appends a child in the form of another process class</span></div>
|
|
<div class="line">.then<my_other_process>();</div>
|
|
</div><!-- fragment --><dl class="tparams"><dt>Template Parameters</dt><dd>
|
|
<table class="tparams">
|
|
<tr><td class="paramname">Proc</td><td>Type of process to schedule. </td></tr>
|
|
<tr><td class="paramname">Args</td><td>Types of arguments to use to initialize the process. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">args</td><td>Parameters to use to initialize the process. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>An opaque object to use to concatenate processes. </dd></dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00177">177</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a871812d08af8483316d1ce5d1e9d686f"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a871812d08af8483316d1ce5d1e9d686f">◆ </a></span>attach() <span class="overload">[2/2]</span></h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<div class="memtemplate">
|
|
template<typename Func > </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">auto <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::attach </td>
|
|
<td>(</td>
|
|
<td class="paramtype">Func && </td>
|
|
<td class="paramname"><em>func</em></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Schedules a process for the next tick. </p>
|
|
<p>A process can be either a lambda or a functor. The scheduler wraps both of them in a process adaptor internally.<br />
|
|
The signature of the function call operator should be equivalent to the following:</p>
|
|
<div class="fragment"><div class="line">void(Delta delta, <span class="keywordtype">void</span> *data, <span class="keyword">auto</span> succeed, <span class="keyword">auto</span> fail);</div>
|
|
</div><!-- fragment --><p>Where:</p>
|
|
<ul>
|
|
<li><code>delta</code> is the elapsed time.</li>
|
|
<li><code>data</code> is an opaque pointer to user data if any, <code>nullptr</code> otherwise.</li>
|
|
<li><code>succeed</code> is a function to call when a process terminates with success.</li>
|
|
<li><code>fail</code> is a function to call when a process terminates with errors.</li>
|
|
</ul>
|
|
<p>The signature of the function call operator of both <code>succeed</code> and <code>fail</code> is equivalent to the following:</p>
|
|
<div class="fragment"><div class="line">void();</div>
|
|
</div><!-- fragment --><p>Returned value is an opaque object that can be used to attach a child to the given process. The child is automatically scheduled when the process terminates and only if the process returns with success.</p>
|
|
<p>Example of use (pseudocode):</p>
|
|
<div class="fragment"><div class="line"><span class="comment">// schedules a task in the form of a lambda function</span></div>
|
|
<div class="line"><a class="code" href="classentt_1_1scheduler.html#a49a81e662dc26831f4a951a715705d6e">scheduler</a>.attach([](<span class="keyword">auto</span> delta, <span class="keywordtype">void</span> *, <span class="keyword">auto</span> succeed, <span class="keyword">auto</span> fail) {</div>
|
|
<div class="line"> <span class="comment">// code</span></div>
|
|
<div class="line">})</div>
|
|
<div class="line"><span class="comment">// appends a child in the form of another lambda function</span></div>
|
|
<div class="line">.then([](<span class="keyword">auto</span> delta, <span class="keywordtype">void</span> *, <span class="keyword">auto</span> succeed, <span class="keyword">auto</span> fail) {</div>
|
|
<div class="line"> <span class="comment">// code</span></div>
|
|
<div class="line">})</div>
|
|
<div class="line"><span class="comment">// appends a child in the form of a process class</span></div>
|
|
<div class="line">.then<my_process>(arguments...);</div>
|
|
</div><!-- fragment --><dl class="section see"><dt>See also</dt><dd><a class="el" href="structentt_1_1process__adaptor.html" title="Adaptor for lambdas and functors to turn them into processes.">process_adaptor</a></dd></dl>
|
|
<dl class="tparams"><dt>Template Parameters</dt><dd>
|
|
<table class="tparams">
|
|
<tr><td class="paramname">Func</td><td>Type of process to schedule. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">func</td><td>Either a lambda or a functor to use as a process. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
<dl class="section return"><dt>Returns</dt><dd>An opaque object to use to concatenate processes. </dd></dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00238">238</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a5a0f92dbe54b58751237a567e86805e0"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a5a0f92dbe54b58751237a567e86805e0">◆ </a></span>clear()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::clear </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Discards all scheduled processes. </p>
|
|
<p>Processes aren't aborted. They are discarded along with their children and never executed again. </p>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00147">147</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a817d93653aec6a479b920143bd21edbb"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a817d93653aec6a479b920143bd21edbb">◆ </a></span>empty()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">bool <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::empty </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Returns true if at least a process is currently scheduled. </p>
|
|
<dl class="section return"><dt>Returns</dt><dd>True if there are scheduled processes, false otherwise. </dd></dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00137">137</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="aea6ab78dbf00ba17c6e828ee0505afd9"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aea6ab78dbf00ba17c6e828ee0505afd9">◆ </a></span>operator=()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classentt_1_1scheduler.html">scheduler</a>& <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::operator= </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="classentt_1_1scheduler.html">scheduler</a>< Delta > && </td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">default</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Default move assignment operator. </p>
|
|
<dl class="section return"><dt>Returns</dt><dd>This scheduler. </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="ab0c473e6d4733bdb78f3dc26147de4ad"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#ab0c473e6d4733bdb78f3dc26147de4ad">◆ </a></span>size()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="classentt_1_1scheduler.html#afcec47d6ec28a994af2a7097348ce59f">size_type</a> <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::size </td>
|
|
<td>(</td>
|
|
<td class="paramname"></td><td>)</td>
|
|
<td> const</td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Number of processes currently scheduled. </p>
|
|
<dl class="section return"><dt>Returns</dt><dd>Number of processes currently scheduled. </dd></dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00129">129</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a827eae426378df9ed9190752156a4154"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a827eae426378df9ed9190752156a4154">◆ </a></span>update()</h2>
|
|
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<div class="memtemplate">
|
|
template<typename Delta> </div>
|
|
<table class="mlabels">
|
|
<tr>
|
|
<td class="mlabels-left">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void <a class="el" href="classentt_1_1scheduler.html">entt::scheduler</a>< Delta >::update </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const Delta </td>
|
|
<td class="paramname"><em>delta</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">void * </td>
|
|
<td class="paramname"><em>data</em> = <code>nullptr</code> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</td>
|
|
<td class="mlabels-right">
|
|
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Updates all scheduled processes. </p>
|
|
<p>All scheduled processes are executed in no specific order.<br />
|
|
If a process terminates with success, it's replaced with its child, if any. Otherwise, if a process terminates with an error, it's removed along with its child.</p>
|
|
<dl class="params"><dt>Parameters</dt><dd>
|
|
<table class="params">
|
|
<tr><td class="paramname">delta</td><td>Elapsed time. </td></tr>
|
|
<tr><td class="paramname">data</td><td>Optional data. </td></tr>
|
|
</table>
|
|
</dd>
|
|
</dl>
|
|
|
|
<p class="definition">Definition at line <a class="el" href="scheduler_8hpp_source.html#l00254">254</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<hr/>The documentation for this class was generated from the following file:<ul>
|
|
<li>src/entt/process/<a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a></li>
|
|
</ul>
|
|
</div><!-- contents -->
|
|
<div class="ttc" id="aclassentt_1_1scheduler_html_a49a81e662dc26831f4a951a715705d6e"><div class="ttname"><a href="classentt_1_1scheduler.html#a49a81e662dc26831f4a951a715705d6e">entt::scheduler::scheduler</a></div><div class="ttdeci">scheduler()=default</div><div class="ttdoc">Default constructor.</div></div>
|
|
<!-- start footer part -->
|
|
<hr class="footer"/><address class="footer"><small>
|
|
Generated by  <a href="http://www.doxygen.org/index.html">
|
|
<img class="footer" src="doxygen.png" alt="doxygen"/>
|
|
</a> 1.8.16
|
|
</small></address>
|
|
</body>
|
|
</html>
|