Add python script for updating lua_api.html

This commit is contained in:
rubenwardy 2015-01-04 17:42:59 +00:00
parent 300d23992c
commit 5b916a14c0
2 changed files with 140 additions and 66 deletions

View File

@ -2,9 +2,7 @@
title: Lua Modding API Reference title: Lua Modding API Reference
layout: default layout: default
--- ---
<h2 id="table-of-contents">Table of Contents</h2>
<h2>Table of Contents</h2>
<div class="toc"> <div class="toc">
<ul> <ul>
<li><a href="#introduction">Introduction</a></li> <li><a href="#introduction">Introduction</a></li>
@ -78,7 +76,8 @@ layout: default
<li><a href="#ore-types">Ore types</a><ul> <li><a href="#ore-types">Ore types</a><ul>
<li><a href="#scatter">scatter</a></li> <li><a href="#scatter">scatter</a></li>
<li><a href="#sheet">sheet</a></li> <li><a href="#sheet">sheet</a></li>
<li><a href="#claylike-not-yet-implemented">claylike -- not yet implemented</a></li> <li><a href="#blob">blob</a></li>
<li><a href="#vein">`vein</a></li>
</ul> </ul>
</li> </li>
<li><a href="#ore-attributes">Ore attributes</a><ul> <li><a href="#ore-attributes">Ore attributes</a><ul>
@ -309,6 +308,7 @@ layout: default
</li> </li>
</ul> </ul>
</div> </div>
<h2 id="introduction">Introduction</h2> <h2 id="introduction">Introduction</h2>
<p>Content and functionality can be added to Minetest 0.4 by using Lua <p>Content and functionality can be added to Minetest 0.4 by using Lua
scripting in run-time loaded mods.</p> scripting in run-time loaded mods.</p>
@ -319,10 +319,10 @@ files are automatically transferred to the client.</p>
<p>If you see a deficiency in the API, feel free to attempt to add the <p>If you see a deficiency in the API, feel free to attempt to add the
functionality in the engine and API. You can send such improvements as functionality in the engine and API. You can send such improvements as
source code patches to <a href="&#109;&#97;&#105;&#108;&#116;&#111;&#58;&#99;&#101;&#108;&#101;&#114;&#111;&#110;&#53;&#53;&#64;&#103;&#109;&#97;&#105;&#108;&#46;&#99;&#111;&#109;">&#99;&#101;&#108;&#101;&#114;&#111;&#110;&#53;&#53;&#64;&#103;&#109;&#97;&#105;&#108;&#46;&#99;&#111;&#109;</a>.</p> source code patches to <a href="&#109;&#97;&#105;&#108;&#116;&#111;&#58;&#99;&#101;&#108;&#101;&#114;&#111;&#110;&#53;&#53;&#64;&#103;&#109;&#97;&#105;&#108;&#46;&#99;&#111;&#109;">&#99;&#101;&#108;&#101;&#114;&#111;&#110;&#53;&#53;&#64;&#103;&#109;&#97;&#105;&#108;&#46;&#99;&#111;&#109;</a>.</p>
<p><strong>This may not be the most up to date version.</strong> See <a href="https://github.com/minetest/minetest/blob/master/doc/lua_api.txt">lua_api.txt</a> <ul>
<em> More information at <a href="http://www.minetest.net/">http://www.minetest.net/</a> <li>More information at <a href="http://www.minetest.net/">http://www.minetest.net/</a></li>
</em> Developer Wiki: <a href="http://dev.minetest.net/">http://dev.minetest.net/</a></p> <li>Developer Wiki: <a href="http://dev.minetest.net/">http://dev.minetest.net/</a></li>
<h2 id="programming-in-lua">Programming in Lua</h2> </ul><h2 id="programming-in-lua">Programming in Lua</h2>
<p>If you have any difficulty in understanding this, please read <a href="http://www.lua.org/pil/">Programming in Lua</a>.</p> <p>If you have any difficulty in understanding this, please read <a href="http://www.lua.org/pil/">Programming in Lua</a>.</p>
<h2 id="startup">Startup</h2> <h2 id="startup">Startup</h2>
<p>Mods are loaded during server startup from the mod load paths by running <p>Mods are loaded during server startup from the mod load paths by running
@ -796,7 +796,7 @@ changed in the future.</p>
set to level from <code>param2</code>.</p> set to level from <code>param2</code>.</p>
<h2 id="meshes">Meshes</h2> <h2 id="meshes">Meshes</h2>
<p>If drawtype <code>mesh</code> is used, tiles should hold model materials textures. <p>If drawtype <code>mesh</code> is used, tiles should hold model materials textures.
Only static meshes are implemented. Only static meshes are implemented.<br />
For supported model formats see Irrlicht engine documentation.</p> For supported model formats see Irrlicht engine documentation.</p>
<h2 id="noise-parameters">Noise Parameters</h2> <h2 id="noise-parameters">Noise Parameters</h2>
<p>Noise Parameters, or commonly called "<code>NoiseParams</code>", define the properties of perlin noise.</p> <p>Noise Parameters, or commonly called "<code>NoiseParams</code>", define the properties of perlin noise.</p>
@ -861,18 +861,41 @@ distribution of ore.</p>
The relative height of the sheet can be controlled by the same perlin noise as well, by specifying The relative height of the sheet can be controlled by the same perlin noise as well, by specifying
a non-zero <code>scale</code> parameter in <code>noise_params</code>.</p> a non-zero <code>scale</code> parameter in <code>noise_params</code>.</p>
<p><strong>IMPORTANT</strong>: The noise is not transformed by <code>offset</code> or <code>scale</code> when comparing against the noise <p><strong>IMPORTANT</strong>: The noise is not transformed by <code>offset</code> or <code>scale</code> when comparing against the noise
threshold, but scale is used to determine relative height. threshold, but scale is used to determine relative height.<br />
The height of the blob is randomly scattered, with a maximum height of <code>clust_size</code>.</p> The height of the blob is randomly scattered, with a maximum height of <code>clust_size</code>.</p>
<p><code>clust_scarcity</code> and <code>clust_num_ores</code> are ignored.</p> <p><code>clust_scarcity</code> and <code>clust_num_ores</code> are ignored.</p>
<p>This is essentially an improved version of the so-called "stratus" ore seen in some unofficial mods.</p> <p>This is essentially an improved version of the so-called "stratus" ore seen in some unofficial mods.</p>
<h3 id="claylike-not-yet-implemented"><code>claylike</code> -- <strong>not yet implemented</strong></h3> <h3 id="blob"><code>blob</code></h3>
<p>Places ore if there are no more than <code>clust_scarcity</code> number of specified nodes within a Von Neumann <p>Creates a deformed sphere of ore according to 3d perlin noise described by
neighborhood of <code>clust_size</code> radius.</p> <code>noise_params</code>. The maximum size of the blob is <code>clust_size</code>, and
<code>clust_scarcity</code> has the same meaning as with the <code>scatter</code> type.</p>
<h3 id="vein">`vein</h3>
<p>Creates veins of ore varying in density by according to the intersection of two
instances of 3d perlin noise with diffferent seeds, both described by
<code>noise_params</code>. <code>random_factor</code> varies the influence random chance has on
placement of an ore inside the vein, which is <code>1</code> by default. Note that
modifying this parameter may require adjusting <code>noise_threshhold</code>.
The parameters <code>clust_scarcity</code>, <code>clust_num_ores</code>, and <code>clust_size</code> are ignored
by this ore type. This ore type is difficult to control since it is sensitive
to small changes. The following is a decent set of parameters to work from:</p>
<pre><code>noise_params = {
offset = 0,
scale = 3,
spread = {x=200, y=200, z=200},
seed = 5390,
octaves = 4,
persist = 0.5,
flags = "eased",
},
noise_threshhold = 1.6
</code></pre>
<p>WARNING: Use this ore type <em>very</em> sparingly since it is ~200x more
computationally expensive than any other ore.</p>
<h2 id="ore-attributes">Ore attributes</h2> <h2 id="ore-attributes">Ore attributes</h2>
<p>See section "Flag Specifier Format".</p> <p>See section "Flag Specifier Format".</p>
<p>Currently supported flags: <code>absheight</code></p> <p>Currently supported flags: <code>absheight</code></p>
<h3 id="absheight"><code>absheight</code></h3> <h3 id="absheight"><code>absheight</code></h3>
<p>Also produce this same ore between the height range of <code>-height_max</code> and <code>-height_min</code>.</p> <p>Also produce this same ore between the height range of <code>-y_max</code> and <code>-y_min</code>.</p>
<p>Useful for having ore in sky realms without having to duplicate ore entries.</p> <p>Useful for having ore in sky realms without having to duplicate ore entries.</p>
<h2 id="decoration-types">Decoration types</h2> <h2 id="decoration-types">Decoration types</h2>
<p>The varying types of decorations that can be placed.</p> <p>The varying types of decorations that can be placed.</p>
@ -1261,7 +1284,7 @@ return damage
<p>Client predicts damage based on damage groups. Because of this, it is able to <p>Client predicts damage based on damage groups. Because of this, it is able to
give an immediate response when an entity is damaged or dies; the response is give an immediate response when an entity is damaged or dies; the response is
pre-defined somehow (e.g. by defining a sprite animation) (not implemented; pre-defined somehow (e.g. by defining a sprite animation) (not implemented;
TODO). TODO).<br />
Currently a smoke puff will appear when an entity dies.</p> Currently a smoke puff will appear when an entity dies.</p>
<p>The group <code>immortal</code> completely disables normal damage.</p> <p>The group <code>immortal</code> completely disables normal damage.</p>
<p>Entities can define a special armor group, which is <code>punch_operable</code>. This <p>Entities can define a special armor group, which is <code>punch_operable</code>. This
@ -1733,7 +1756,10 @@ value must (always) be two hexadecimal digits.</p>
Optional: Also returns <code>0</code> when the absolute value is within the tolerance (default: <code>0</code>)</li> Optional: Also returns <code>0</code> when the absolute value is within the tolerance (default: <code>0</code>)</li>
</ul> </ul>
</li> </li>
<li><code>string:split(separator)</code><ul> <li>`string.split(str, separator=",", include_empty=false, max_splits=-1,</li>
<li>sep_is_pattern=false)`<ul>
<li>If <code>max_splits</code> is negative, do not limit splits.</li>
<li><code>sep_is_pattern</code> specifies if separator is a plain string or a pattern (regex).</li>
<li>e.g. <code>string:split("a,b", ",") == {"a","b"}</code></li> <li>e.g. <code>string:split("a,b", ",") == {"a","b"}</code></li>
</ul> </ul>
</li> </li>
@ -1936,11 +1962,6 @@ value must (always) be two hexadecimal digits.</p>
<li>If function returns <code>true</code>, remaining functions are not called</li> <li>If function returns <code>true</code>, remaining functions are not called</li>
</ul> </ul>
</li> </li>
<li><code>minetest.register_on_mapgen_init(func(MapgenParams))</code><ul>
<li>Called just before the map generator is initialized but before the environment is initialized</li>
<li><code>MapgenParams</code> consists of a table with the fields <code>mgname</code>, <code>seed</code>, <code>water_level</code>, and <code>flags</code></li>
</ul>
</li>
<li><code>minetest.register_on_craft(func(itemstack, player, old_craft_grid, craft_inv))</code><ul> <li><code>minetest.register_on_craft(func(itemstack, player, old_craft_grid, craft_inv))</code><ul>
<li>Called when <code>player</code> crafts something</li> <li>Called when <code>player</code> crafts something</li>
<li><code>itemstack</code> is the output</li> <li><code>itemstack</code> is the output</li>
@ -2113,8 +2134,9 @@ and <code>minetest.auth_reload</code> call the authetification handler.</p>
<li>Return world-specific perlin noise (<code>int(worldseed)+seeddiff</code>)</li> <li>Return world-specific perlin noise (<code>int(worldseed)+seeddiff</code>)</li>
</ul> </ul>
</li> </li>
<li><code>minetest.get_voxel_manip()</code><ul> <li><code>minetest.get_voxel_manip([pos1, pos2])</code><ul>
<li>Return voxel manipulator object</li> <li>Return voxel manipulator object.</li>
<li>Loads the manipulator from the map if positions are passed.</li>
</ul> </ul>
</li> </li>
<li><code>minetest.set_gen_notify(flags, {deco_ids})</code><ul> <li><code>minetest.set_gen_notify(flags, {deco_ids})</code><ul>
@ -2128,6 +2150,8 @@ and <code>minetest.auth_reload</code> call the authetification handler.</p>
<li>Return requested mapgen object if available (see "Mapgen objects")</li> <li>Return requested mapgen object if available (see "Mapgen objects")</li>
</ul> </ul>
</li> </li>
<li><code>minetest.get_mapgen_params()</code> Returns mapgen parameters, a table containing
<code>mgname</code>, <code>seed</code>, <code>chunksize</code>, <code>water_level</code>, and <code>flags</code>.</li>
<li><code>minetest.set_mapgen_params(MapgenParams)</code><ul> <li><code>minetest.set_mapgen_params(MapgenParams)</code><ul>
<li>Set map generation parameters</li> <li>Set map generation parameters</li>
<li>Function cannot be called after the registration period; only initialization and <code>on_mapgen_init</code></li> <li>Function cannot be called after the registration period; only initialization and <code>on_mapgen_init</code></li>
@ -2675,7 +2699,7 @@ end
</ul> </ul>
<h2 id="class-reference">Class reference</h2> <h2 id="class-reference">Class reference</h2>
<h3 id="nodemetaref"><code>NodeMetaRef</code></h3> <h3 id="nodemetaref"><code>NodeMetaRef</code></h3>
<p>Node metadata: reference extra data and functionality stored in a node. <p>Node metadata: reference extra data and functionality stored in a node.<br />
Can be gotten via <code>minetest.get_meta(pos)</code>.</p> Can be gotten via <code>minetest.get_meta(pos)</code>.</p>
<h4 id="methods">Methods</h4> <h4 id="methods">Methods</h4>
<ul> <ul>
@ -2693,7 +2717,7 @@ Can be gotten via <code>minetest.get_meta(pos)</code>.</p>
</li> </li>
</ul> </ul>
<h3 id="notetimerref"><code>NoteTimerRef</code></h3> <h3 id="notetimerref"><code>NoteTimerRef</code></h3>
<p>Node Timers: a high resolution persistent per-node timer. <p>Node Timers: a high resolution persistent per-node timer.<br />
Can be gotten via <code>minetest.get_node_timer(pos)</code>.</p> Can be gotten via <code>minetest.get_node_timer(pos)</code>.</p>
<h4 id="methods_1">Methods</h4> <h4 id="methods_1">Methods</h4>
<ul> <ul>
@ -2933,44 +2957,39 @@ Can be gotten via <code>minetest.get_node_timer(pos)</code>.</p>
an itemstring, a table or <code>nil</code>.</p> an itemstring, a table or <code>nil</code>.</p>
<h4 id="methods_4">Methods</h4> <h4 id="methods_4">Methods</h4>
<ul> <ul>
<li><code>is_empty()</code>: return <code>true</code> if stack is empty</li> <li><code>is_empty()</code>: Returns <code>true</code> if stack is empty.</li>
<li><code>get_name()</code>: returns item name (e.g. <code>"default:stone"</code>)</li> <li><code>get_name()</code>: Returns item name (e.g. <code>"default:stone"</code>).</li>
<li><code>set_name(itemname)</code></li> <li><code>set_name(item_name)</code>: Returns boolean success.
<li><code>get_count()</code>: returns number of items on the stack</li> Clears item on failure.</li>
<li><code>get_count()</code>: Returns number of items on the stack.</li>
<li><code>set_count(count)</code></li> <li><code>set_count(count)</code></li>
<li><code>get_wear()</code>: returns tool wear (<code>0</code>-<code>65535</code>), <code>0</code> for non-tools</li> <li><code>get_wear()</code>: Returns tool wear (<code>0</code>-<code>65535</code>), <code>0</code> for non-tools.</li>
<li><code>set_wear(wear)</code></li> <li><code>set_wear(wear)</code>: Returns boolean success.
<li><code>get_metadata()</code>: returns metadata (a string attached to an item stack)</li> Clears item on failure.</li>
<li><code>set_metadata(metadata)</code></li> <li><code>get_metadata()</code>: Returns metadata (a string attached to an item stack).</li>
<li><code>clear()</code>: removes all items from the stack, making it empty</li> <li><code>set_metadata(metadata)</code>: Returns true.</li>
<li><code>replace(item)</code>: replace the contents of this stack<ul> <li><code>clear()</code>: removes all items from the stack, making it empty.</li>
<li><code>item</code> can also be an itemstring or table</li> <li><code>replace(item)</code>: replace the contents of this stack.<ul>
<li><code>item</code> can also be an itemstring or table.</li>
</ul> </ul>
</li> </li>
<li><code>to_string()</code>: returns the stack in itemstring form</li> <li><code>to_string()</code>: Returns the stack in itemstring form.</li>
<li><code>to_table()</code>: returns the stack in Lua table form</li> <li><code>to_table()</code>: Returns the stack in Lua table form.</li>
<li><code>get_stack_max()</code>: returns the maximum size of the stack (depends on the item)</li> <li><code>get_stack_max()</code>: Returns the maximum size of the stack (depends on the item).</li>
<li><code>get_free_space()</code>: returns <code>get_stack_max() - get_count()</code></li> <li><code>get_free_space()</code>: Returns <code>get_stack_max() - get_count()</code>.</li>
<li><code>is_known()</code>: returns <code>true</code> if the item name refers to a defined item type</li> <li><code>is_known()</code>: Returns <code>true</code> if the item name refers to a defined item type.</li>
<li><code>get_definition()</code>: returns the item definition table</li> <li><code>get_definition()</code>: Returns the item definition table.</li>
<li><code>get_tool_capabilities()</code>: returns the digging properties of the item, <li><code>get_tool_capabilities()</code>: Returns the digging properties of the item,
or those of the hand if none are defined for this item type</li> or those of the hand if none are defined for this item type</li>
<li><code>add_wear(amount)</code>: increases wear by <code>amount</code> if the item is a tool</li> <li><code>add_wear(amount)</code>: Increases wear by <code>amount</code> if the item is a tool.</li>
<li><code>add_item(item)</code>: put some item or stack onto this stack,<ul> <li><code>add_item(item)</code>: Put some item or stack onto this stack.
<li>returns leftover ItemStack</li> Returns leftover <code>ItemStack</code>.</li>
</ul> <li><code>item_fits(item)</code>: Returns <code>true</code> if item or stack can be fully added to
</li> this one.</li>
<li><code>item_fits(item)</code>: returns <code>true</code> if item or stack can be fully added to this one</li> <li><code>take_item(n=1)</code>: Take (and remove) up to <code>n</code> items from this stack.
<li><code>take_item(n)</code>: take (and remove) up to <code>n</code> items from this stack<ul> Returns taken <code>ItemStack</code>.</li>
<li>returns taken <code>ItemStack</code></li> <li><code>peek_item(n=1)</code>: copy (don't remove) up to <code>n</code> items from this stack.
<li>if <code>n</code> is omitted, <code>n=1</code> is used</li> Returns taken <code>ItemStack</code>.</li>
</ul>
</li>
<li><code>peek_item(n)</code>: copy (don't remove) up to <code>n</code> items from this stack<ul>
<li>returns taken <code>ItemStack</code></li>
<li>if <code>n</code> is omitted, <code>n=1</code> is used</li>
</ul>
</li>
</ul> </ul>
<h3 id="pseudorandom"><code>PseudoRandom</code></h3> <h3 id="pseudorandom"><code>PseudoRandom</code></h3>
<p>A pseudorandom number generator.</p> <p>A pseudorandom number generator.</p>
@ -2987,7 +3006,7 @@ an itemstring, a table or <code>nil</code>.</p>
<h3 id="perlinnoise"><code>PerlinNoise</code></h3> <h3 id="perlinnoise"><code>PerlinNoise</code></h3>
<p>A perlin noise generator. <p>A perlin noise generator.
It can be created via <code>PerlinNoise(seed, octaves, persistence, scale)</code> It can be created via <code>PerlinNoise(seed, octaves, persistence, scale)</code>
or <code>PerlinNoise(noiseparams)</code>. or <code>PerlinNoise(noiseparams)</code>.<br />
Alternatively with <code>minetest.get_perlin(seeddiff, octaves, persistence, scale)</code> Alternatively with <code>minetest.get_perlin(seeddiff, octaves, persistence, scale)</code>
or <code>minetest.get_perlin(noiseparams)</code>.</p> or <code>minetest.get_perlin(noiseparams)</code>.</p>
<h4 id="methods_6">Methods</h4> <h4 id="methods_6">Methods</h4>
@ -3013,7 +3032,8 @@ for 2D noise, and it must be must be larger than 1 for 3D noise (otherwise
</ul> </ul>
<h3 id="voxelmanip"><code>VoxelManip</code></h3> <h3 id="voxelmanip"><code>VoxelManip</code></h3>
<p>An interface to the <code>MapVoxelManipulator</code> for Lua.</p> <p>An interface to the <code>MapVoxelManipulator</code> for Lua.</p>
<p>It can be created via <code>VoxelManip()</code> or <code>minetest.get_voxel_manip()</code>.</p> <p>It can be created via <code>VoxelManip()</code> or <code>minetest.get_voxel_manip()</code>.
The map will be pre-loaded if two positions are passed to either.</p>
<h4 id="methods_8">Methods</h4> <h4 id="methods_8">Methods</h4>
<ul> <ul>
<li><code>read_from_map(p1, p2)</code>: Reads a chunk of map from the map containing the region formed by <code>p1</code> and <code>p2</code>.<ul> <li><code>read_from_map(p1, p2)</code>: Reads a chunk of map from the map containing the region formed by <code>p1</code> and <code>p2</code>.<ul>
@ -3062,6 +3082,7 @@ for 2D noise, and it must be must be larger than 1 for 3D noise (otherwise
<li><code>update_liquids()</code>: Update liquid flow</li> <li><code>update_liquids()</code>: Update liquid flow</li>
<li><code>was_modified()</code>: Returns <code>true</code> or <code>false</code> if the data in the voxel manipulator had been modified since <li><code>was_modified()</code>: Returns <code>true</code> or <code>false</code> if the data in the voxel manipulator had been modified since
the last read from map, due to a call to <code>minetest.set_data()</code> on the loaded area elsewhere</li> the last read from map, due to a call to <code>minetest.set_data()</code> on the loaded area elsewhere</li>
<li><code>get_emerged_area()</code>: Returns actual emerged minimum and maximum positions.</li>
</ul> </ul>
<h3 id="voxelarea"><code>VoxelArea</code></h3> <h3 id="voxelarea"><code>VoxelArea</code></h3>
<p>A helper class for voxel areas. <p>A helper class for voxel areas.
@ -3412,7 +3433,6 @@ minetest.spawn_tree(pos,apple_tree)
liquid_alternative_source = "", -- Source version of flowing liquid liquid_alternative_source = "", -- Source version of flowing liquid
liquid_viscosity = 0, -- Higher viscosity = slower flow (max. 7) liquid_viscosity = 0, -- Higher viscosity = slower flow (max. 7)
liquid_renewable = true, -- Can new liquid source be created by placing two or more sources nearby? liquid_renewable = true, -- Can new liquid source be created by placing two or more sources nearby?
freezemelt = "", -- water for snow/ice, ice/snow for water
leveled = 0, -- Block contain level in param2. value - default level, used for snow. Don't forget use "leveled" type nodebox leveled = 0, -- Block contain level in param2. value - default level, used for snow. Don't forget use "leveled" type nodebox
liquid_range = 8, -- number of flowing nodes around source (max. 8) liquid_range = 8, -- number of flowing nodes around source (max. 8)
drowning = 0, -- Player will take this amount of damage if no bubbles are left drowning = 0, -- Player will take this amount of damage if no bubbles are left
@ -3579,8 +3599,8 @@ minetest.spawn_tree(pos,apple_tree)
clust_size = 3, clust_size = 3,
-- ^ Size of the bounding box of the cluster -- ^ Size of the bounding box of the cluster
-- ^ In this example, there is a 3x3x3 cluster where 8 out of the 27 nodes are coal ore -- ^ In this example, there is a 3x3x3 cluster where 8 out of the 27 nodes are coal ore
height_min = -31000, y_min = -31000,
height_max = 64, y_max = 64,
flags = "", flags = "",
-- ^ Attributes for this ore generation -- ^ Attributes for this ore generation
noise_threshhold = 0.5, noise_threshhold = 0.5,
@ -3588,6 +3608,10 @@ minetest.spawn_tree(pos,apple_tree)
noise_params = {offset=0, scale=1, spread={x=100, y=100, z=100}, seed=23, octaves=3, persist=0.70} noise_params = {offset=0, scale=1, spread={x=100, y=100, z=100}, seed=23, octaves=3, persist=0.70}
-- ^ NoiseParams structure describing the perlin noise used for ore distribution. -- ^ NoiseParams structure describing the perlin noise used for ore distribution.
-- ^ Needed for sheet ore_type. Omit from scatter ore_type for a uniform ore distribution -- ^ Needed for sheet ore_type. Omit from scatter ore_type for a uniform ore distribution
random_factor = 1.0,
-- ^ Multiplier of the randomness contribution to the noise value at any
-- given point to decide if ore should be placed. Set to 0 for solid veins.
-- ^ This parameter is only valid for ore_type == "vein".
} }
</code></pre> </code></pre>
<h3 id="decoration-definition-register_decoration">Decoration definition (<code>register_decoration</code>)</h3> <h3 id="decoration-definition-register_decoration">Decoration definition (<code>register_decoration</code>)</h3>
@ -3607,13 +3631,18 @@ minetest.spawn_tree(pos,apple_tree)
biomes = {"Oceanside", "Hills", "Plains"}, biomes = {"Oceanside", "Hills", "Plains"},
-- ^ List of biomes in which this decoration occurs. Occurs in all biomes if this is omitted, -- ^ List of biomes in which this decoration occurs. Occurs in all biomes if this is omitted,
-- ^ and ignored if the Mapgen being used does not support biomes. -- ^ and ignored if the Mapgen being used does not support biomes.
y_min = -31000
y_max = 31000
-- ^ Minimum and maximum `y` positions these decorations can be generated at.
-- ^ This parameter refers to the `y` position of the decoration base, so
-- the actual maximum height would be `height_max + size.Y`.
----- Simple-type parameters ----- Simple-type parameters
decoration = "default:grass", decoration = "default:grass",
-- ^ The node name used as the decoration. -- ^ The node name used as the decoration.
-- ^ If instead a list of strings, a randomly selected node from the list is placed as the decoration. -- ^ If instead a list of strings, a randomly selected node from the list is placed as the decoration.
height = 1, height = 1,
-- ^ Number of nodes high the decoration is made. -- ^ Number of nodes high the decoration is made.
-- ^ If height_max is not 0, this is the lower bound of the randomly selected height. -- ^ If height_max is not 0, this is the lower bound of the randomly selected height.
height_max = 0, height_max = 0,
-- ^ Number of nodes the decoration can be at maximum. -- ^ Number of nodes the decoration can be at maximum.
@ -3751,4 +3780,4 @@ minetest.spawn_tree(pos,apple_tree)
playername = "singleplayer" playername = "singleplayer"
-- ^ Playername is optional, if specified spawns particle only on the player's client -- ^ Playername is optional, if specified spawns particle only on the player's client
} }
</code></pre> </code></pre>

45
update_lua_api.py Normal file
View File

@ -0,0 +1,45 @@
import markdown, urllib2
#
# Downloading lua_api.txt
#
print("Downloading lua_api.txt...")
url = "https://raw.githubusercontent.com/minetest/minetest/master/doc/lua_api.txt"
text = urllib2.urlopen(url).read()
header = """Minetest Lua Modding API Reference 0.4.11
========================================="""
text = text.replace(header, "")
#
# Generating HTML
#
print("Generating HTML...")
md = markdown.Markdown(extensions=['markdown.extensions.toc'])
links = """<ul>
<li>More information at <a href="http://www.minetest.net/">http://www.minetest.net/</a></li>
<li>Developer Wiki: <a href="http://dev.minetest.net/">http://dev.minetest.net/</a></li>
</ul>"""
html = md.convert(text).replace("{{", "{ {")
html = html.replace(links, "")
html = html.replace("<h2 id=\"programming-in-lua\">", links + "<h2 id=\"programming-in-lua\">")
#
# Writing to file
#
print("Writing to file...")
file = open("lua_api.html", "w")
file.write("---\ntitle: Lua Modding API Reference\nlayout: default\n---\n")
file.write("<h2 id=\"table-of-contents\">Table of Contents</h2>\n")
file.write(md.toc)
file.write(html)
file.close()
print("Done")