Documentation pass, part 2

This commit is contained in:
Hugues Ross 2020-06-13 08:50:36 -04:00
parent 309ff6b8d4
commit db45633b16
10 changed files with 157 additions and 28 deletions

View File

@ -4,17 +4,15 @@ local modpath = minetest.get_modpath("cartographer");
-- Includes -- Includes
local map_data = loadfile(modpath .. "/storage.lua") (); local map_data = loadfile(modpath .. "/storage.lua") ();
local chunk = loadfile(modpath .. "/chunk_api.lua") (); local chunk = loadfile(modpath .. "/chunk_api.lua") ();
local skin = loadfile(modpath .. "/skin_api.lua") ();
local gui = loadfile(modpath .. "/formspec.lua") (); local gui = loadfile(modpath .. "/formspec.lua") ();
local audio = loadfile(modpath .. "/audio.lua") (); local skin = loadfile(modpath .. "/skin_api.lua") ();
local util = loadfile(modpath .. "/util.lua") (); local util = loadfile(modpath .. "/util.lua") ();
local audio = loadfile(modpath .. "/audio.lua") ();
local biomes = loadfile(modpath .. "/biome_api.lua") (util); local biomes = loadfile(modpath .. "/biome_api.lua") (util);
local markers = loadfile(modpath .. "/marker_api.lua") ();
local scanner = loadfile(modpath .. "/scanner.lua") (map_data, chunk); local scanner = loadfile(modpath .. "/scanner.lua") (map_data, chunk);
local maps = loadfile(modpath .. "/map_api.lua") (map_data, chunk); local maps = loadfile(modpath .. "/map_api.lua") (map_data, chunk);
local materials = loadfile(modpath .. "/material_api.lua") (); local materials = loadfile(modpath .. "/material_api.lua") ();
local markers = loadfile(modpath .. "/marker_api.lua") ();
local map_formspec = loadfile(modpath .. "/map_formspec.lua") (map_data, gui, skin, util, biomes, markers); local map_formspec = loadfile(modpath .. "/map_formspec.lua") (map_data, gui, skin, util, biomes, markers);
local map_item = loadfile(modpath .. "/items.lua") (chunk, gui, skin, audio, maps, markers, map_formspec); local map_item = loadfile(modpath .. "/items.lua") (chunk, gui, skin, audio, maps, markers, map_formspec);
loadfile(modpath .. "/commands.lua") (chunk, audio, map_formspec); loadfile(modpath .. "/commands.lua") (chunk, audio, map_formspec);

View File

@ -1,9 +1,18 @@
-- Arguments
-- chunk: The chunk coordinate conversion API
-- gui: The GUI API
-- skin: The GUI skin
-- audio: The audio playback API
-- maps: The map API
-- markers: The marker API
-- map_formspec: The map display API
local chunk, gui, skin, audio, maps, markers, map_formspec = ...; local chunk, gui, skin, audio, maps, markers, map_formspec = ...;
-- The list of players looking at maps, and the map IDs that they're looking at -- The list of players looking at maps, and the map IDs that they're looking at
local player_maps = {}; local player_maps = {};
-- Generates formspec data for the map marker editor -- Generate formspec data for the map marker editor
--
-- selected_id: The id of the currently selected marker, or nil if no marker is -- selected_id: The id of the currently selected marker, or nil if no marker is
-- selected -- selected
-- detail: The map's detail level -- detail: The map's detail level
@ -90,23 +99,19 @@ local function marker_formspec(selected_id, detail, page)
return table.concat(formspec); return table.concat(formspec);
end end
-- Show a map to a player from the ID -- Show a map to a player
-- id: The map ID --
-- map: The map to display
-- player_x: The X position (in world coordinates) -- player_x: The X position (in world coordinates)
-- player_z: The Z position (in world coordinates) -- player_z: The Z position (in world coordinates)
-- player_name: The name of the player to show to -- player_name: The name of the player to show to
-- height_mode: Whether or not to display the map in height mode -- height_mode: Whether or not to display the map in height mode
-- (Optional) marker_page: The current page that the marker editor is on -- (Optional) marker_page: The current page that the marker editor is on
local function show_map_id_formspec(id, player_x, player_z, player_name, height_mode, marker_page) local function show_map_formspec(map, player_x, player_z, player_name, height_mode, marker_page)
local map = maps.get(id); map:fill_local(player_x, player_z);
if not map then
return
end
map:fill_local(id, player_x, player_z);
player_maps[player_name] = { player_maps[player_name] = {
id = id, id = map.id,
page = marker_page or 1, page = marker_page or 1,
height_mode = height_mode, height_mode = height_mode,
}; };
@ -174,11 +179,14 @@ local function show_map_id_formspec(id, player_x, player_z, player_name, height_
end end
-- Get the description text for a map ID and dimensions -- Get the description text for a map ID and dimensions
--
-- id: The map ID -- id: The map ID
-- from_x: The x coordinate of the top-left corner of the map, in world coordinates -- from_x: The x coordinate of the top-left corner of the map, in world coordinates
-- from_z: The z coordinate of the top-left corner of the map, in world coordinates -- from_z: The z coordinate of the top-left corner of the map, in world coordinates
-- w: The width, in world coordinates -- w: The width, in world coordinates
-- h: The height, in world coordinates -- h: The height, in world coordinates
--
-- returns a string containing the description
local function map_description(id, from_x, from_z, w, h) local function map_description(id, from_x, from_z, w, h)
return string.format("Map #%d\n[%d,%d] - [%d,%d]", return string.format("Map #%d\n[%d,%d] - [%d,%d]",
id, id,
@ -187,9 +195,12 @@ local function map_description(id, from_x, from_z, w, h)
end end
-- Create a map from metadata, and assign the ID to the metadata -- Create a map from metadata, and assign the ID to the metadata
--
-- meta: A metadata object containing the map ID -- meta: A metadata object containing the map ID
-- player_x: The X position (in map coordinates) -- player_x: The X position (in map coordinates)
-- player_z: The Z position (in map coordinates) -- player_z: The Z position (in map coordinates)
--
-- Returns the id of the new map
local function map_from_meta(meta, player_x, player_z) local function map_from_meta(meta, player_x, player_z)
local size = meta:get_int("cartographer:size") or 10; local size = meta:get_int("cartographer:size") or 10;
local detail = meta:get_int("cartographer:detail") or 1; local detail = meta:get_int("cartographer:detail") or 1;
@ -208,7 +219,8 @@ local function map_from_meta(meta, player_x, player_z)
return id; return id;
end end
-- Show a map to a player from metadata, creating it if possible -- Show a map to a player from metadata, creating it if necessary
--
-- meta: A metadata object containing the map ID -- meta: A metadata object containing the map ID
-- player: The player to show the map to -- player: The player to show the map to
local function show_map_meta(meta, player) local function show_map_meta(meta, player)
@ -221,11 +233,15 @@ local function show_map_meta(meta, player)
id = map_from_meta(meta, player_x, player_z); id = map_from_meta(meta, player_x, player_z);
end end
show_map_id_formspec(id, pos.x, pos.z, player:get_player_name(), true); local map = maps.get(id);
if map then
show_map_formspec(map, pos.x, pos.z, player:get_player_name(), true);
end
end end
-- Called when a player sends input to the server from a formspec -- Called when a player sends input to the server from a formspec
-- This callback handles player input in the map formspec, for editing markers -- This callback handles player input in the map formspec, for editing markers
--
-- player: The player who sent the input -- player: The player who sent the input
-- name: The formspec name -- name: The formspec name
-- fields: A table containing the input -- fields: A table containing the input
@ -249,13 +265,13 @@ minetest.register_on_player_receive_fields(function(player, name, fields)
map:set_marker(player_x, player_z, marker); map:set_marker(player_x, player_z, marker);
audio.play_feedback("cartographer_write", player); audio.play_feedback("cartographer_write", player);
show_map_id_formspec(map.id, pos.x, pos.z, player:get_player_name(), data.page); show_map_formspec(map, pos.x, pos.z, player:get_player_name(), data.page);
elseif k == "prev_button" then elseif k == "prev_button" then
show_map_id_formspec(map.id, pos.x, pos.z, player:get_player_name(), data.height_mode, data.page - 1); show_map_formspec(map, pos.x, pos.z, player:get_player_name(), data.height_mode, data.page - 1);
elseif k == "next_button" then elseif k == "next_button" then
show_map_id_formspec(map.id, pos.x, pos.z, player:get_player_name(), data.height_mode, data.page + 1); show_map_formspec(map, pos.x, pos.z, player:get_player_name(), data.height_mode, data.page + 1);
elseif k == "height_button" then elseif k == "height_button" then
show_map_id_formspec(map.id, pos.x, pos.z, player:get_player_name(), not data.height_mode, data.page); show_map_formspec(map, pos.x, pos.z, player:get_player_name(), not data.height_mode, data.page);
elseif k == "quit" then elseif k == "quit" then
player_maps[player:get_player_name()] = nil; player_maps[player:get_player_name()] = nil;
end end
@ -345,6 +361,13 @@ minetest.register_node("cartographer:map", {
end, end,
}); });
-- Create an empty map item with the given parameters
--
-- size: The size of the map
-- detail: The detail level of the map
-- scale: The scaling factor of the map
--
-- Returns an ItemStack
local function create_map_item(size, detail, scale) local function create_map_item(size, detail, scale)
local map = ItemStack("cartographer:map"); local map = ItemStack("cartographer:map");
local meta = map:get_meta(); local meta = map:get_meta();
@ -357,9 +380,10 @@ local function create_map_item(size, detail, scale)
end end
-- Create a copy of the given map -- Create a copy of the given map
--
-- stack: An itemstack containing a map -- stack: An itemstack containing a map
-- --
-- Returns an itemstack with the copied map -- Returns a new ItemStack with the copied map
local function copy_map_item(stack) local function copy_map_item(stack)
local meta = stack:get_meta(); local meta = stack:get_meta();
@ -392,6 +416,10 @@ local function copy_map_item(stack)
return copy; return copy;
end end
-- Resize the given map item
--
-- meta: A metadata object containing the map data
-- size: The new size
local function resize_map_item(meta, size) local function resize_map_item(meta, size)
local old_size = meta:get_int("cartographer:size"); local old_size = meta:get_int("cartographer:size");
@ -407,8 +435,8 @@ local function resize_map_item(meta, size)
map:resize(size, size); map:resize(size, size);
meta:set_string("description", map_description(id, meta:set_string("description", map_description(id,
chunk.from(map.x), chunk.from(map.z), chunk.from(map.x), chunk.from(map.z),
chunk.from(map.w), chunk.from(map.h))); chunk.from(map.w), chunk.from(map.h)));
end end
end end

View File

@ -1,5 +1,9 @@
-- Arguments
-- map_data: The map data source
-- chunk: The chunk coordinate conversion API
local map_data, chunk = ...; local map_data, chunk = ...;
-- The map 'class'
local Map = {}; local Map = {};
Map.__index = Map; Map.__index = Map;
@ -7,6 +11,10 @@ for _,loaded_map in ipairs(map_data.maps) do
setmetatable(loaded_map, Map); setmetatable(loaded_map, Map);
end end
-- Resize this map
--
-- w: The new width
-- h: The new height
function Map.resize(self, w, h) function Map.resize(self, w, h)
if w >= self.w and h >= self.h then if w >= self.w and h >= self.h then
self.w = w; self.w = w;
@ -15,6 +23,13 @@ function Map.resize(self, w, h)
end end
end end
-- Fill in a region of this map
--
-- x: The x position, in map coordinates
-- z: The z position, in map coordinates
-- w: The width, in map coordinates
-- h: The height, in map coordinates
function Map.fill_area(self, x, z, w, h) function Map.fill_area(self, x, z, w, h)
for i = math.max(x, self.x),math.min(x + w - 1, self.x + self.w),1 do for i = math.max(x, self.x),math.min(x + w - 1, self.x + self.w),1 do
for j = math.max(z, self.z),math.min(z + h - 1, self.z + self.h),1 do for j = math.max(z, self.z),math.min(z + h - 1, self.z + self.h),1 do
@ -23,6 +38,11 @@ function Map.fill_area(self, x, z, w, h)
end end
end end
-- Set the marker at the given position
--
-- x: The x position, in map coordinates
-- z: The z position, in map coordinates
-- marker: The marker ID to set, or nil to unset
function Map.set_marker(self, x, z, marker) function Map.set_marker(self, x, z, marker)
if x < self.x or x > self.x + self.w or z < self.z or z > self.z + self.h then if x < self.x or x > self.x + self.w or z < self.z or z > self.z + self.h then
return; return;
@ -37,6 +57,12 @@ function Map.set_marker(self, x, z, marker)
end end
end end
-- Get the marker at the given position
--
-- x: The x position, in map coordinates
-- z: The z position, in map coordinates
--
-- Returns a marker id
function Map.get_marker(self, x, z) function Map.get_marker(self, x, z)
if x < self.x or x > self.x + self.w or z < self.z or z > self.z + self.h or not self.markers[x] then if x < self.x or x > self.x + self.w or z < self.z or z > self.z + self.h or not self.markers[x] then
return nil; return nil;
@ -46,6 +72,7 @@ function Map.get_marker(self, x, z)
end end
-- Fill in the local area of a map around a position -- Fill in the local area of a map around a position
--
-- id: A map ID -- id: A map ID
-- x: The x position, in world coordinates -- x: The x position, in world coordinates
-- z: The z position, in world coordinates -- z: The z position, in world coordinates
@ -59,7 +86,7 @@ function Map.fill_local(self, x, z)
end end
-- Convert a position in world coordinates to the given map's coordinate system -- Convert a position in world coordinates to the given map's coordinate system
-- self: The map to use as reference --
-- x: The x position, in world coordinates -- x: The x position, in world coordinates
-- z: The z position, in world coordinates -- z: The z position, in world coordinates
-- --
@ -72,11 +99,27 @@ function Map.to_coordinates(self, x, z)
return math.floor(chunk.to(x) / self.scale + 0.5), math.floor(chunk.to(z) / self.scale + 0.5); return math.floor(chunk.to(x) / self.scale + 0.5), math.floor(chunk.to(z) / self.scale + 0.5);
end end
-- Check if the given position on this map is filled
--
-- x: The x position, in map coordinates
-- z: The z position, in map coordinates
function Map.is_filled(self, x, z) function Map.is_filled(self, x, z)
return self.fill[(x - self.x) + ((z - self.z) * self.w)] ~= nil; return self.fill[(x - self.x) + ((z - self.z) * self.w)] ~= nil;
end end
-- The Map API
local maps = { local maps = {
-- Create a new map object with the given parameters
--
-- x: The x position, in map coordinates
-- z: The z position, in map coordinates
-- w: The width, in map coordinates
-- h: The height, in map coordinates
-- filled: Whether or not the map is pre-filled
-- detail: The detail level
-- scale: The scale factor
--
-- Returns the new map's id
create = function(x, z, w, h, filled, detail, scale) create = function(x, z, w, h, filled, detail, scale)
local id = map_data.next_map_id; local id = map_data.next_map_id;
@ -103,6 +146,11 @@ local maps = {
return id; return id;
end, end,
-- Get the map objwct assigned to the given id
--
-- id: The map id
--
-- Returns a map object, or nil if the id is invalid
get = function(id) get = function(id)
return map_data.maps[id]; return map_data.maps[id];
end, end,

View File

@ -1,5 +1,10 @@
-- Arguments -- Arguments
-- map_data: The cartographer map data table -- map_data: The cartographer map data table
-- gui: The GUI API
-- skin: The GUI skin
-- util: API for uncategorized utility methods
-- biomes: The biome API
-- markers: The marker API
local map_data, gui, skin, util, biomes, markers = ...; local map_data, gui, skin, util, biomes, markers = ...;
-- Constants -- Constants

View File

@ -3,6 +3,7 @@ local marker_lookup = {};
-- Format marker ids to allow their use as formspec element ids. -- Format marker ids to allow their use as formspec element ids.
-- We're mostly concerned with guarding against the : character because it is -- We're mostly concerned with guarding against the : character because it is
-- common for ids and has an alternate meaning in formspecs. -- common for ids and has an alternate meaning in formspecs.
--
-- id: The id to format -- id: The id to format
-- --
-- Returns the formatted id -- Returns the formatted id
@ -11,6 +12,7 @@ local function format_marker_id(id)
end end
-- Find the marker data for a given id -- Find the marker data for a given id
--
-- id: The id to search for -- id: The id to search for
-- --
-- Returns the marker data, or nil if not found -- Returns the marker data, or nil if not found
@ -44,6 +46,7 @@ local function get_registered_markers()
end end
-- Register a marker with textures to display -- Register a marker with textures to display
--
-- id: A string containing the id of the marker -- id: A string containing the id of the marker
-- name: A string containing the displayedname of the marker -- name: A string containing the displayedname of the marker
-- textures: A table of texture names. -- textures: A table of texture names.
@ -69,6 +72,7 @@ local function add_marker(id, name, textures)
end end
-- Get the texture name (minus extension) for the given marker and detail level. -- Get the texture name (minus extension) for the given marker and detail level.
--
-- id: A string containing the marker id -- id: A string containing the marker id
-- detail: The detail level -- detail: The detail level
-- Returns a string with a texture name, or nil if no matching marker was found. -- Returns a string with a texture name, or nil if no matching marker was found.

View File

@ -3,6 +3,7 @@ local materials_by_group = {};
return { return {
-- Get the converted material value of the given itemstack -- Get the converted material value of the given itemstack
--
-- stack: The itemstack to convert -- stack: The itemstack to convert
-- --
-- Returns a table with the material values -- Returns a table with the material values
@ -34,6 +35,11 @@ return {
}; };
end, end,
-- Register a material from an item name
--
-- name: The name of the item
-- material: The material type to set
-- value: The material value
register_by_name = function(name, material, value) register_by_name = function(name, material, value)
if materials_by_name[name] then if materials_by_name[name] then
materials_by_name[name][material] = value or 1; materials_by_name[name][material] = value or 1;
@ -44,6 +50,11 @@ return {
end end
end, end,
-- Register a material from an item group
--
-- group: The name of the group
-- material: The material type to set
-- value: The material value
register_by_group = function(name, material, value) register_by_group = function(name, material, value)
if materials_by_group[name] then if materials_by_group[name] then
materials_by_group[name][material] = value or 1; materials_by_group[name][material] = value or 1;

View File

@ -1,2 +1,2 @@
name = cartographer name = cartographer
description = A game-agnostic mapmaking API. Needs additional mods to function. description = A mapmaking API. Needs additional mods to function.

View File

@ -1,5 +1,6 @@
-- Arguments -- Arguments
-- map_data: The cartographer map data table -- map_data: The cartographer map data table
-- chunk: The chunk coordinate conversion API
local map_data, chunk = ...; local map_data, chunk = ...;
local scan_queue = {}; local scan_queue = {};
@ -34,6 +35,14 @@ local function register_tile(x, y, biome, height, manual_scan)
end end
end end
-- Get the biome and height data for a region from mapgen data
--
-- min: The min coord of the generated terrain
-- max: The max coord of the generated terrain
-- mmin: The min coord of the region to scan
-- mmax: The max coord of the region to scan
--
-- Returns the biome and height of the scanned region
local function get_mapgen_biome(min, max, mmin, mmax) local function get_mapgen_biome(min, max, mmin, mmax)
local UNDERGROUND = minetest.get_biome_id("underground"); local UNDERGROUND = minetest.get_biome_id("underground");
local DEFAULT = minetest.get_biome_id("default"); local DEFAULT = minetest.get_biome_id("default");
@ -79,6 +88,12 @@ local function get_mapgen_biome(min, max, mmin, mmax)
return biome, avg_height; return biome, avg_height;
end end
-- Get the biome and height data for a region from existing terrain
--
-- min: The min coord of the region to scan
-- max: The max coord of the region to scan
--
-- Returns the biome and height of the scanned region
local function get_biome(min, max) local function get_biome(min, max)
local UNDERGROUND = minetest.get_biome_id("underground"); local UNDERGROUND = minetest.get_biome_id("underground");
local DEFAULT = minetest.get_biome_id("default"); local DEFAULT = minetest.get_biome_id("default");
@ -122,6 +137,10 @@ local function get_biome(min, max)
return biome, avg_height; return biome, avg_height;
end end
-- Called when new terrain is generated
--
-- min: The min coord of the generated terrain
-- max: The max coord of the generated terrain
local function on_generated(min, max, _) local function on_generated(min, max, _)
for i = chunk.to(min.x),chunk.to(max.x),1 do for i = chunk.to(min.x),chunk.to(max.x),1 do
for j = chunk.to(min.z),chunk.to(max.z),1 do for j = chunk.to(min.z),chunk.to(max.z),1 do
@ -144,10 +163,10 @@ local function on_generated(min, max, _)
end end
end end
end end
minetest.register_on_generated(on_generated); minetest.register_on_generated(on_generated);
-- Is the scan of this position already handled? -- Is the scan of this position already handled?
--
-- x: The x position, in map coordinates -- x: The x position, in map coordinates
-- y: The y position, in world coordinates -- y: The y position, in world coordinates
-- x: The z position, in map coordinates -- x: The z position, in map coordinates
@ -166,6 +185,7 @@ end
local scanner = {}; local scanner = {};
-- Queue a tile for manual scanning -- Queue a tile for manual scanning
--
-- pos: The position as a table, in world coordinates -- pos: The position as a table, in world coordinates
function scanner.queue_region(pos) function scanner.queue_region(pos)
local converted = { local converted = {

View File

@ -178,6 +178,9 @@ return {
radius = 8, radius = 8,
}, },
-- The texture of the height toggle button when active
height_button_texture = "cartographer_height_button", height_button_texture = "cartographer_height_button",
-- The texture of the height toggle button when inactive
flat_button_texture = "cartographer_flat_button", flat_button_texture = "cartographer_flat_button",
}; };

View File

@ -1,20 +1,32 @@
-- Storage and saving -- Storage and saving
local mod_storage = minetest.get_mod_storage(); local mod_storage = minetest.get_mod_storage();
local map_data = { local map_data = {
-- Scanned map data
generated = minetest.deserialize(mod_storage:get_string("map")) or {}, generated = minetest.deserialize(mod_storage:get_string("map")) or {},
-- Maps
maps = minetest.deserialize(mod_storage:get_string("maps")) or {}, maps = minetest.deserialize(mod_storage:get_string("maps")) or {},
-- The next id
next_map_id = mod_storage:get_int("next_map_id"), next_map_id = mod_storage:get_int("next_map_id"),
-- The version of the map api
api_version = mod_storage:get_int("api_version"),
}; };
if map_data.next_map_id == 0 then if map_data.next_map_id == 0 then
map_data.next_map_id = 1; map_data.next_map_id = 1;
end end
if map_data.api_version == 0 then
map_data.api_version = 1;
end
local function save() local function save()
mod_storage:set_string("maps", minetest.serialize(map_data.maps)); mod_storage:set_string("maps", minetest.serialize(map_data.maps));
mod_storage:set_int("next_map_id", map_data.next_map_id); mod_storage:set_int("next_map_id", map_data.next_map_id);
mod_storage:set_string("map", minetest.serialize(map_data.generated)); mod_storage:set_string("map", minetest.serialize(map_data.generated));
mod_storage:set_string("api_version", minetest.serialize(map_data.api_version));
end end
minetest.register_on_shutdown(save); minetest.register_on_shutdown(save);
minetest.register_on_leaveplayer(save); minetest.register_on_leaveplayer(save);