3 Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as published by
7 the Free Software Foundation; either version 2.1 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 #include "lua_api/l_base.h"
24 #include "environment.h"
26 class ModApiEnvMod : public ModApiBase {
28 // set_node(pos, node)
29 // pos = {x=num, y=num, z=num}
30 static int l_set_node(lua_State *L);
32 static int l_add_node(lua_State *L);
35 // pos = {x=num, y=num, z=num}
36 static int l_remove_node(lua_State *L);
38 // swap_node(pos, node)
39 // pos = {x=num, y=num, z=num}
40 static int l_swap_node(lua_State *L);
43 // pos = {x=num, y=num, z=num}
44 static int l_get_node(lua_State *L);
46 // get_node_or_nil(pos)
47 // pos = {x=num, y=num, z=num}
48 static int l_get_node_or_nil(lua_State *L);
50 // get_node_light(pos, timeofday)
51 // pos = {x=num, y=num, z=num}
52 // timeofday: nil = current time, 0 = night, 0.5 = day
53 static int l_get_node_light(lua_State *L);
55 // place_node(pos, node)
56 // pos = {x=num, y=num, z=num}
57 static int l_place_node(lua_State *L);
60 // pos = {x=num, y=num, z=num}
61 static int l_dig_node(lua_State *L);
64 // pos = {x=num, y=num, z=num}
65 static int l_punch_node(lua_State *L);
67 // get_node_max_level(pos)
68 // pos = {x=num, y=num, z=num}
69 static int l_get_node_max_level(lua_State *L);
71 // get_node_level(pos)
72 // pos = {x=num, y=num, z=num}
73 static int l_get_node_level(lua_State *L);
75 // set_node_level(pos)
76 // pos = {x=num, y=num, z=num}
77 static int l_set_node_level(lua_State *L);
79 // add_node_level(pos)
80 // pos = {x=num, y=num, z=num}
81 static int l_add_node_level(lua_State *L);
83 // find_nodes_with_meta(pos1, pos2)
84 static int l_find_nodes_with_meta(lua_State *L);
87 static int l_get_meta(lua_State *L);
89 // get_node_timer(pos)
90 static int l_get_node_timer(lua_State *L);
92 // add_entity(pos, entityname) -> ObjectRef or nil
93 // pos = {x=num, y=num, z=num}
94 static int l_add_entity(lua_State *L);
96 // add_item(pos, itemstack or itemstring or table) -> ObjectRef or nil
97 // pos = {x=num, y=num, z=num}
98 static int l_add_item(lua_State *L);
100 // get_player_by_name(name)
101 static int l_get_player_by_name(lua_State *L);
103 // get_objects_inside_radius(pos, radius)
104 static int l_get_objects_inside_radius(lua_State *L);
106 // set_timeofday(val)
108 static int l_set_timeofday(lua_State *L);
110 // get_timeofday() -> 0...1
111 static int l_get_timeofday(lua_State *L);
114 static int l_get_gametime(lua_State *L);
116 // find_node_near(pos, radius, nodenames) -> pos or nil
117 // nodenames: eg. {"ignore", "group:tree"} or "default:dirt"
118 static int l_find_node_near(lua_State *L);
120 // find_nodes_in_area(minp, maxp, nodenames) -> list of positions
121 // nodenames: eg. {"ignore", "group:tree"} or "default:dirt"
122 static int l_find_nodes_in_area(lua_State *L);
124 // find_surface_nodes_in_area(minp, maxp, nodenames) -> list of positions
125 // nodenames: eg. {"ignore", "group:tree"} or "default:dirt"
126 static int l_find_nodes_in_area_under_air(lua_State *L);
128 // delete_area(p1, p2) -> true/false
129 static int l_delete_area(lua_State *L);
131 // get_perlin(seeddiff, octaves, persistence, scale)
132 // returns world-specific PerlinNoise
133 static int l_get_perlin(lua_State *L);
135 // get_perlin_map(noiseparams, size)
136 // returns world-specific PerlinNoiseMap
137 static int l_get_perlin_map(lua_State *L);
140 // returns world-specific voxel manipulator
141 static int l_get_voxel_manip(lua_State *L);
144 // clear all objects in the environment
145 static int l_clear_objects(lua_State *L);
147 // spawn_tree(pos, treedef)
148 static int l_spawn_tree(lua_State *L);
150 // line_of_sight(pos1, pos2, stepsize) -> true/false
151 static int l_line_of_sight(lua_State *L);
153 // find_path(pos1, pos2, searchdistance,
154 // max_jump, max_drop, algorithm) -> table containing path
155 static int l_find_path(lua_State *L);
157 // transforming_liquid_add(pos)
158 static int l_transforming_liquid_add(lua_State *L);
160 // forceload_block(blockpos)
161 // forceloads a block
162 static int l_forceload_block(lua_State *L);
164 // forceload_free_block(blockpos)
165 // stops forceloading a position
166 static int l_forceload_free_block(lua_State *L);
168 // get us precision time
169 static int l_get_us_time(lua_State *L);
172 static void Initialize(lua_State *L, int top);
175 class LuaABM : public ActiveBlockModifier
180 std::set<std::string> m_trigger_contents;
181 std::set<std::string> m_required_neighbors;
182 float m_trigger_interval;
183 u32 m_trigger_chance;
185 LuaABM(lua_State *L, int id,
186 const std::set<std::string> &trigger_contents,
187 const std::set<std::string> &required_neighbors,
188 float trigger_interval, u32 trigger_chance):
190 m_trigger_contents(trigger_contents),
191 m_required_neighbors(required_neighbors),
192 m_trigger_interval(trigger_interval),
193 m_trigger_chance(trigger_chance)
196 virtual std::set<std::string> getTriggerContents()
198 return m_trigger_contents;
200 virtual std::set<std::string> getRequiredNeighbors()
202 return m_required_neighbors;
204 virtual float getTriggerInterval()
206 return m_trigger_interval;
208 virtual u32 getTriggerChance()
210 return m_trigger_chance;
212 virtual void trigger(ServerEnvironment *env, v3s16 p, MapNode n,
213 u32 active_object_count, u32 active_object_count_wider);
216 #endif /* L_ENV_H_ */