Overall improvements to log messages (#9598)

Hide some unnecessarily verbose ones behind --trace or disable them entirely.
Remove duplicate ones. Improve their contents in some places.
This commit is contained in:
sfan5 2020-04-08 20:13:23 +02:00 committed by GitHub
parent 3494475df1
commit de73f989eb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
22 changed files with 87 additions and 111 deletions

View File

@ -60,6 +60,20 @@ with this program; if not, write to the Free Software Foundation, Inc.,
extern gui::IGUIEnvironment* guienv; extern gui::IGUIEnvironment* guienv;
/*
Utility classes
*/
void PacketCounter::print(std::ostream &o) const
{
for (const auto &it : m_packets) {
auto name = it.first >= TOCLIENT_NUM_MSG_TYPES ? "?"
: toClientCommandTable[it.first].name;
o << "cmd " << it.first << " (" << name << ") count "
<< it.second << std::endl;
}
}
/* /*
Client Client
*/ */
@ -336,12 +350,12 @@ void Client::step(float dtime)
{ {
float &counter = m_packetcounter_timer; float &counter = m_packetcounter_timer;
counter -= dtime; counter -= dtime;
if(counter <= 0.0) if(counter <= 0.0f)
{ {
counter = 20.0; counter = 30.0f;
infostream << "Client packetcounter (" << m_packetcounter_timer infostream << "Client packetcounter (" << m_packetcounter_timer
<< "):"<<std::endl; << "s):"<<std::endl;
m_packetcounter.print(infostream); m_packetcounter.print(infostream);
m_packetcounter.clear(); m_packetcounter.clear();
} }
@ -621,14 +635,17 @@ void Client::step(float dtime)
m_mod_storage_save_timer -= dtime; m_mod_storage_save_timer -= dtime;
if (m_mod_storage_save_timer <= 0.0f) { if (m_mod_storage_save_timer <= 0.0f) {
verbosestream << "Saving registered mod storages." << std::endl;
m_mod_storage_save_timer = g_settings->getFloat("server_map_save_interval"); m_mod_storage_save_timer = g_settings->getFloat("server_map_save_interval");
int n = 0;
for (std::unordered_map<std::string, ModMetadata *>::const_iterator for (std::unordered_map<std::string, ModMetadata *>::const_iterator
it = m_mod_storages.begin(); it != m_mod_storages.end(); ++it) { it = m_mod_storages.begin(); it != m_mod_storages.end(); ++it) {
if (it->second->isModified()) { if (it->second->isModified()) {
it->second->save(getModStoragePath()); it->second->save(getModStoragePath());
n++;
} }
} }
if (n > 0)
infostream << "Saved " << n << " modified mod storages." << std::endl;
} }
// Write server map // Write server map
@ -653,8 +670,8 @@ bool Client::loadMedia(const std::string &data, const std::string &filename)
}; };
name = removeStringEnd(filename, image_ext); name = removeStringEnd(filename, image_ext);
if (!name.empty()) { if (!name.empty()) {
verbosestream<<"Client: Attempting to load image " TRACESTREAM(<< "Client: Attempting to load image "
<<"file \""<<filename<<"\""<<std::endl; << "file \"" << filename << "\"" << std::endl);
io::IFileSystem *irrfs = RenderingEngine::get_filesystem(); io::IFileSystem *irrfs = RenderingEngine::get_filesystem();
video::IVideoDriver *vdrv = RenderingEngine::get_video_driver(); video::IVideoDriver *vdrv = RenderingEngine::get_video_driver();
@ -687,10 +704,9 @@ bool Client::loadMedia(const std::string &data, const std::string &filename)
}; };
name = removeStringEnd(filename, sound_ext); name = removeStringEnd(filename, sound_ext);
if (!name.empty()) { if (!name.empty()) {
verbosestream<<"Client: Attempting to load sound " TRACESTREAM(<< "Client: Attempting to load sound "
<<"file \""<<filename<<"\""<<std::endl; << "file \"" << filename << "\"" << std::endl);
m_sound->loadSoundData(name, data); return m_sound->loadSoundData(name, data);
return true;
} }
const char *model_ext[] = { const char *model_ext[] = {
@ -714,8 +730,8 @@ bool Client::loadMedia(const std::string &data, const std::string &filename)
}; };
name = removeStringEnd(filename, translate_ext); name = removeStringEnd(filename, translate_ext);
if (!name.empty()) { if (!name.empty()) {
verbosestream << "Client: Loading translation: " TRACESTREAM(<< "Client: Loading translation: "
<< "\"" << filename << "\"" << std::endl; << "\"" << filename << "\"" << std::endl);
g_translations->loadTranslation(data); g_translations->loadTranslation(data);
return true; return true;
} }

View File

@ -82,30 +82,19 @@ public:
void add(u16 command) void add(u16 command)
{ {
std::map<u16, u16>::iterator n = m_packets.find(command); auto n = m_packets.find(command);
if(n == m_packets.end()) if (n == m_packets.end())
{
m_packets[command] = 1; m_packets[command] = 1;
}
else else
{
n->second++; n->second++;
}
} }
void clear() void clear()
{ {
for (auto &m_packet : m_packets) { m_packets.clear();
m_packet.second = 0;
}
} }
void print(std::ostream &o) void print(std::ostream &o) const;
{
for (const auto &m_packet : m_packets) {
o << "cmd "<< m_packet.first <<" count "<< m_packet.second << std::endl;
}
}
private: private:
// command, count // command, count

View File

@ -576,9 +576,10 @@ void GenericCAO::addToScene(ITextureSource *tsrc)
m_visuals_expired = false; m_visuals_expired = false;
if (!m_prop.is_visible) { if (!m_prop.is_visible)
return; return;
}
infostream << "GenericCAO::addToScene(): " << m_prop.visual << std::endl;
if (m_enable_shaders) { if (m_enable_shaders) {
IShaderSource *shader_source = m_client->getShaderSource(); IShaderSource *shader_source = m_client->getShaderSource();
@ -593,7 +594,6 @@ void GenericCAO::addToScene(ITextureSource *tsrc)
} }
auto grabMatrixNode = [this] { auto grabMatrixNode = [this] {
infostream << "GenericCAO::addToScene(): " << m_prop.visual << std::endl;
m_matrixnode = RenderingEngine::get_scene_manager()-> m_matrixnode = RenderingEngine::get_scene_manager()->
addDummyTransformationSceneNode(); addDummyTransformationSceneNode();
m_matrixnode->grab(); m_matrixnode->grab();

View File

@ -239,7 +239,7 @@ void FontEngine::updateSkin()
FATAL_ERROR_IF(font == NULL, "Could not create/get font"); FATAL_ERROR_IF(font == NULL, "Could not create/get font");
u32 text_height = font->getDimension(L"Hello, world!").Height; u32 text_height = font->getDimension(L"Hello, world!").Height;
infostream << "text_height=" << text_height << std::endl; infostream << "FontEngine: measured text_height=" << text_height << std::endl;
} }
/******************************************************************************/ /******************************************************************************/

View File

@ -2010,7 +2010,6 @@ void Game::processItemSelection(u16 *new_playeritem)
for (u16 i = 0; i <= max_item; i++) { for (u16 i = 0; i <= max_item; i++) {
if (wasKeyDown((GameKeyType) (KeyType::SLOT_1 + i))) { if (wasKeyDown((GameKeyType) (KeyType::SLOT_1 + i))) {
*new_playeritem = i; *new_playeritem = i;
infostream << "Selected item: " << new_playeritem << std::endl;
break; break;
} }
} }
@ -2039,7 +2038,7 @@ void Game::openInventory()
if (!player || !player->getCAO()) if (!player || !player->getCAO())
return; return;
infostream << "the_game: " << "Launching inventory" << std::endl; infostream << "Game: Launching inventory" << std::endl;
PlayerInventoryFormSource *fs_src = new PlayerInventoryFormSource(client); PlayerInventoryFormSource *fs_src = new PlayerInventoryFormSource(client);

View File

@ -226,27 +226,17 @@ bool RenderingEngine::setupTopLevelWindow(const std::string &name)
{ {
// FIXME: It would make more sense for there to be a switch of some // FIXME: It would make more sense for there to be a switch of some
// sort here that would call the correct toplevel setup methods for // sort here that would call the correct toplevel setup methods for
// the environment Minetest is running in but for now not deviating // the environment Minetest is running in.
// from the original pattern.
/* Setting Xorg properties for the top level window */ /* Setting Xorg properties for the top level window */
setupTopLevelXorgWindow(name); setupTopLevelXorgWindow(name);
/* Done with Xorg properties */
/* Setting general properties for the top level window */ /* Setting general properties for the top level window */
verbosestream << "Client: Configuring general top level" verbosestream << "Client: Configuring general top level"
<< " window properties" << " window properties"
<< std::endl; << std::endl;
bool result = setWindowIcon(); bool result = setWindowIcon();
verbosestream << "Client: Finished configuring general top level"
<< " window properties"
<< std::endl;
/* Done with general properties */
// FIXME: setWindowIcon returns a bool result but it is unused.
// For now continue to return this result.
return result; return result;
} }
@ -262,7 +252,7 @@ void RenderingEngine::setupTopLevelXorgWindow(const std::string &name)
return; return;
} }
verbosestream << "Client: Configuring Xorg specific top level" verbosestream << "Client: Configuring X11-specific top level"
<< " window properties" << " window properties"
<< std::endl; << std::endl;
@ -309,8 +299,6 @@ void RenderingEngine::setupTopLevelXorgWindow(const std::string &name)
Atom NET_WM_PID = XInternAtom(x11_dpl, "_NET_WM_PID", false); Atom NET_WM_PID = XInternAtom(x11_dpl, "_NET_WM_PID", false);
pid_t pid = getpid(); pid_t pid = getpid();
infostream << "Client: PID is '" << static_cast<long>(pid) << "'"
<< std::endl;
XChangeProperty(x11_dpl, x11_win, NET_WM_PID, XChangeProperty(x11_dpl, x11_win, NET_WM_PID,
XA_CARDINAL, 32, PropModeReplace, XA_CARDINAL, 32, PropModeReplace,
@ -327,10 +315,6 @@ void RenderingEngine::setupTopLevelXorgWindow(const std::string &name)
XChangeProperty (x11_dpl, x11_win, WM_CLIENT_LEADER, XChangeProperty (x11_dpl, x11_win, WM_CLIENT_LEADER,
XA_WINDOW, 32, PropModeReplace, XA_WINDOW, 32, PropModeReplace,
reinterpret_cast<unsigned char *>(&x11_win), 1); reinterpret_cast<unsigned char *>(&x11_win), 1);
verbosestream << "Client: Finished configuring Xorg specific top level"
<< " window properties"
<< std::endl;
#endif #endif
} }

View File

@ -165,8 +165,8 @@ SoundBuffer *load_opened_ogg_file(OggVorbis_File *oggFile,
<< "preparing sound buffer" << std::endl; << "preparing sound buffer" << std::endl;
} }
infostream << "Audio file " //infostream << "Audio file "
<< filename_for_logging << " loaded" << std::endl; // << filename_for_logging << " loaded" << std::endl;
// Clean up! // Clean up!
ov_clear(oggFile); ov_clear(oggFile);
@ -498,9 +498,11 @@ public:
// Remove stopped sounds // Remove stopped sounds
void maintain() void maintain()
{ {
verbosestream<<"OpenALSoundManager::maintain(): " if (!m_sounds_playing.empty()) {
<<m_sounds_playing.size()<<" playing sounds, " verbosestream << "OpenALSoundManager::maintain(): "
<<m_buffers.size()<<" sound names loaded"<<std::endl; << m_sounds_playing.size() <<" playing sounds, "
<< m_buffers.size() <<" sound names loaded"<<std::endl;
}
std::unordered_set<int> del_list; std::unordered_set<int> del_list;
for (const auto &sp : m_sounds_playing) { for (const auto &sp : m_sounds_playing) {
int id = sp.first; int id = sp.first;
@ -530,7 +532,7 @@ public:
SoundBuffer *buf = load_ogg_from_file(filepath); SoundBuffer *buf = load_ogg_from_file(filepath);
if (buf) if (buf)
addBuffer(name, buf); addBuffer(name, buf);
return false; return !!buf;
} }
bool loadSoundData(const std::string &name, bool loadSoundData(const std::string &name,
@ -539,7 +541,7 @@ public:
SoundBuffer *buf = load_ogg_from_buffer(filedata, name); SoundBuffer *buf = load_ogg_from_buffer(filedata, name);
if (buf) if (buf)
addBuffer(name, buf); addBuffer(name, buf);
return false; return !!buf;
} }
void updateListener(const v3f &pos, const v3f &vel, const v3f &at, const v3f &up) void updateListener(const v3f &pos, const v3f &vel, const v3f &at, const v3f &up)

View File

@ -471,8 +471,8 @@ TextureSource::~TextureSource()
driver->removeTexture(t); driver->removeTexture(t);
} }
infostream << "~TextureSource() "<< textures_before << "/" infostream << "~TextureSource() before cleanup: "<< textures_before
<< driver->getTextureCount() << std::endl; << " after: " << driver->getTextureCount() << std::endl;
} }
u32 TextureSource::getTextureId(const std::string &name) u32 TextureSource::getTextureId(const std::string &name)
@ -763,6 +763,9 @@ void TextureSource::rebuildImagesAndTextures()
video::IVideoDriver *driver = RenderingEngine::get_video_driver(); video::IVideoDriver *driver = RenderingEngine::get_video_driver();
sanity_check(driver); sanity_check(driver);
infostream << "TextureSource: recreating " << m_textureinfo_cache.size()
<< " textures" << std::endl;
// Recreate textures // Recreate textures
for (TextureInfo &ti : m_textureinfo_cache) { for (TextureInfo &ti : m_textureinfo_cache) {
video::IImage *img = generateImage(ti.name); video::IImage *img = generateImage(ti.name);
@ -1270,8 +1273,6 @@ bool TextureSource::generateImagePart(std::string part_of_name,
video::IImage *img = generateImage(filename); video::IImage *img = generateImage(filename);
if (img) { if (img) {
core::dimension2d<u32> dim = img->getDimension(); core::dimension2d<u32> dim = img->getDimension();
infostream<<"Size "<<dim.Width
<<"x"<<dim.Height<<std::endl;
core::position2d<s32> pos_base(x, y); core::position2d<s32> pos_base(x, y);
video::IImage *img2 = video::IImage *img2 =
driver->createImage(video::ECF_A8R8G8B8, dim); driver->createImage(video::ECF_A8R8G8B8, dim);

View File

@ -253,7 +253,7 @@ std::vector<WorldSpec> getAvailableWorlds()
worldspaths.insert(porting::path_user + DIR_DELIM + "worlds"); worldspaths.insert(porting::path_user + DIR_DELIM + "worlds");
infostream << "Searching worlds..." << std::endl; infostream << "Searching worlds..." << std::endl;
for (const std::string &worldspath : worldspaths) { for (const std::string &worldspath : worldspaths) {
infostream << " In " << worldspath << ": " << std::endl; infostream << " In " << worldspath << ": ";
std::vector<fs::DirListNode> dirvector = fs::GetDirListing(worldspath); std::vector<fs::DirListNode> dirvector = fs::GetDirListing(worldspath);
for (const fs::DirListNode &dln : dirvector) { for (const fs::DirListNode &dln : dirvector) {
if (!dln.dir) if (!dln.dir)

View File

@ -711,13 +711,11 @@ float LuaEntitySAO::getMinimumSavedMovement()
std::string LuaEntitySAO::getDescription() std::string LuaEntitySAO::getDescription()
{ {
std::ostringstream os(std::ios::binary); std::ostringstream oss;
os<<"LuaEntitySAO at ("; oss << "LuaEntitySAO \"" << m_init_name << "\" ";
os<<(m_base_position.X/BS)<<","; auto pos = floatToInt(m_base_position, BS);
os<<(m_base_position.Y/BS)<<","; oss << "at " << PP(pos);
os<<(m_base_position.Z/BS); return oss.str();
os<<")";
return os.str();
} }
void LuaEntitySAO::setHP(s32 hp, const PlayerHPChangeReason &reason) void LuaEntitySAO::setHP(s32 hp, const PlayerHPChangeReason &reason)

View File

@ -1066,8 +1066,8 @@ public:
} }
virtual void registerCraft(CraftDefinition *def, IGameDef *gamedef) virtual void registerCraft(CraftDefinition *def, IGameDef *gamedef)
{ {
verbosestream << "registerCraft: registering craft definition: " TRACESTREAM(<< "registerCraft: registering craft definition: "
<< def->dump() << std::endl; << def->dump() << std::endl);
m_craft_defs[(int) CRAFT_HASH_TYPE_UNHASHED][0].push_back(def); m_craft_defs[(int) CRAFT_HASH_TYPE_UNHASHED][0].push_back(def);
CraftInput input; CraftInput input;

View File

@ -136,7 +136,6 @@ EmergeManager::EmergeManager(Server *server)
nthreads = Thread::getNumberOfProcessors() - 2; nthreads = Thread::getNumberOfProcessors() - 2;
if (nthreads < 1) if (nthreads < 1)
nthreads = 1; nthreads = 1;
verbosestream << "Using " << nthreads << " emerge threads." << std::endl;
m_qlimit_total = g_settings->getU16("emergequeue_limit_total"); m_qlimit_total = g_settings->getU16("emergequeue_limit_total");
if (!g_settings->getU16NoEx("emergequeue_limit_diskonly", m_qlimit_diskonly)) if (!g_settings->getU16NoEx("emergequeue_limit_diskonly", m_qlimit_diskonly))

View File

@ -463,7 +463,7 @@ public:
} }
virtual void registerItem(const ItemDefinition &def) virtual void registerItem(const ItemDefinition &def)
{ {
verbosestream<<"ItemDefManager: registering \""<<def.name<<"\""<<std::endl; TRACESTREAM(<< "ItemDefManager: registering " << def.name << std::endl);
// Ensure that the "" item (the hand) always has ToolCapabilities // Ensure that the "" item (the hand) always has ToolCapabilities
if (def.name.empty()) if (def.name.empty())
FATAL_ERROR_IF(!def.tool_capabilities, "Hand does not have ToolCapabilities"); FATAL_ERROR_IF(!def.tool_capabilities, "Hand does not have ToolCapabilities");
@ -490,8 +490,8 @@ public:
const std::string &convert_to) const std::string &convert_to)
{ {
if (m_item_definitions.find(name) == m_item_definitions.end()) { if (m_item_definitions.find(name) == m_item_definitions.end()) {
verbosestream<<"ItemDefManager: setting alias "<<name TRACESTREAM(<< "ItemDefManager: setting alias " << name
<<" -> "<<convert_to<<std::endl; << " -> " << convert_to << std::endl);
m_aliases[name] = convert_to; m_aliases[name] = convert_to;
} }
} }

View File

@ -207,9 +207,6 @@ int main(int argc, char *argv[])
sanity_check(!game_params.world_path.empty()); sanity_check(!game_params.world_path.empty());
infostream << "Using commanded world path ["
<< game_params.world_path << "]" << std::endl;
if (game_params.is_dedicated_server) if (game_params.is_dedicated_server)
return run_dedicated_server(game_params, cmd_args) ? 0 : 1; return run_dedicated_server(game_params, cmd_args) ? 0 : 1;
@ -686,8 +683,6 @@ static bool auto_select_world(GameParams *game_params)
// No world was specified; try to select it automatically // No world was specified; try to select it automatically
// Get information about available worlds // Get information about available worlds
verbosestream << _("Determining world path") << std::endl;
std::vector<WorldSpec> worldspecs = getAvailableWorlds(); std::vector<WorldSpec> worldspecs = getAvailableWorlds();
std::string world_path; std::string world_path;
@ -708,7 +703,7 @@ static bool auto_select_world(GameParams *game_params)
// This is the ultimate default world path // This is the ultimate default world path
world_path = porting::path_user + DIR_DELIM + "worlds" + world_path = porting::path_user + DIR_DELIM + "worlds" +
DIR_DELIM + "world"; DIR_DELIM + "world";
infostream << "Creating default world at [" infostream << "Using default world at ["
<< world_path << "]" << std::endl; << world_path << "]" << std::endl;
} }
@ -770,7 +765,6 @@ static bool determine_subgame(GameParams *game_params)
assert(game_params->world_path != ""); // Pre-condition assert(game_params->world_path != ""); // Pre-condition
verbosestream << _("Determining gameid/gamespec") << std::endl;
// If world doesn't exist // If world doesn't exist
if (!game_params->world_path.empty() if (!game_params->world_path.empty()
&& !getWorldExists(game_params->world_path)) { && !getWorldExists(game_params->world_path)) {

View File

@ -1827,10 +1827,10 @@ void ServerMap::save(ModifiedState save_level)
*/ */
if(save_level == MOD_STATE_CLEAN if(save_level == MOD_STATE_CLEAN
|| block_count != 0) { || block_count != 0) {
infostream<<"ServerMap: Written: " infostream << "ServerMap: Written: "
<<block_count<<" block files" << block_count << " blocks"
<<", "<<block_count_all<<" blocks in memory." << ", " << block_count_all << " blocks in memory."
<<std::endl; << std::endl;
PrintInfo(infostream); // ServerMap/ClientMap: PrintInfo(infostream); // ServerMap/ClientMap:
infostream<<"Blocks modified by: "<<std::endl; infostream<<"Blocks modified by: "<<std::endl;
modprofiler.print(infostream); modprofiler.print(infostream);

View File

@ -386,10 +386,10 @@ void Client::handleCommand_TimeOfDay(NetworkPacket* pkt)
m_env.setTimeOfDaySpeed(time_speed); m_env.setTimeOfDaySpeed(time_speed);
m_time_of_day_set = true; m_time_of_day_set = true;
u32 dr = m_env.getDayNightRatio(); //u32 dr = m_env.getDayNightRatio();
infostream << "Client: time_of_day=" << time_of_day //infostream << "Client: time_of_day=" << time_of_day
<< " time_speed=" << time_speed // << " time_speed=" << time_speed
<< " dr=" << dr << std::endl; // << " dr=" << dr << std::endl;
} }
void Client::handleCommand_ChatMessage(NetworkPacket *pkt) void Client::handleCommand_ChatMessage(NetworkPacket *pkt)

View File

@ -199,7 +199,6 @@ void ConnectionSendThread::runTimeouts(float dtime)
infostream << m_connection->getDesc() infostream << m_connection->getDesc()
<< "RunTimeouts(): Peer " << peer->id << "RunTimeouts(): Peer " << peer->id
<< " has timed out." << " has timed out."
<< " (source=peer->timeout_counter)"
<< std::endl; << std::endl;
// Add peer to the list // Add peer to the list
timeouted_peers.push_back(peer->id); timeouted_peers.push_back(peer->id);
@ -292,7 +291,7 @@ void ConnectionSendThread::runTimeouts(float dtime)
// Remove timed out peers // Remove timed out peers
for (u16 timeouted_peer : timeouted_peers) { for (u16 timeouted_peer : timeouted_peers) {
LOG(derr_con << m_connection->getDesc() LOG(dout_con << m_connection->getDesc()
<< "RunTimeouts(): Removing peer " << timeouted_peer << std::endl); << "RunTimeouts(): Removing peer " << timeouted_peer << std::endl);
m_connection->deletePeer(timeouted_peer, true); m_connection->deletePeer(timeouted_peer, true);
} }

View File

@ -1458,7 +1458,7 @@ void NodeDefManager::deSerialize(std::istream &is)
m_content_features.resize((u32)(i) + 1); m_content_features.resize((u32)(i) + 1);
m_content_features[i] = f; m_content_features[i] = f;
addNameIdMapping(i, f.name); addNameIdMapping(i, f.name);
verbosestream << "deserialized " << f.name << std::endl; TRACESTREAM(<< "NodeDef: deserialized " << f.name << std::endl);
getNodeBoxUnion(f.selection_box, f, &m_selection_box_union); getNodeBoxUnion(f.selection_box, f, &m_selection_box_union);
fixSelectionBoxIntUnion(); fixSelectionBoxIntUnion();

View File

@ -86,7 +86,7 @@ void ScriptApiEnv::player_event(ServerActiveObject *player, const std::string &t
void ScriptApiEnv::initializeEnvironment(ServerEnvironment *env) void ScriptApiEnv::initializeEnvironment(ServerEnvironment *env)
{ {
SCRIPTAPI_PRECHECKHEADER SCRIPTAPI_PRECHECKHEADER
verbosestream << "scriptapi_add_environment" << std::endl; verbosestream << "ScriptApiEnv: Environment initialized" << std::endl;
setEnv(env); setEnv(env);
/* /*

View File

@ -522,7 +522,6 @@ int ModApiItemMod::l_register_item_raw(lua_State *L)
lua_getfield(L, table, "name"); lua_getfield(L, table, "name");
if(lua_isstring(L, -1)){ if(lua_isstring(L, -1)){
name = readParam<std::string>(L, -1); name = readParam<std::string>(L, -1);
verbosestream<<"register_item_raw: "<<name<<std::endl;
} else { } else {
throw LuaError("register_item_raw: name is not defined or not a string"); throw LuaError("register_item_raw: name is not defined or not a string");
} }

View File

@ -656,14 +656,17 @@ void Server::AsyncRunStep(bool initial_step)
// Save mod storages if modified // Save mod storages if modified
m_mod_storage_save_timer -= dtime; m_mod_storage_save_timer -= dtime;
if (m_mod_storage_save_timer <= 0.0f) { if (m_mod_storage_save_timer <= 0.0f) {
infostream << "Saving registered mod storages." << std::endl;
m_mod_storage_save_timer = g_settings->getFloat("server_map_save_interval"); m_mod_storage_save_timer = g_settings->getFloat("server_map_save_interval");
int n = 0;
for (std::unordered_map<std::string, ModMetadata *>::const_iterator for (std::unordered_map<std::string, ModMetadata *>::const_iterator
it = m_mod_storages.begin(); it != m_mod_storages.end(); ++it) { it = m_mod_storages.begin(); it != m_mod_storages.end(); ++it) {
if (it->second->isModified()) { if (it->second->isModified()) {
it->second->save(getModStoragePath()); it->second->save(getModStoragePath());
n++;
} }
} }
if (n > 0)
infostream << "Saved " << n << " modified mod storages." << std::endl;
} }
} }
@ -809,7 +812,6 @@ void Server::AsyncRunStep(bool initial_step)
disable_single_change_sending ? 5 : 30); disable_single_change_sending ? 5 : 30);
break; break;
case MEET_BLOCK_NODE_METADATA_CHANGED: { case MEET_BLOCK_NODE_METADATA_CHANGED: {
verbosestream << "Server: MEET_BLOCK_NODE_METADATA_CHANGED" << std::endl;
prof.add("MEET_BLOCK_NODE_METADATA_CHANGED", 1); prof.add("MEET_BLOCK_NODE_METADATA_CHANGED", 1);
if (!event->is_private_change) { if (!event->is_private_change) {
// Don't send the change yet. Collect them to eliminate dupes. // Don't send the change yet. Collect them to eliminate dupes.
@ -825,7 +827,6 @@ void Server::AsyncRunStep(bool initial_step)
break; break;
} }
case MEET_OTHER: case MEET_OTHER:
infostream << "Server: MEET_OTHER" << std::endl;
prof.add("MEET_OTHER", 1); prof.add("MEET_OTHER", 1);
for (const v3s16 &modified_block : event->modified_blocks) { for (const v3s16 &modified_block : event->modified_blocks) {
m_clients.markBlockposAsNotSent(modified_block); m_clients.markBlockposAsNotSent(modified_block);
@ -2535,9 +2536,6 @@ void Server::fillMediaCache()
void Server::sendMediaAnnouncement(session_t peer_id, const std::string &lang_code) void Server::sendMediaAnnouncement(session_t peer_id, const std::string &lang_code)
{ {
verbosestream << "Server: Announcing files to id(" << peer_id << ")"
<< std::endl;
// Make packet // Make packet
NetworkPacket pkt(TOCLIENT_ANNOUNCE_MEDIA, 0, peer_id); NetworkPacket pkt(TOCLIENT_ANNOUNCE_MEDIA, 0, peer_id);
@ -2560,6 +2558,9 @@ void Server::sendMediaAnnouncement(session_t peer_id, const std::string &lang_co
pkt << g_settings->get("remote_media"); pkt << g_settings->get("remote_media");
Send(&pkt); Send(&pkt);
verbosestream << "Server: Announcing files to id(" << peer_id
<< "): count=" << media_sent << " size=" << pkt.getSize() << std::endl;
} }
struct SendableMedia struct SendableMedia
@ -2938,10 +2939,8 @@ void Server::UpdateCrafting(RemotePlayer *player)
if (!clist || clist->getSize() == 0) if (!clist || clist->getSize() == 0)
return; return;
if (!clist->checkModified()) { if (!clist->checkModified())
verbosestream << "Skip Server::UpdateCrafting(): list unmodified" << std::endl;
return; return;
}
// Get a preview for crafting // Get a preview for crafting
ItemStack preview; ItemStack preview;

View File

@ -22,6 +22,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#include "log.h" #include "log.h"
#include "scripting_server.h" #include "scripting_server.h"
#include "content/subgames.h" #include "content/subgames.h"
#include "porting.h"
/** /**
* Manage server mods * Manage server mods
@ -66,14 +67,10 @@ void ServerModManager::loadMods(ServerScripting *script)
"Only characters [a-z0-9_] are allowed."); "Only characters [a-z0-9_] are allowed.");
} }
std::string script_path = mod.path + DIR_DELIM + "init.lua"; std::string script_path = mod.path + DIR_DELIM + "init.lua";
infostream << " [" << padStringRight(mod.name, 12) << "] [\"" auto t = porting::getTimeMs();
<< script_path << "\"]" << std::endl;
auto t = std::chrono::steady_clock::now();
script->loadMod(script_path, mod.name); script->loadMod(script_path, mod.name);
infostream << "Mod \"" << mod.name << "\" loaded after " infostream << "Mod \"" << mod.name << "\" loaded after "
<< std::chrono::duration_cast<std::chrono::milliseconds>( << (porting::getTimeMs() - t) << " ms" << std::endl;
std::chrono::steady_clock::now() - t).count() * 0.001f
<< " seconds" << std::endl;
} }
// Run a callback when mods are loaded // Run a callback when mods are loaded