purposes</title>
<meta name='generator' content='cgit v1.2.3'/>
<meta name='robots' content='index, nofollow'/>
<link rel='stylesheet' type='text/css' href='/static/cgit.css'/>
<link rel='shortcut icon' href='//bananach.space/favicon.png'/>
<link rel='alternate' title='Atom feed' href='https://git.bananach.space/minetest.git/atom/builtin/profiler/init.lua?h=release' type='application/atom+xml'/>
</head>
<body>
<div id='cgit'><table id='header'>
<tr>
<td class='logo' rowspan='2'><a href='/'><img src='//bananach.space/bananach.png' alt='cgit logo'/></a></td>
<td class='main'><a href='/'>index</a> : <a href='/minetest.git/'>minetest.git</a></td><td class='form'><form method='get'>
<input type='hidden' name='id' value='0d0f1a2fb25fbfef8e0a1d42028257736fd80146'/><select name='h' onchange='this.form.submit();'>
<option value='gpcf'>gpcf</option>
<option value='lifo-fixes'>lifo-fixes</option>
<option value='release' selected='selected'>release</option>
</select> <input type='submit' value='switch'/></form></td></tr>
<tr><td class='sub'>modified minetest for gpcfs purposes</td><td class='sub right'>gpcf</td></tr></table>
<table class='tabs'><tr><td>
<a href='/minetest.git/about/?h=release'>about</a><a href='/minetest.git/?h=release'>summary</a><a href='/minetest.git/refs/?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>refs</a><a href='/minetest.git/log/builtin/profiler/init.lua?h=release'>log</a><a class='active' href='/minetest.git/tree/builtin/profiler/init.lua?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>tree</a><a href='/minetest.git/commit/builtin/profiler/init.lua?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>commit</a><a href='/minetest.git/diff/builtin/profiler/init.lua?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>diff</a></td><td class='form'><form class='right' method='get' action='/minetest.git/log/builtin/profiler/init.lua'>
<input type='hidden' name='h' value='release'/><input type='hidden' name='id' value='0d0f1a2fb25fbfef8e0a1d42028257736fd80146'/><select name='qt'>
<option value='grep'>log msg</option>
<option value='author'>author</option>
<option value='committer'>committer</option>
<option value='range'>range</option>
</select>
<input class='txt' type='search' size='10' name='q' value=''/>
<input type='submit' value='search'/>
</form>
</td></tr></table>
<div class='path'>path: <a href='/minetest.git/tree/?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>root</a>/<a href='/minetest.git/tree/builtin?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>builtin</a>/<a href='/minetest.git/tree/builtin/profiler?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>profiler</a>/<a href='/minetest.git/tree/builtin/profiler/init.lua?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>init.lua</a></div><div class='content'>blob: 7f63dfaead3505cef848a2e4fd91a4ff9756e1b9 (<a href='/minetest.git/plain/builtin/profiler/init.lua?h=release&amp;id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>plain</a>)
<table summary='blob content' class='blob'>
<tr><td class='linenumbers'><pre><a id='n1' href='#n1'>1</a>
<a id='n2' href='#n2'>2</a>
<a id='n3' href='#n3'>3</a>
<a id='n4' href='#n4'>4</a>
<a id='n5' href='#n5'>5</a>
<a id='n6' href='#n6'>6</a>
<a id='n7' href='#n7'>7</a>
<a id='n8' href='#n8'>8</a>
<a id='n9' href='#n9'>9</a>
<a id='n10' href='#n10'>10</a>
<a id='n11' href='#n11'>11</a>
<a id='n12' href='#n12'>12</a>
<a id='n13' href='#n13'>13</a>
<a id='n14' href='#n14'>14</a>
<a id='n15' href='#n15'>15</a>
<a id='n16' href='#n16'>16</a>
<a id='n17' href='#n17'>17</a>
<a id='n18' href='#n18'>18</a>
<a id='n19' href='#n19'>19</a>
<a id='n20' href='#n20'>20</a>
<a id='n21' href='#n21'>21</a>
<a id='n22' href='#n22'>22</a>
<a id='n23' href='#n23'>23</a>
<a id='n24' href='#n24'>24</a>
<a id='n25' href='#n25'>25</a>
<a id='n26' href='#n26'>26</a>
<a id='n27' href='#n27'>27</a>
<a id='n28' href='#n28'>28</a>
<a id='n29' href='#n29'>29</a>
<a id='n30' href='#n30'>30</a>
<a id='n31' href='#n31'>31</a>
<a id='n32' href='#n32'>32</a>
<a id='n33' href='#n33'>33</a>
<a id='n34' href='#n34'>34</a>
<a id='n35' href='#n35'>35</a>
<a id='n36' href='#n36'>36</a>
<a id='n37' href='#n37'>37</a>
<a id='n38' href='#n38'>38</a>
<a id='n39' href='#n39'>39</a>
<a id='n40' href='#n40'>40</a>
<a id='n41' href='#n41'>41</a>
<a id='n42' href='#n42'>42</a>
<a id='n43' href='#n43'>43</a>
<a id='n44' href='#n44'>44</a>
<a id='n45' href='#n45'>45</a>
<a id='n46' href='#n46'>46</a>
<a id='n47' href='#n47'>47</a>
<a id='n48' href='#n48'>48</a>
<a id='n49' href='#n49'>49</a>
<a id='n50' href='#n50'>50</a>
<a id='n51' href='#n51'>51</a>
<a id='n52' href='#n52'>52</a>
<a id='n53' href='#n53'>53</a>
<a id='n54' href='#n54'>54</a>
<a id='n55' href='#n55'>55</a>
<a id='n56' href='#n56'>56</a>
<a id='n57' href='#n57'>57</a>
<a id='n58' href='#n58'>58</a>
<a id='n59' href='#n59'>59</a>
<a id='n60' href='#n60'>60</a>
<a id='n61' href='#n61'>61</a>
<a id='n62' href='#n62'>62</a>
<a id='n63' href='#n63'>63</a>
<a id='n64' href='#n64'>64</a>
<a id='n65' href='#n65'>65</a>
<a id='n66' href='#n66'>66</a>
<a id='n67' href='#n67'>67</a>
<a id='n68' href='#n68'>68</a>
<a id='n69' href='#n69'>69</a>
<a id='n70' href='#n70'>70</a>
<a id='n71' href='#n71'>71</a>
<a id='n72' href='#n72'>72</a>
<a id='n73' href='#n73'>73</a>
<a id='n74' href='#n74'>74</a>
<a id='n75' href='#n75'>75</a>
<a id='n76' href='#n76'>76</a>
<a id='n77' href='#n77'>77</a>
<a id='n78' href='#n78'>78</a>
<a id='n79' href='#n79'>79</a>
<a id='n80' href='#n80'>80</a>
</pre></td>
<td class='lines'><pre><code><span class="hl slc">--Minetest</span>
<span class="hl slc">--Copyright (C) 2016 T4im</span>
<span class="hl slc">--</span>
<span class="hl slc">--This program is free software; you can redistribute it and/or modify</span>
<span class="hl slc">--it under the terms of the GNU Lesser General Public License as published by</span>
<span class="hl slc">--the Free Software Foundation; either version 2.1 of the License, or</span>
<span class="hl slc">--(at your option) any later version.</span>
<span class="hl slc">--</span>
<span class="hl slc">--This program is distributed in the hope that it will be useful,</span>
<span class="hl slc">--but WITHOUT ANY WARRANTY; without even the implied warranty of</span>
<span class="hl slc">--MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the</span>
<span class="hl slc">--GNU Lesser General Public License for more details.</span>
<span class="hl slc">--</span>
<span class="hl slc">--You should have received a copy of the GNU Lesser General Public License along</span>
<span class="hl slc">--with this program; if not, write to the Free Software Foundation, Inc.,</span>
<span class="hl slc">--51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.</span>

<span class="hl kwa">local</span> S <span class="hl opt">=</span> core<span class="hl opt">.</span><span class="hl kwd">get_translator</span><span class="hl opt">(</span><span class="hl str">&quot;__builtin&quot;</span><span class="hl opt">)</span>

<span class="hl kwa">local function</span> <span class="hl kwd">get_bool_default</span><span class="hl opt">(</span>name<span class="hl opt">,</span> default<span class="hl opt">)</span>
	<span class="hl kwa">local</span> val <span class="hl opt">=</span> core<span class="hl opt">.</span>settings<span class="hl opt">:</span><span class="hl kwd">get_bool</span><span class="hl opt">(</span>name<span class="hl opt">)</span>
	<span class="hl kwa">if</span> val <span class="hl opt">==</span> <span class="hl kwa">nil then</span>
		<span class="hl kwa">return</span> default
	<span class="hl kwa">end</span>
	<span class="hl kwa">return</span> val
<span class="hl kwa">end</span>

<span class="hl kwa">local</span> profiler_path <span class="hl opt">=</span> core<span class="hl opt">.</span><span class="hl kwd">get_builtin_path</span><span class="hl opt">()..</span><span class="hl str">&quot;profiler&quot;</span><span class="hl opt">..</span>DIR_DELIM
<span class="hl kwa">local</span> profiler <span class="hl opt">= {}</span>
<span class="hl kwa">local</span> sampler <span class="hl opt">=</span> <span class="hl kwb">assert</span><span class="hl opt">(</span><span class="hl kwd">loadfile</span><span class="hl opt">(</span>profiler_path <span class="hl opt">..</span> <span class="hl str">&quot;sampling.lua&quot;</span><span class="hl opt">))(</span>profiler<span class="hl opt">)</span>
<span class="hl kwa">local</span> instrumentation  <span class="hl opt">=</span> <span class="hl kwb">assert</span><span class="hl opt">(</span><span class="hl kwd">loadfile</span><span class="hl opt">(</span>profiler_path <span class="hl opt">..</span> <span class="hl str">&quot;instrumentation.lua&quot;</span><span class="hl opt">))(</span>profiler<span class="hl opt">,</span> sampler<span class="hl opt">,</span> get_bool_default<span class="hl opt">)</span>
<span class="hl kwa">local</span> reporter <span class="hl opt">=</span> <span class="hl kwb">dofile</span><span class="hl opt">(</span>profiler_path <span class="hl opt">..</span> <span class="hl str">&quot;reporter.lua&quot;</span><span class="hl opt">)</span>
profiler<span class="hl opt">.</span>instrument <span class="hl opt">=</span> instrumentation<span class="hl opt">.</span>instrument

<span class="hl slc">---</span>
<span class="hl slc">-- Delayed registration of the /profiler chat command</span>
<span class="hl slc">-- Is called later, after `core.register_chatcommand` was set up.</span>
<span class="hl slc">--</span>
<span class="hl kwa">function</span> profiler<span class="hl opt">.</span><span class="hl kwd">init_chatcommand</span><span class="hl opt">()</span>
	<span class="hl kwa">local</span> instrument_profiler <span class="hl opt">=</span> <span class="hl kwd">get_bool_default</span><span class="hl opt">(</span><span class="hl str">&quot;instrument.profiler&quot;</span><span class="hl opt">,</span> <span class="hl kwa">false</span><span class="hl opt">)</span>
	<span class="hl kwa">if</span> instrument_profiler <span class="hl kwa">then</span>
		instrumentation<span class="hl opt">.</span><span class="hl kwd">init_chatcommand</span><span class="hl opt">()</span>
	<span class="hl kwa">end</span>

	<span class="hl kwa">local</span> param_usage <span class="hl opt">=</span> <span class="hl kwd">S</span><span class="hl opt">(</span><span class="hl str">&quot;print [&lt;filter&gt;] | dump [&lt;filter&gt;] | save [&lt;format&gt; [&lt;filter&gt;]] | reset&quot;</span><span class="hl opt">)</span>
	core<span class="hl opt">.</span><span class="hl kwd">register_chatcommand</span><span class="hl opt">(</span><span class="hl str">&quot;profiler&quot;</span><span class="hl opt">, {</span>
		description <span class="hl opt">=</span> <span class="hl kwd">S</span><span class="hl opt">(</span><span class="hl str">&quot;Handle the profiler and profiling data&quot;</span><span class="hl opt">),</span>
		params <span class="hl opt">=</span> param_usage<span class="hl opt">,</span>
		privs <span class="hl opt">= {</span> server<span class="hl opt">=</span><span class="hl kwa">true</span> <span class="hl opt">},</span>
		func <span class="hl opt">=</span> <span class="hl kwa">function</span><span class="hl opt">(</span>name<span class="hl opt">,</span> param<span class="hl opt">)</span>
			<span class="hl kwa">local</span> command<span class="hl opt">,</span> arg0 <span class="hl opt">=</span> <span class="hl kwb">string</span><span class="hl opt">.</span><span class="hl kwd">match</span><span class="hl opt">(</span>param<span class="hl opt">,</span> <span class="hl str">&quot;([^ ]+) ?(.*)&quot;</span><span class="hl opt">)</span>
			<span class="hl kwa">local</span> args <span class="hl opt">=</span> arg0 <span class="hl kwa">and</span> <span class="hl kwb">string</span><span class="hl opt">.</span><span class="hl kwd">split</span><span class="hl opt">(</span>arg0<span class="hl opt">,</span> <span class="hl str">&quot; &quot;</span><span class="hl opt">)</span>

			<span class="hl kwa">if</span> command <span class="hl opt">==</span> <span class="hl str">&quot;dump&quot;</span> <span class="hl kwa">then