522 lines
30 KiB
HTML
522 lines
30 KiB
HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://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.13"/>
|
|
<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">2.7.1</span>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.8.13 -->
|
|
<script type="text/javascript">
|
|
var searchBox = new SearchBox("searchBox", "search",false,'Search');
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search');
|
|
$(document).ready(function() { init_search(); });
|
|
});
|
|
</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<span class="mlabels"><span class="mlabel">final</span></span></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:a2d76dbf324cf960ac8f2fc6d87d40eba"><td class="memItemLeft" align="right" valign="top"><a id="a2d76dbf324cf960ac8f2fc6d87d40eba"></a>
|
|
using </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a2d76dbf324cf960ac8f2fc6d87d40eba">size_type</a> = typename std::vector< ProcessHandler >::<a class="el" href="classentt_1_1Scheduler.html#a2d76dbf324cf960ac8f2fc6d87d40eba">size_type</a></td></tr>
|
|
<tr class="memdesc:a2d76dbf324cf960ac8f2fc6d87d40eba"><td class="mdescLeft"> </td><td class="mdescRight">Unsigned integer type. <br /></td></tr>
|
|
<tr class="separator:a2d76dbf324cf960ac8f2fc6d87d40eba"><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:a9c8baf08ea6f2869432cb13d870481c3"><td class="memItemLeft" align="right" valign="top"><a id="a9c8baf08ea6f2869432cb13d870481c3"></a>
|
|
 </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a9c8baf08ea6f2869432cb13d870481c3">Scheduler</a> () ENTT_NOEXCEPT=default</td></tr>
|
|
<tr class="memdesc:a9c8baf08ea6f2869432cb13d870481c3"><td class="mdescLeft"> </td><td class="mdescRight">Default constructor. <br /></td></tr>
|
|
<tr class="separator:a9c8baf08ea6f2869432cb13d870481c3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a4527dc6d1aedb50126e522ae7c8de5a1"><td class="memItemLeft" align="right" valign="top"><a id="a4527dc6d1aedb50126e522ae7c8de5a1"></a>
|
|
 </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a4527dc6d1aedb50126e522ae7c8de5a1">Scheduler</a> (const <a class="el" href="classentt_1_1Scheduler.html">Scheduler</a> &)=delete</td></tr>
|
|
<tr class="memdesc:a4527dc6d1aedb50126e522ae7c8de5a1"><td class="mdescLeft"> </td><td class="mdescRight">Copying a scheduler isn't allowed. <br /></td></tr>
|
|
<tr class="separator:a4527dc6d1aedb50126e522ae7c8de5a1"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:ab3a3ca9fa457fd48873c6d0d700a6f6c"><td class="memItemLeft" align="right" valign="top"><a id="ab3a3ca9fa457fd48873c6d0d700a6f6c"></a>
|
|
 </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#ab3a3ca9fa457fd48873c6d0d700a6f6c">Scheduler</a> (<a class="el" href="classentt_1_1Scheduler.html">Scheduler</a> &&)=default</td></tr>
|
|
<tr class="memdesc:ab3a3ca9fa457fd48873c6d0d700a6f6c"><td class="mdescLeft"> </td><td class="mdescRight">Default move constructor. <br /></td></tr>
|
|
<tr class="separator:ab3a3ca9fa457fd48873c6d0d700a6f6c"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a66fa731504da02dfaa607e1c3f153120"><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#a66fa731504da02dfaa607e1c3f153120">operator=</a> (const <a class="el" href="classentt_1_1Scheduler.html">Scheduler</a> &)=delete</td></tr>
|
|
<tr class="memdesc:a66fa731504da02dfaa607e1c3f153120"><td class="mdescLeft"> </td><td class="mdescRight">Copying a scheduler isn't allowed. <a href="#a66fa731504da02dfaa607e1c3f153120">More...</a><br /></td></tr>
|
|
<tr class="separator:a66fa731504da02dfaa607e1c3f153120"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a929ec57792af25f0552f25ad445c7731"><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#a929ec57792af25f0552f25ad445c7731">operator=</a> (<a class="el" href="classentt_1_1Scheduler.html">Scheduler</a> &&)=default</td></tr>
|
|
<tr class="memdesc:a929ec57792af25f0552f25ad445c7731"><td class="mdescLeft"> </td><td class="mdescRight">Default move assignment operator. <a href="#a929ec57792af25f0552f25ad445c7731">More...</a><br /></td></tr>
|
|
<tr class="separator:a929ec57792af25f0552f25ad445c7731"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a59aea2fac213df785278870474a3abb5"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classentt_1_1Scheduler.html#a2d76dbf324cf960ac8f2fc6d87d40eba">size_type</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a59aea2fac213df785278870474a3abb5">size</a> () const ENTT_NOEXCEPT</td></tr>
|
|
<tr class="memdesc:a59aea2fac213df785278870474a3abb5"><td class="mdescLeft"> </td><td class="mdescRight">Number of processes currently scheduled. <a href="#a59aea2fac213df785278870474a3abb5">More...</a><br /></td></tr>
|
|
<tr class="separator:a59aea2fac213df785278870474a3abb5"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aba0da7c946d76561a8694ecf7c5b29e3"><td class="memItemLeft" align="right" valign="top">bool </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#aba0da7c946d76561a8694ecf7c5b29e3">empty</a> () const ENTT_NOEXCEPT</td></tr>
|
|
<tr class="memdesc:aba0da7c946d76561a8694ecf7c5b29e3"><td class="mdescLeft"> </td><td class="mdescRight">Returns true if at least a process is currently scheduled. <a href="#aba0da7c946d76561a8694ecf7c5b29e3">More...</a><br /></td></tr>
|
|
<tr class="separator:aba0da7c946d76561a8694ecf7c5b29e3"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a2fd48cfd2ce32308f5e7bb8bafd5cda2"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a2fd48cfd2ce32308f5e7bb8bafd5cda2">clear</a> ()</td></tr>
|
|
<tr class="memdesc:a2fd48cfd2ce32308f5e7bb8bafd5cda2"><td class="mdescLeft"> </td><td class="mdescRight">Discards all scheduled processes. <a href="#a2fd48cfd2ce32308f5e7bb8bafd5cda2">More...</a><br /></td></tr>
|
|
<tr class="separator:a2fd48cfd2ce32308f5e7bb8bafd5cda2"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a1a836000f65e8e275119c0f77ec46674"><td class="memTemplParams" colspan="2">template<typename Proc , typename... Args> </td></tr>
|
|
<tr class="memitem:a1a836000f65e8e275119c0f77ec46674"><td class="memTemplItemLeft" align="right" valign="top">auto </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a1a836000f65e8e275119c0f77ec46674">attach</a> (Args &&... args)</td></tr>
|
|
<tr class="memdesc:a1a836000f65e8e275119c0f77ec46674"><td class="mdescLeft"> </td><td class="mdescRight">Schedules a process for the next tick. <a href="#a1a836000f65e8e275119c0f77ec46674">More...</a><br /></td></tr>
|
|
<tr class="separator:a1a836000f65e8e275119c0f77ec46674"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:a5915b9783b278a6006d4857feefc0e3b"><td class="memTemplParams" colspan="2">template<typename Func > </td></tr>
|
|
<tr class="memitem:a5915b9783b278a6006d4857feefc0e3b"><td class="memTemplItemLeft" align="right" valign="top">auto </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#a5915b9783b278a6006d4857feefc0e3b">attach</a> (Func &&func)</td></tr>
|
|
<tr class="memdesc:a5915b9783b278a6006d4857feefc0e3b"><td class="mdescLeft"> </td><td class="mdescRight">Schedules a process for the next tick. <a href="#a5915b9783b278a6006d4857feefc0e3b">More...</a><br /></td></tr>
|
|
<tr class="separator:a5915b9783b278a6006d4857feefc0e3b"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:aff001b4bf5aaa53fe1fda94991e73935"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#aff001b4bf5aaa53fe1fda94991e73935">update</a> (const Delta delta, void *data=nullptr)</td></tr>
|
|
<tr class="memdesc:aff001b4bf5aaa53fe1fda94991e73935"><td class="mdescLeft"> </td><td class="mdescRight">Updates all scheduled processes. <a href="#aff001b4bf5aaa53fe1fda94991e73935">More...</a><br /></td></tr>
|
|
<tr class="separator:aff001b4bf5aaa53fe1fda94991e73935"><td class="memSeparator" colspan="2"> </td></tr>
|
|
<tr class="memitem:af2494e025703d03a87117d6e897c87db"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classentt_1_1Scheduler.html#af2494e025703d03a87117d6e897c87db">abort</a> (const bool immediately=false)</td></tr>
|
|
<tr class="memdesc:af2494e025703d03a87117d6e897c87db"><td class="mdescLeft"> </td><td class="mdescRight">Aborts all scheduled processes. <a href="#af2494e025703d03a87117d6e897c87db">More...</a><br /></td></tr>
|
|
<tr class="separator:af2494e025703d03a87117d6e897c87db"><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">scheduler.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<MyProcess>(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="af2494e025703d03a87117d6e897c87db"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#af2494e025703d03a87117d6e897c87db">◆ </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#l00291">291</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a1a836000f65e8e275119c0f77ec46674"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a1a836000f65e8e275119c0f77ec46674">◆ </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">scheduler.attach<MyProcess>(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<MyOtherProcess>();</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#l00188">188</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a5915b9783b278a6006d4857feefc0e3b"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a5915b9783b278a6006d4857feefc0e3b">◆ </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="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>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">scheduler.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<MyProcess>(arguments...);</div></div><!-- fragment --><dl class="section see"><dt>See also</dt><dd><a class="el" href="structentt_1_1ProcessAdaptor.html" title="Adaptor for lambdas and functors to turn them into processes. ">ProcessAdaptor</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#l00249">249</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a2fd48cfd2ce32308f5e7bb8bafd5cda2"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a2fd48cfd2ce32308f5e7bb8bafd5cda2">◆ </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#l00158">158</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="aba0da7c946d76561a8694ecf7c5b29e3"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aba0da7c946d76561a8694ecf7c5b29e3">◆ </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#l00148">148</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a66fa731504da02dfaa607e1c3f153120"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a66fa731504da02dfaa607e1c3f153120">◆ </a></span>operator=() <span class="overload">[1/2]</span></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">const <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">delete</span></span> </td>
|
|
</tr>
|
|
</table>
|
|
</div><div class="memdoc">
|
|
|
|
<p>Copying a scheduler isn't allowed. </p>
|
|
<dl class="section return"><dt>Returns</dt><dd>This scheduler. </dd></dl>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="a929ec57792af25f0552f25ad445c7731"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a929ec57792af25f0552f25ad445c7731">◆ </a></span>operator=() <span class="overload">[2/2]</span></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="a59aea2fac213df785278870474a3abb5"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#a59aea2fac213df785278870474a3abb5">◆ </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#a2d76dbf324cf960ac8f2fc6d87d40eba">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#l00140">140</a> of file <a class="el" href="scheduler_8hpp_source.html">scheduler.hpp</a>.</p>
|
|
|
|
</div>
|
|
</div>
|
|
<a id="aff001b4bf5aaa53fe1fda94991e73935"></a>
|
|
<h2 class="memtitle"><span class="permalink"><a href="#aff001b4bf5aaa53fe1fda94991e73935">◆ </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#l00265">265</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 -->
|
|
<!-- 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.13
|
|
</small></address>
|
|
</body>
|
|
</html>
|