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&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&id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>tree</a><a href='/minetest.git/commit/builtin/profiler/init.lua?h=release&id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>commit</a><a href='/minetest.git/diff/builtin/profiler/init.lua?h=release&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&id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>root</a>/<a href='/minetest.git/tree/builtin?h=release&id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>builtin</a>/<a href='/minetest.git/tree/builtin/profiler?h=release&id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>profiler</a>/<a href='/minetest.git/tree/builtin/profiler/init.lua?h=release&id=0d0f1a2fb25fbfef8e0a1d42028257736fd80146'>init.lua</a></div><div class='content'>blob: 7f63dfaead3505cef848a2e4fd91a4ff9756e1b9 (<a href='/minetest.git/plain/builtin/profiler/init.lua?h=release&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">"__builtin"</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">"profiler"</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">"sampling.lua"</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">"instrumentation.lua"</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">"reporter.lua"</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">"instrument.profiler"</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">"print [<filter>] | dump [<filter>] | save [<format> [<filter>]] | reset"</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">"profiler"</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">"Handle the profiler and profiling data"</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">"([^ ]+) ?(.*)"</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">" "</span><span class="hl opt">)</span> <span class="hl kwa">if</span> command <span class="hl opt">==</span> <span class="hl str">"dump"</span> <span class="hl kwa">then